From 540d5eed469d19d2161ff157ec161e70384a80e9 Mon Sep 17 00:00:00 2001 From: "Anselm R. Garbe" Date: Wed, 11 Apr 2007 15:17:29 +0200 Subject: make also transients floating when we do not know the main window --- client.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/client.c b/client.c index 282ad53..0d2ab9a 100644 --- a/client.c +++ b/client.c @@ -173,8 +173,9 @@ killclient(const char *arg) { void manage(Window w, XWindowAttributes *wa) { - Client *c, *t; + Client *c, *t = NULL; Window trans; + Status rettrans; XWindowChanges wc; c = emallocz(sizeof(Client)); @@ -203,17 +204,17 @@ manage(Window w, XWindowAttributes *wa) { updatesizehints(c); XSelectInput(dpy, w, StructureNotifyMask | PropertyChangeMask | EnterWindowMask); - XGetTransientForHint(dpy, w, &trans); grabbuttons(c, False); wc.border_width = c->border; XConfigureWindow(dpy, w, CWBorderWidth, &wc); XSetWindowBorder(dpy, w, dc.norm[ColBorder]); configure(c); /* propagates border_width, if size doesn't change */ updatetitle(c); - for(t = clients; t && t->win != trans; t = t->next); + if((rettrans = XGetTransientForHint(dpy, w, &trans) == Success)) + for(t = clients; t && t->win != trans; t = t->next); settags(c, t); if(!c->isfloating) - c->isfloating = (t != NULL) || c->isfixed; + c->isfloating = (rettrans == Success) || c->isfixed; attach(c); attachstack(c); c->isbanned = True; -- cgit v1.2.3-70-g09d2