The LAST netwm update. Made all function prototypes similar, return int

on get (error or not) and no return from set.


SVN revision: 15179
This commit is contained in:
sebastid 2005-06-07 15:34:54 +00:00 committed by sebastid
parent 9ee64d258a
commit 990a827101
2 changed files with 114 additions and 231 deletions

View File

@ -1214,28 +1214,28 @@ EAPI int ecore_x_mwm_hints_get(Ecore_X_Window win,
/* netwm */ /* netwm */
EAPI void ecore_x_netwm_init(void); EAPI void ecore_x_netwm_init(void);
EAPI void ecore_x_netwm_wm_identify(Ecore_X_Window root, Ecore_X_Window check, const char *wm_name); EAPI void ecore_x_netwm_wm_identify(Ecore_X_Window root, Ecore_X_Window check, const char *wm_name);
EAPI int ecore_x_netwm_supported_set(Ecore_X_Window root, Ecore_X_Atom *supported, int num); EAPI void ecore_x_netwm_supported_set(Ecore_X_Window root, Ecore_X_Atom *supported, int num);
EAPI Ecore_X_Atom *ecore_x_netwm_supported_get(Ecore_X_Window root, int *num); EAPI int ecore_x_netwm_supported_get(Ecore_X_Window root, Ecore_X_Atom **supported, int *num);
EAPI void ecore_x_netwm_desk_count_set(Ecore_X_Window root, unsigned int n_desks); EAPI void ecore_x_netwm_desk_count_set(Ecore_X_Window root, unsigned int n_desks);
EAPI void ecore_x_netwm_desk_roots_set(Ecore_X_Window root, unsigned int n_desks, Ecore_X_Window * vroots); EAPI void ecore_x_netwm_desk_roots_set(Ecore_X_Window root, Ecore_X_Window *vroots, unsigned int n_desks);
EAPI void ecore_x_netwm_desk_names_set(Ecore_X_Window root, unsigned int n_desks, const char **names); EAPI void ecore_x_netwm_desk_names_set(Ecore_X_Window root, const char **names, unsigned int n_desks);
EAPI void ecore_x_netwm_desk_size_set(Ecore_X_Window root, unsigned int width, unsigned int height); EAPI void ecore_x_netwm_desk_size_set(Ecore_X_Window root, unsigned int width, unsigned int height);
EAPI void ecore_x_netwm_desk_workareas_set(Ecore_X_Window root, unsigned int n_desks, unsigned int *areas); EAPI void ecore_x_netwm_desk_workareas_set(Ecore_X_Window root, unsigned int *areas, unsigned int n_desks);
EAPI void ecore_x_netwm_desk_current_set(Ecore_X_Window root, unsigned int desk); EAPI void ecore_x_netwm_desk_current_set(Ecore_X_Window root, unsigned int desk);
EAPI void ecore_x_netwm_desk_viewports_set(Ecore_X_Window root, unsigned int n_desks, unsigned int *origins); EAPI void ecore_x_netwm_desk_viewports_set(Ecore_X_Window root, unsigned int *origins, unsigned int n_desks);
EAPI void ecore_x_netwm_desk_layout_set(Ecore_X_Window root, int orientation, int columns, int rows, int starting_corner); EAPI void ecore_x_netwm_desk_layout_set(Ecore_X_Window root, int orientation, int columns, int rows, int starting_corner);
EAPI void ecore_x_netwm_showing_desktop_set(Ecore_X_Window root, int on); EAPI void ecore_x_netwm_showing_desktop_set(Ecore_X_Window root, int on);
EAPI void ecore_x_netwm_client_list_set(Ecore_X_Window root, unsigned int n_clients, Ecore_X_Window * p_clients); EAPI void ecore_x_netwm_client_list_set(Ecore_X_Window root, Ecore_X_Window *p_clients, unsigned int n_clients);
EAPI void ecore_x_netwm_client_list_stacking_set(Ecore_X_Window root, unsigned int n_clients, Ecore_X_Window * p_clients); EAPI void ecore_x_netwm_client_list_stacking_set(Ecore_X_Window root, Ecore_X_Window *p_clients, unsigned int n_clients);
EAPI void ecore_x_netwm_client_active_set(Ecore_X_Window root, Ecore_X_Window win); EAPI void ecore_x_netwm_client_active_set(Ecore_X_Window root, Ecore_X_Window win);
EAPI void ecore_x_netwm_name_set(Ecore_X_Window win, const char *name); EAPI void ecore_x_netwm_name_set(Ecore_X_Window win, const char *name);
EAPI char *ecore_x_netwm_name_get(Ecore_X_Window win); EAPI int ecore_x_netwm_name_get(Ecore_X_Window win, char **name);
EAPI void ecore_x_netwm_visible_name_set(Ecore_X_Window win, const char *name); EAPI void ecore_x_netwm_visible_name_set(Ecore_X_Window win, const char *name);
EAPI char *ecore_x_netwm_visible_name_get(Ecore_X_Window win); EAPI int ecore_x_netwm_visible_name_get(Ecore_X_Window win, char **name);
EAPI void ecore_x_netwm_icon_name_set(Ecore_X_Window win, const char *name); EAPI void ecore_x_netwm_icon_name_set(Ecore_X_Window win, const char *name);
EAPI char *ecore_x_netwm_icon_name_get(Ecore_X_Window win); EAPI int ecore_x_netwm_icon_name_get(Ecore_X_Window win, char **name);
EAPI void ecore_x_netwm_visible_icon_name_set(Ecore_X_Window win, const char *name); EAPI void ecore_x_netwm_visible_icon_name_set(Ecore_X_Window win, const char *name);
EAPI char *ecore_x_netwm_visible_icon_name_get(Ecore_X_Window win); EAPI int ecore_x_netwm_visible_icon_name_get(Ecore_X_Window win, char **name);
EAPI void ecore_x_netwm_desktop_set(Ecore_X_Window win, unsigned int desk); EAPI void ecore_x_netwm_desktop_set(Ecore_X_Window win, unsigned int desk);
EAPI int ecore_x_netwm_desktop_get(Ecore_X_Window win, unsigned int *desk); EAPI int ecore_x_netwm_desktop_get(Ecore_X_Window win, unsigned int *desk);
EAPI void ecore_x_netwm_strut_set(Ecore_X_Window win, int left, int right, int top, int bottom); EAPI void ecore_x_netwm_strut_set(Ecore_X_Window win, int left, int right, int top, int bottom);
@ -1251,22 +1251,18 @@ EAPI void ecore_x_netwm_handled_icons_set(Ecore_X_Window win);
EAPI int ecore_x_netwm_handled_icons_get(Ecore_X_Window win); EAPI int ecore_x_netwm_handled_icons_get(Ecore_X_Window win);
EAPI void ecore_x_netwm_user_time_set(Ecore_X_Window win, unsigned int time); EAPI void ecore_x_netwm_user_time_set(Ecore_X_Window win, unsigned int time);
EAPI int ecore_x_netwm_user_time_get(Ecore_X_Window win, unsigned int *time); EAPI int ecore_x_netwm_user_time_get(Ecore_X_Window win, unsigned int *time);
EAPI void ecore_x_netwm_window_state_set(Ecore_X_Window win, Ecore_X_Window_State *state, unsigned int num);
EAPI Ecore_X_Window_State *ecore_x_netwm_window_state_list_get(Ecore_X_Window win, int *num); EAPI int ecore_x_netwm_window_state_get(Ecore_X_Window win, Ecore_X_Window_State **state, unsigned int *num);
EAPI int ecore_x_netwm_window_state_list_set(Ecore_X_Window win, Ecore_X_Window_State *state, int num);
EAPI void ecore_x_netwm_window_state_set(Ecore_X_Window win, Ecore_X_Window_State state, int on);
EAPI int ecore_x_netwm_window_state_isset(Ecore_X_Window win, Ecore_X_Window_State state);
EAPI void ecore_x_netwm_window_type_set(Ecore_X_Window win, Ecore_X_Window_Type type); EAPI void ecore_x_netwm_window_type_set(Ecore_X_Window win, Ecore_X_Window_Type type);
EAPI Ecore_X_Window_Type ecore_x_netwm_window_type_get(Ecore_X_Window win); EAPI int ecore_x_netwm_window_type_get(Ecore_X_Window win, Ecore_X_Window_Type *type);
EAPI int ecore_x_netwm_allowed_action_isset(Ecore_X_Window win, Ecore_X_Action action); EAPI int ecore_x_netwm_allowed_action_isset(Ecore_X_Window win, Ecore_X_Action action);
EAPI void ecore_x_netwm_allowed_action_set(Ecore_X_Window win, Ecore_X_Action action, int on); EAPI void ecore_x_netwm_allowed_action_set(Ecore_X_Window win, Ecore_X_Action action, int on);
EAPI void ecore_x_netwm_opacity_set(Ecore_X_Window win, unsigned int opacity); EAPI void ecore_x_netwm_opacity_set(Ecore_X_Window win, unsigned int opacity);
EAPI int ecore_x_netwm_opacity_get(Ecore_X_Window win, unsigned int *opacity); EAPI int ecore_x_netwm_opacity_get(Ecore_X_Window win, unsigned int *opacity);
EAPI void ecore_x_netwm_frame_size_set(Ecore_X_Window win, int fl, int fr, int ft, int fb); EAPI void ecore_x_netwm_frame_size_set(Ecore_X_Window win, int fl, int fr, int ft, int fb);
EAPI int ecore_x_netwm_frame_size_get(Ecore_X_Window win, int *fl, int *fr, int *ft, int *fb); EAPI int ecore_x_netwm_frame_size_get(Ecore_X_Window win, int *fl, int *fr, int *ft, int *fb);
EAPI void ecore_x_netwm_ping(Ecore_X_Window win);
EAPI int ecore_x_netwm_sync_counter_get(Ecore_X_Window win, Ecore_X_Sync_Counter *counter); EAPI int ecore_x_netwm_sync_counter_get(Ecore_X_Window win, Ecore_X_Sync_Counter *counter);
EAPI void ecore_x_netwm_ping(Ecore_X_Window win);
EAPI void ecore_x_netwm_sync_request_send(Ecore_X_Window win, unsigned int serial); EAPI void ecore_x_netwm_sync_request_send(Ecore_X_Window win, unsigned int serial);

View File

@ -142,40 +142,6 @@ _ecore_x_window_prop_string_utf8_get(Ecore_X_Window win, Ecore_X_Atom atom)
return str; return str;
} }
#if 0 /* Unused */
/* Set/clear atom in list */
static void
_ecore_x_netwm_atom_list_set(Ecore_X_Atom *atoms, int size, int *count,
Ecore_X_Atom atom, int set)
{
int i, n, in_list = 0;
n = *count;
/* Check if atom is in list or not (+get index) */
for (i = 0; i < n; i++)
if (atoms[i] == atom)
{
in_list = 1;
break;
}
if (set && !in_list)
{
/* Add it (if space left) */
if (n < size)
atoms[n++] = atom;
*count = n;
}
else if (!set && in_list)
{
/* Remove it */
atoms[i] = atoms[--n];
*count = n;
}
}
#endif
/* /*
* Root window NetWM hints. * Root window NetWM hints.
*/ */
@ -384,29 +350,30 @@ ecore_x_netwm_wm_identify(Ecore_X_Window root, Ecore_X_Window check,
/* /*
* Set supported atoms * Set supported atoms
*/ */
int void
ecore_x_netwm_supported_set(Ecore_X_Window root, Ecore_X_Atom *supported, int num) ecore_x_netwm_supported_set(Ecore_X_Window root, Ecore_X_Atom *supported, int num)
{ {
_ATOM_SET_ATOM(root, ECORE_X_ATOM_NET_SUPPORTED, supported, num); _ATOM_SET_ATOM(root, ECORE_X_ATOM_NET_SUPPORTED, supported, num);
return 1;
} }
Ecore_X_Atom * int
ecore_x_netwm_supported_get(Ecore_X_Window root, int *num) ecore_x_netwm_supported_get(Ecore_X_Window root, Ecore_X_Atom **supported, int *num)
{ {
int num_ret; int num_ret;
unsigned char *data; unsigned char *data;
if (num) *num = 0; if (num) *num = 0;
if (supported) *supported = NULL;
if (!ecore_x_window_prop_property_get(root, ECORE_X_ATOM_NET_SUPPORTED, if (!ecore_x_window_prop_property_get(root, ECORE_X_ATOM_NET_SUPPORTED,
XA_ATOM, 32, &data, &num_ret)) XA_ATOM, 32, &data, &num_ret))
return NULL; return 0;
if ((!data) || (!num_ret)) return NULL; if ((!data) || (!num_ret)) return 0;
if (num) *num = num_ret; if (num) *num = num_ret;
return (Ecore_X_Atom *)data; if (supported) *supported = (Ecore_X_Atom *)data;
return 1;
} }
/* /*
@ -420,15 +387,15 @@ ecore_x_netwm_desk_count_set(Ecore_X_Window root, unsigned int n_desks)
} }
void void
ecore_x_netwm_desk_roots_set(Ecore_X_Window root, unsigned int n_desks, ecore_x_netwm_desk_roots_set(Ecore_X_Window root,
Ecore_X_Window * vroots) Ecore_X_Window *vroots, unsigned int n_desks)
{ {
_ATOM_SET_WINDOW(root, ECORE_X_ATOM_NET_VIRTUAL_ROOTS, vroots, n_desks); _ATOM_SET_WINDOW(root, ECORE_X_ATOM_NET_VIRTUAL_ROOTS, vroots, n_desks);
} }
void void
ecore_x_netwm_desk_names_set(Ecore_X_Window root, unsigned int n_desks, ecore_x_netwm_desk_names_set(Ecore_X_Window root,
const char **names) const char **names, unsigned int n_desks)
{ {
char ss[32], *buf; char ss[32], *buf;
const char *s; const char *s;
@ -472,8 +439,8 @@ ecore_x_netwm_desk_size_set(Ecore_X_Window root, unsigned int width,
} }
void void
ecore_x_netwm_desk_viewports_set(Ecore_X_Window root, unsigned int n_desks, ecore_x_netwm_desk_viewports_set(Ecore_X_Window root,
unsigned int *origins) unsigned int *origins, unsigned int n_desks)
{ {
ecore_x_window_prop_card32_set(root, ECORE_X_ATOM_NET_DESKTOP_VIEWPORT, ecore_x_window_prop_card32_set(root, ECORE_X_ATOM_NET_DESKTOP_VIEWPORT,
origins, 2 * n_desks); origins, 2 * n_desks);
@ -495,8 +462,8 @@ ecore_x_netwm_desk_layout_set(Ecore_X_Window root, int orientation,
} }
void void
ecore_x_netwm_desk_workareas_set(Ecore_X_Window root, unsigned int n_desks, ecore_x_netwm_desk_workareas_set(Ecore_X_Window root,
unsigned int *areas) unsigned int *areas, unsigned int n_desks)
{ {
ecore_x_window_prop_card32_set(root, ECORE_X_ATOM_NET_WORKAREA, areas, ecore_x_window_prop_card32_set(root, ECORE_X_ATOM_NET_WORKAREA, areas,
4 * n_desks); 4 * n_desks);
@ -512,7 +479,7 @@ ecore_x_netwm_desk_current_set(Ecore_X_Window root, unsigned int desk)
void void
ecore_x_netwm_showing_desktop_set(Ecore_X_Window root, int on) ecore_x_netwm_showing_desktop_set(Ecore_X_Window root, int on)
{ {
unsigned int val; unsigned int val;
val = (on) ? 1 : 0; val = (on) ? 1 : 0;
ecore_x_window_prop_card32_set(root, ECORE_X_ATOM_NET_SHOWING_DESKTOP, &val, ecore_x_window_prop_card32_set(root, ECORE_X_ATOM_NET_SHOWING_DESKTOP, &val,
@ -525,8 +492,8 @@ ecore_x_netwm_showing_desktop_set(Ecore_X_Window root, int on)
/* Mapping order */ /* Mapping order */
void void
ecore_x_netwm_client_list_set(Ecore_X_Window root, unsigned int n_clients, ecore_x_netwm_client_list_set(Ecore_X_Window root,
Ecore_X_Window * p_clients) Ecore_X_Window *p_clients, unsigned int n_clients)
{ {
_ATOM_SET_WINDOW(root, ECORE_X_ATOM_NET_CLIENT_LIST, p_clients, n_clients); _ATOM_SET_WINDOW(root, ECORE_X_ATOM_NET_CLIENT_LIST, p_clients, n_clients);
} }
@ -534,8 +501,8 @@ ecore_x_netwm_client_list_set(Ecore_X_Window root, unsigned int n_clients,
/* Stacking order */ /* Stacking order */
void void
ecore_x_netwm_client_list_stacking_set(Ecore_X_Window root, ecore_x_netwm_client_list_stacking_set(Ecore_X_Window root,
unsigned int n_clients, Ecore_X_Window *p_clients,
Ecore_X_Window * p_clients) unsigned int n_clients)
{ {
_ATOM_SET_WINDOW(root, ECORE_X_ATOM_NET_CLIENT_LIST_STACKING, p_clients, _ATOM_SET_WINDOW(root, ECORE_X_ATOM_NET_CLIENT_LIST_STACKING, p_clients,
n_clients); n_clients);
@ -553,10 +520,12 @@ ecore_x_netwm_name_set(Ecore_X_Window win, const char *name)
_ecore_x_window_prop_string_utf8_set(win, ECORE_X_ATOM_NET_WM_NAME, name); _ecore_x_window_prop_string_utf8_set(win, ECORE_X_ATOM_NET_WM_NAME, name);
} }
char * int
ecore_x_netwm_name_get(Ecore_X_Window win) ecore_x_netwm_name_get(Ecore_X_Window win, char **name)
{ {
return _ecore_x_window_prop_string_utf8_get(win, ECORE_X_ATOM_NET_WM_NAME); if (name)
*name = _ecore_x_window_prop_string_utf8_get(win, ECORE_X_ATOM_NET_WM_NAME);
return 1;
} }
void void
@ -566,11 +535,13 @@ ecore_x_netwm_visible_name_set(Ecore_X_Window win, const char *name)
name); name);
} }
char * int
ecore_x_netwm_visible_name_get(Ecore_X_Window win) ecore_x_netwm_visible_name_get(Ecore_X_Window win, char **name)
{ {
return _ecore_x_window_prop_string_utf8_get(win, if (name)
ECORE_X_ATOM_NET_WM_VISIBLE_NAME); *name = _ecore_x_window_prop_string_utf8_get(win,
ECORE_X_ATOM_NET_WM_VISIBLE_NAME);
return 1;
} }
void void
@ -580,11 +551,13 @@ ecore_x_netwm_icon_name_set(Ecore_X_Window win, const char *name)
name); name);
} }
char * int
ecore_x_netwm_icon_name_get(Ecore_X_Window win) ecore_x_netwm_icon_name_get(Ecore_X_Window win, char **name)
{ {
return _ecore_x_window_prop_string_utf8_get(win, if (name)
ECORE_X_ATOM_NET_WM_ICON_NAME); *name = _ecore_x_window_prop_string_utf8_get(win,
ECORE_X_ATOM_NET_WM_ICON_NAME);
return 1;
} }
void void
@ -595,11 +568,13 @@ ecore_x_netwm_visible_icon_name_set(Ecore_X_Window win, const char *name)
name); name);
} }
char * int
ecore_x_netwm_visible_icon_name_get(Ecore_X_Window win) ecore_x_netwm_visible_icon_name_get(Ecore_X_Window win, char **name)
{ {
return _ecore_x_window_prop_string_utf8_get(win, if (name)
ECORE_X_ATOM_NET_WM_VISIBLE_ICON_NAME); *name = _ecore_x_window_prop_string_utf8_get(win,
ECORE_X_ATOM_NET_WM_VISIBLE_ICON_NAME);
return 1;
} }
void void
@ -896,51 +871,21 @@ _ecore_x_netwm_state_atom_get(Ecore_X_Window_State s)
} }
} }
Ecore_X_Window_State * void
ecore_x_netwm_window_state_list_get(Ecore_X_Window win, int *num) ecore_x_netwm_window_state_set(Ecore_X_Window win, Ecore_X_Window_State *state, unsigned int num)
{
int num_ret, i;
unsigned char *data;
Ecore_X_Atom *atoms;
Ecore_X_Window_State *state;
if (num) *num = 0;
if (!ecore_x_window_prop_property_get(win, ECORE_X_ATOM_NET_WM_STATE,
XA_ATOM, 32, &data, &num_ret))
return NULL;
if ((!data) || (!num_ret)) return NULL;
atoms = (Ecore_X_Atom *) data;
state = malloc(num_ret * sizeof(Ecore_X_Window_State));
if (state)
{
for (i = 0; i < num_ret; ++i)
state[i] = _ecore_x_netwm_state_get(atoms[i]);
if (num) *num = num_ret;
}
free(data);
return state;
}
int
ecore_x_netwm_window_state_list_set(Ecore_X_Window win, Ecore_X_Window_State *state, int num)
{ {
unsigned char *data; unsigned char *data;
Ecore_X_Atom *set; Ecore_X_Atom *set;
int i; int i;
if (num == 0) if (!num)
{ {
XDeleteProperty(_ecore_x_disp, win, ECORE_X_ATOM_NET_WM_STATE); XDeleteProperty(_ecore_x_disp, win, ECORE_X_ATOM_NET_WM_STATE);
return 1; return;
} }
data = malloc(num * sizeof(Ecore_X_Atom)); data = malloc(num * sizeof(Ecore_X_Atom));
if (!data) return 1; if (!data) return;
set = (Ecore_X_Atom *) data; set = (Ecore_X_Atom *) data;
for (i = 0; i < num; i++) for (i = 0; i < num; i++)
@ -949,100 +894,38 @@ ecore_x_netwm_window_state_list_set(Ecore_X_Window win, Ecore_X_Window_State *st
_ATOM_SET_ATOM(win, ECORE_X_ATOM_NET_WM_STATE, data, num); _ATOM_SET_ATOM(win, ECORE_X_ATOM_NET_WM_STATE, data, num);
free(data); free(data);
return 1; return;
} }
int int
ecore_x_netwm_window_state_isset(Ecore_X_Window win, Ecore_X_Window_State s) ecore_x_netwm_window_state_get(Ecore_X_Window win, Ecore_X_Window_State **state, unsigned int *num)
{ {
int num, i, ret = 0; int num_ret, i;
unsigned char *data; unsigned char *data;
Ecore_X_Atom *atoms, atom; Ecore_X_Atom *atoms;
if (num) *num = 0;
if (state) *state = NULL;
if (!ecore_x_window_prop_property_get(win, ECORE_X_ATOM_NET_WM_STATE, if (!ecore_x_window_prop_property_get(win, ECORE_X_ATOM_NET_WM_STATE,
XA_ATOM, 32, &data, &num)) XA_ATOM, 32, &data, &num_ret))
return ret; return 0;
if ((!data) || (!num_ret)) return 0;
atom = _ecore_x_netwm_state_atom_get(s);
atoms = (Ecore_X_Atom *) data; atoms = (Ecore_X_Atom *) data;
if (state)
for (i = 0; i < num; ++i)
{ {
if (atoms[i] == atom) *state = malloc(num_ret * sizeof(Ecore_X_Window_State));
{ if (*state)
ret = 1; for (i = 0; i < num_ret; ++i)
break; (*state)[i] = _ecore_x_netwm_state_get(atoms[i]);
}
if (num) *num = num_ret;
} }
free(data); free(data);
return ret; return 1;
}
void
ecore_x_netwm_window_state_set(Ecore_X_Window win, Ecore_X_Window_State state, int on)
{
Ecore_X_Atom atom;
Ecore_X_Atom *oldset = NULL, *newset = NULL;
int i, j = 0, num = 0;
unsigned char *data = NULL;
unsigned char *old_data = NULL;
atom = _ecore_x_netwm_state_atom_get(state);
ecore_x_window_prop_property_get(win, ECORE_X_ATOM_NET_WM_STATE,
XA_ATOM, 32, &old_data, &num);
oldset = (Ecore_X_Atom *) old_data;
if (on)
{
for (i = 0; i < num; ++i)
{
if (oldset[i] == atom)
goto done;
}
newset = calloc(num + 1, sizeof(Ecore_X_Atom));
if (!newset)
goto done;
data = (unsigned char *) newset;
for (i = 0; i < num; i++)
newset[i] = oldset[i];
newset[num] = atom;
ecore_x_window_prop_property_set(win, ECORE_X_ATOM_NET_WM_STATE,
XA_ATOM, 32, data, num + 1);
}
else
{
int has;
has = 0;
for (i = 0; i < num; ++i)
{
if (oldset[i] == atom)
has = 1;
}
if (!has)
goto done;
newset = calloc(num - 1, sizeof(Ecore_X_Atom));
if (!newset)
goto done;
data = (unsigned char *) newset;
for (i = 0; i < num; i++)
if (oldset[i] != atom)
newset[j++] = oldset[i];
ecore_x_window_prop_property_set(win, ECORE_X_ATOM_NET_WM_STATE,
XA_ATOM, 32, data, num - 1);
}
free(newset);
done:
free(oldset);
} }
static Ecore_X_Window_Type static Ecore_X_Window_Type
@ -1108,37 +991,39 @@ ecore_x_netwm_window_type_set(Ecore_X_Window win, Ecore_X_Window_Type type)
XA_ATOM, 32, (unsigned char *)&atom, 1); XA_ATOM, 32, (unsigned char *)&atom, 1);
} }
Ecore_X_Window_Type /* FIXME: Maybe return 0 on some conditions? */
ecore_x_netwm_window_type_get(Ecore_X_Window win) int
ecore_x_netwm_window_type_get(Ecore_X_Window win, Ecore_X_Window_Type *type)
{ {
int num, i; int num, i;
Ecore_X_Window_Type ret = ECORE_X_WINDOW_TYPE_NORMAL, type;
unsigned char *data; unsigned char *data;
Ecore_X_Atom *atoms; Ecore_X_Atom *atoms;
if (type) *type = ECORE_X_WINDOW_TYPE_NORMAL;
if (!ecore_x_window_prop_property_get(win, ECORE_X_ATOM_NET_WM_WINDOW_TYPE, if (!ecore_x_window_prop_property_get(win, ECORE_X_ATOM_NET_WM_WINDOW_TYPE,
XA_ATOM, 32, &data, &num)) XA_ATOM, 32, &data, &num))
{ {
/* Check if WM_TRANSIENT_FOR is set */ /* Check if WM_TRANSIENT_FOR is set */
if (ecore_x_icccm_transient_for_get(win)) if ((type) && (ecore_x_icccm_transient_for_get(win)))
ret = ECORE_X_WINDOW_TYPE_DIALOG; *type = ECORE_X_WINDOW_TYPE_DIALOG;
return ret; return 1;
} }
atoms = (Ecore_X_Atom *) data; atoms = (Ecore_X_Atom *) data;
for (i = 0; i < num; ++i) if (type)
{ {
type = _ecore_x_netwm_window_type_type_get(atoms[i]); for (i = 0; i < num; ++i)
if (type != ECORE_X_WINDOW_TYPE_UNKNOWN)
{ {
ret = type; *type = _ecore_x_netwm_window_type_type_get(atoms[i]);
break; if (*type != ECORE_X_WINDOW_TYPE_UNKNOWN)
break;
} }
} }
free(data); free(data);
return ret; return 1;
} }
static Ecore_X_Atom static Ecore_X_Atom
@ -1171,6 +1056,7 @@ _ecore_x_netwm_action_atom_get(Ecore_X_Action action)
} }
} }
/* FIXME: Get complete list */
int int
ecore_x_netwm_allowed_action_isset(Ecore_X_Window win, Ecore_X_Action action) ecore_x_netwm_allowed_action_isset(Ecore_X_Window win, Ecore_X_Action action)
{ {
@ -1198,6 +1084,7 @@ ecore_x_netwm_allowed_action_isset(Ecore_X_Window win, Ecore_X_Action action)
return ret; return ret;
} }
/* FIXME: Set complete list */
void void
ecore_x_netwm_allowed_action_set(Ecore_X_Window win, Ecore_X_Action action, int on) ecore_x_netwm_allowed_action_set(Ecore_X_Window win, Ecore_X_Action action, int on)
{ {
@ -1311,6 +1198,19 @@ ecore_x_netwm_frame_size_get(Ecore_X_Window win, int *fl, int *fr, int *ft, int
return 1; return 1;
} }
int
ecore_x_netwm_sync_counter_get(Ecore_X_Window win, Ecore_X_Sync_Counter *counter)
{
int ret;
unsigned int tmp;
ret = ecore_x_window_prop_card32_get(win, ECORE_X_ATOM_NET_WM_SYNC_REQUEST_COUNTER,
&tmp, 1);
if (counter) *counter = tmp;
return ret == 1 ? 1 : 0;
}
void void
ecore_x_netwm_ping(Ecore_X_Window win) ecore_x_netwm_ping(Ecore_X_Window win)
{ {
@ -1333,19 +1233,6 @@ ecore_x_netwm_ping(Ecore_X_Window win)
XSendEvent(_ecore_x_disp, win, False, NoEventMask, &xev); XSendEvent(_ecore_x_disp, win, False, NoEventMask, &xev);
} }
int
ecore_x_netwm_sync_counter_get(Ecore_X_Window win, Ecore_X_Sync_Counter *counter)
{
int ret;
unsigned int tmp;
ret = ecore_x_window_prop_card32_get(win, ECORE_X_ATOM_NET_WM_SYNC_REQUEST_COUNTER,
&tmp, 1);
if (counter) *counter = tmp;
return ret == 1 ? 1 : 0;
}
void void
ecore_x_netwm_sync_request_send(Ecore_X_Window win, unsigned int serial) ecore_x_netwm_sync_request_send(Ecore_X_Window win, unsigned int serial)
{ {