client: split X props; handle fullscreen status
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
0dde158b5f
commit
7cf2b6615f
|
@ -146,7 +146,7 @@ scan(void)
|
||||||
state = window_state_get_reply(state_wins[i]);
|
state = window_state_get_reply(state_wins[i]);
|
||||||
|
|
||||||
has_awesome_prop = xutil_text_prop_get(globalconf.connection, wins[i],
|
has_awesome_prop = xutil_text_prop_get(globalconf.connection, wins[i],
|
||||||
_AWESOME_PROPERTIES, NULL, NULL);
|
_AWESOME_TAGS, NULL, NULL);
|
||||||
|
|
||||||
if(!attr_r || attr_r->override_redirect
|
if(!attr_r || attr_r->override_redirect
|
||||||
|| (attr_r->map_state != XCB_MAP_STATE_VIEWABLE && !has_awesome_prop)
|
|| (attr_r->map_state != XCB_MAP_STATE_VIEWABLE && !has_awesome_prop)
|
||||||
|
|
68
client.c
68
client.c
|
@ -71,27 +71,45 @@ client_loadprops(client_t * c, screen_t *screen)
|
||||||
ssize_t len;
|
ssize_t len;
|
||||||
tag_array_t *tags = &screen->tags;
|
tag_array_t *tags = &screen->tags;
|
||||||
char *prop = NULL;
|
char *prop = NULL;
|
||||||
|
xcb_get_property_cookie_t floating_q, fullscreen_q;
|
||||||
|
xcb_get_property_reply_t *reply;
|
||||||
|
void *data;
|
||||||
|
|
||||||
if(!xutil_text_prop_get(globalconf.connection, c->win, _AWESOME_PROPERTIES,
|
if(!xutil_text_prop_get(globalconf.connection, c->win, _AWESOME_TAGS,
|
||||||
&prop, &len))
|
&prop, &len))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if(len != tags->len + 2)
|
/* Send the GetProperty requests which will be processed later */
|
||||||
{
|
floating_q = xcb_get_property_unchecked(globalconf.connection, false, c->win,
|
||||||
/* ignore property if the tag count isn't matching */
|
_AWESOME_FLOATING, CARDINAL, 0, 1);
|
||||||
p_delete(&prop);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(int i = 0; i < tags->len; i++)
|
fullscreen_q = xcb_get_property_unchecked(globalconf.connection, false, c->win,
|
||||||
if(prop[i] == '1')
|
_AWESOME_FULLSCREEN, CARDINAL, 0, 1);
|
||||||
tag_client(c, tags->tab[i]);
|
|
||||||
else
|
/* ignore property if the tag count isn't matching */
|
||||||
untag_client(c, tags->tab[i]);
|
if(len == tags->len)
|
||||||
|
for(int i = 0; i < tags->len; i++)
|
||||||
|
if(prop[i] == '1')
|
||||||
|
tag_client(c, tags->tab[i]);
|
||||||
|
else
|
||||||
|
untag_client(c, tags->tab[i]);
|
||||||
|
|
||||||
client_setlayer(c, prop[tags->len + 1] - '0');
|
|
||||||
client_setfloating(c, prop[tags->len] == '1');
|
|
||||||
p_delete(&prop);
|
p_delete(&prop);
|
||||||
|
|
||||||
|
/* check for floating */
|
||||||
|
reply = xcb_get_property_reply(globalconf.connection, floating_q, NULL);
|
||||||
|
|
||||||
|
if(reply && reply->value_len && (data = xcb_get_property_value(reply)))
|
||||||
|
client_setfloating(c, *(bool *) data);
|
||||||
|
p_delete(&reply);
|
||||||
|
|
||||||
|
/* check for fullscreen */
|
||||||
|
reply = xcb_get_property_reply(globalconf.connection, fullscreen_q, NULL);
|
||||||
|
|
||||||
|
if(reply && reply->value_len && (data = xcb_get_property_value(reply)))
|
||||||
|
client_setfullscreen(c, *(bool *) data);
|
||||||
|
p_delete(&reply);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -609,7 +627,6 @@ client_setlayer(client_t *c, layer_t layer)
|
||||||
{
|
{
|
||||||
c->layer = layer;
|
c->layer = layer;
|
||||||
client_raise(c);
|
client_raise(c);
|
||||||
client_saveprops(c);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Set a clinet floating.
|
/** Set a clinet floating.
|
||||||
|
@ -632,8 +649,11 @@ client_setfloating(client_t *c, bool floating)
|
||||||
}
|
}
|
||||||
client_need_arrange(c);
|
client_need_arrange(c);
|
||||||
widget_invalidate_cache(c->screen, WIDGET_CACHE_CLIENTS);
|
widget_invalidate_cache(c->screen, WIDGET_CACHE_CLIENTS);
|
||||||
client_saveprops(c);
|
|
||||||
client_stack();
|
client_stack();
|
||||||
|
xcb_change_property(globalconf.connection,
|
||||||
|
XCB_PROP_MODE_REPLACE,
|
||||||
|
c->win, _AWESOME_FLOATING, CARDINAL, 8, 1,
|
||||||
|
&c->isfloating);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -693,6 +713,10 @@ client_setfullscreen(client_t *c, bool s)
|
||||||
client_resize(c, geometry, false);
|
client_resize(c, geometry, false);
|
||||||
client_need_arrange(c);
|
client_need_arrange(c);
|
||||||
client_stack();
|
client_stack();
|
||||||
|
xcb_change_property(globalconf.connection,
|
||||||
|
XCB_PROP_MODE_REPLACE,
|
||||||
|
c->win, _AWESOME_FULLSCREEN, CARDINAL, 8, 1,
|
||||||
|
&c->isfullscreen);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -756,19 +780,16 @@ client_setontop(client_t *c, bool s)
|
||||||
* \param c The client.
|
* \param c The client.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
client_saveprops(client_t *c)
|
client_saveprops_tags(client_t *c)
|
||||||
{
|
{
|
||||||
tag_array_t *tags = &globalconf.screens[c->screen].tags;
|
tag_array_t *tags = &globalconf.screens[c->screen].tags;
|
||||||
unsigned char *prop = p_alloca(unsigned char, tags->len + 3);
|
unsigned char *prop = p_alloca(unsigned char, tags->len + 1);
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for(i = 0; i < tags->len; i++)
|
for(i = 0; i < tags->len; i++)
|
||||||
prop[i] = is_client_tagged(c, tags->tab[i]) ? '1' : '0';
|
prop[i] = is_client_tagged(c, tags->tab[i]) ? '1' : '0';
|
||||||
|
|
||||||
prop[i++] = c->isfloating ? '1' : '0';
|
xcb_change_property(globalconf.connection, XCB_PROP_MODE_REPLACE, c->win, _AWESOME_TAGS, STRING, 8, i, prop);
|
||||||
prop[i++] = '0' + c->layer;
|
|
||||||
|
|
||||||
xcb_change_property(globalconf.connection, XCB_PROP_MODE_REPLACE, c->win, _AWESOME_PROPERTIES, STRING, 8, i, prop);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Unban a client.
|
/** Unban a client.
|
||||||
|
@ -828,7 +849,8 @@ client_unmanage(client_t *c)
|
||||||
ewmh_update_net_client_list(c->phys_screen);
|
ewmh_update_net_client_list(c->phys_screen);
|
||||||
|
|
||||||
/* delete properties */
|
/* delete properties */
|
||||||
xcb_delete_property(globalconf.connection, c->win, _AWESOME_PROPERTIES);
|
xcb_delete_property(globalconf.connection, c->win, _AWESOME_TAGS);
|
||||||
|
xcb_delete_property(globalconf.connection, c->win, _AWESOME_FLOATING);
|
||||||
|
|
||||||
/* set client as invalid */
|
/* set client as invalid */
|
||||||
c->invalid = true;
|
c->invalid = true;
|
||||||
|
|
2
client.h
2
client.h
|
@ -48,7 +48,7 @@ void client_unmanage(client_t *);
|
||||||
void client_updatewmhints(client_t *);
|
void client_updatewmhints(client_t *);
|
||||||
bool client_updatesizehints(client_t *, xcb_size_hints_t *);
|
bool client_updatesizehints(client_t *, xcb_size_hints_t *);
|
||||||
bool client_updatetitle(client_t *);
|
bool client_updatetitle(client_t *);
|
||||||
void client_saveprops(client_t *);
|
void client_saveprops_tags(client_t *);
|
||||||
void client_kill(client_t *);
|
void client_kill(client_t *);
|
||||||
void client_setfloating(client_t *, bool);
|
void client_setfloating(client_t *, bool);
|
||||||
void client_setsticky(client_t *, bool);
|
void client_setsticky(client_t *, bool);
|
||||||
|
|
|
@ -31,7 +31,9 @@ _NET_WM_STATE_MODAL
|
||||||
_NET_WM_STATE_HIDDEN
|
_NET_WM_STATE_HIDDEN
|
||||||
_NET_WM_STATE_DEMANDS_ATTENTION
|
_NET_WM_STATE_DEMANDS_ATTENTION
|
||||||
UTF8_STRING
|
UTF8_STRING
|
||||||
_AWESOME_PROPERTIES
|
_AWESOME_FLOATING
|
||||||
|
_AWESOME_FULLSCREEN
|
||||||
|
_AWESOME_TAGS
|
||||||
WM_PROTOCOLS
|
WM_PROTOCOLS
|
||||||
WM_DELETE_WINDOW
|
WM_DELETE_WINDOW
|
||||||
_XEMBED
|
_XEMBED
|
||||||
|
|
4
tag.c
4
tag.c
|
@ -133,7 +133,7 @@ tag_client(client_t *c, tag_t *t)
|
||||||
|
|
||||||
tag_ref(&t);
|
tag_ref(&t);
|
||||||
client_array_append(&t->clients, c);
|
client_array_append(&t->clients, c);
|
||||||
client_saveprops(c);
|
client_saveprops_tags(c);
|
||||||
widget_invalidate_cache(c->screen, WIDGET_CACHE_CLIENTS);
|
widget_invalidate_cache(c->screen, WIDGET_CACHE_CLIENTS);
|
||||||
client_need_arrange(c);
|
client_need_arrange(c);
|
||||||
}
|
}
|
||||||
|
@ -151,7 +151,7 @@ untag_client(client_t *c, tag_t *t)
|
||||||
client_need_arrange(c);
|
client_need_arrange(c);
|
||||||
client_array_take(&t->clients, i);
|
client_array_take(&t->clients, i);
|
||||||
tag_unref(&t);
|
tag_unref(&t);
|
||||||
client_saveprops(c);
|
client_saveprops_tags(c);
|
||||||
widget_invalidate_cache(c->screen, WIDGET_CACHE_CLIENTS);
|
widget_invalidate_cache(c->screen, WIDGET_CACHE_CLIENTS);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue