Add client wrapper for XWMHints to support XA_WM_HINTS in PropertyNotify

events; based off a diff from Thomas Adam.
This commit is contained in:
okan 2013-12-11 15:41:11 +00:00
parent 0d9b1becff
commit 7e0749b0b1
3 changed files with 15 additions and 7 deletions

View File

@ -398,6 +398,7 @@ void client_unhide(struct client_ctx *);
void client_vmaximize(struct client_ctx *);
void client_vtile(struct client_ctx *);
void client_warp(struct client_ctx *);
void client_wm_hints(struct client_ctx *);
void group_alltoggle(struct screen_ctx *);
void group_autogroup(struct client_ctx *);

View File

@ -77,7 +77,7 @@ client_init(Window win, struct screen_ctx *sc, int mapped)
conf_client(cc);
XGetClassHint(X_Dpy, cc->win, &cc->ch);
cc->wmh = XGetWMHints(X_Dpy, cc->win);
client_wm_hints(cc);
client_getmwmhints(cc);
client_wm_protocols(cc);
client_getsizehints(cc);
@ -93,12 +93,6 @@ client_init(Window win, struct screen_ctx *sc, int mapped)
cc->geom.h = wattr.height;
cc->colormap = wattr.colormap;
if (cc->wmh != NULL) {
if (cc->wmh->flags & InputHint) {
if (cc->wmh->input == 1)
cc->flags |= CLIENT_INPUT;
}
}
if (wattr.map_state != IsViewable) {
client_placecalc(cc);
client_move(cc);
@ -509,6 +503,16 @@ client_wm_protocols(struct client_ctx *cc)
}
}
void
client_wm_hints(struct client_ctx *cc)
{
if ((cc->wmh = XGetWMHints(X_Dpy, cc->win)) == NULL)
return;
if ((cc->wmh->flags & InputHint) && (cc->wmh->input))
cc->flags |= CLIENT_INPUT;
}
void
client_msg(struct client_ctx *cc, Atom proto)
{

View File

@ -186,6 +186,9 @@ xev_handle_propertynotify(XEvent *ee)
case XA_WM_NAME:
client_setname(cc);
break;
case XA_WM_HINTS:
client_wm_hints(cc);
break;
case XA_WM_TRANSIENT_FOR:
client_transient(cc);
break;