aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnselm R. Garbe <arg@suckless.org>2007-04-11 15:17:29 +0200
committerAnselm R. Garbe <arg@suckless.org>2007-04-11 15:17:29 +0200
commit540d5eed469d19d2161ff157ec161e70384a80e9 (patch)
treef2f8a0497a98d440db000d0ec82ef0febd16b5ec
parent7d071ce2bd12916cf0784cc2d666b2e66931c174 (diff)
make also transients floating when we do not know the main window
-rw-r--r--client.c9
1 files 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;