add WM_TRANSIENT_FOR event support: moves dialogs, toolbars and such to

the group of the main application window; based on a diff from Alexander
Polakov with CLIENT_IGNORE flag suggestion from oga@.

ok oga@
This commit is contained in:
okan 2011-09-13 08:41:57 +00:00
parent b96caa16e6
commit 796b32123d
3 changed files with 21 additions and 0 deletions

View File

@ -328,6 +328,7 @@ void client_send_delete(struct client_ctx *);
void client_setactive(struct client_ctx *, int); void client_setactive(struct client_ctx *, int);
void client_setname(struct client_ctx *); void client_setname(struct client_ctx *);
int client_snapcalc(int, int, int, int, int); int client_snapcalc(int, int, int, int, int);
void client_transient(struct client_ctx *);
void client_unhide(struct client_ctx *); void client_unhide(struct client_ctx *);
void client_vertmaximize(struct client_ctx *); void client_vertmaximize(struct client_ctx *);
void client_warp(struct client_ctx *); void client_warp(struct client_ctx *);

View File

@ -113,6 +113,8 @@ client_new(Window win, struct screen_ctx *sc, int mapped)
XAddToSaveSet(X_Dpy, cc->win); XAddToSaveSet(X_Dpy, cc->win);
client_transient(cc);
/* Notify client of its configuration. */ /* Notify client of its configuration. */
xu_configure(cc); xu_configure(cc);
@ -869,6 +871,21 @@ client_freehints(struct client_ctx *cc)
XFree(cc->app_class); XFree(cc->app_class);
} }
void
client_transient(struct client_ctx *cc)
{
struct client_ctx *tc;
Window trans;
if (XGetTransientForHint(X_Dpy, cc->win, &trans)) {
if ((tc = client_find(trans)) && tc->group) {
group_movetogroup(cc, tc->group->shortcut - 1);
if (tc->flags & CLIENT_IGNORE)
cc->flags |= CLIENT_IGNORE;
}
}
}
static int static int
client_inbound(struct client_ctx *cc, int x, int y) client_inbound(struct client_ctx *cc, int x, int y)
{ {

View File

@ -191,6 +191,9 @@ xev_handle_propertynotify(XEvent *ee)
case XA_WM_NAME: case XA_WM_NAME:
client_setname(cc); client_setname(cc);
break; break;
case XA_WM_TRANSIENT_FOR:
client_transient(cc);
break;
default: default:
/* do nothing */ /* do nothing */
break; break;