diff options
| author | Anselm R. Garbe <arg@suckless.org> | 2007-04-11 15:17:29 +0200 | 
|---|---|---|
| committer | Anselm R. Garbe <arg@suckless.org> | 2007-04-11 15:17:29 +0200 | 
| commit | 540d5eed469d19d2161ff157ec161e70384a80e9 (patch) | |
| tree | f2f8a0497a98d440db000d0ec82ef0febd16b5ec | |
| parent | 7d071ce2bd12916cf0784cc2d666b2e66931c174 (diff) | |
make also transients floating when we do not know the main window
| -rw-r--r-- | client.c | 9 | 
1 files changed, 5 insertions, 4 deletions
| @@ -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; | 
