X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;ds=sidebyside;f=client.c;h=45cb3a362fff8a0c2a49bc572280e68972c5afab;hb=fd00b3a18620c70721c4c4d9f0169e06b9ce4437;hp=ecb91782ca675a97b3ac6153524ef172288dd955;hpb=0d0e8bde134b999dd22c891d227d886ca6c9ba2c;p=dwm.git diff --git a/client.c b/client.c index ecb9178..45cb3a3 100644 --- a/client.c +++ b/client.c @@ -99,6 +99,13 @@ focus(Client *c) } } if(c) { + if(c->isfloat || arrange == dofloat) { + detach(c); + if(clients) + clients->prev = c; + c->next = clients; + clients = c; + } grabbuttons(c, True); drawtitle(c); XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); @@ -199,7 +206,7 @@ void manage(Window w, XWindowAttributes *wa) { unsigned int i; - Client *c, *tc; + Client *c; Window trans; XSetWindowAttributes twa; @@ -238,17 +245,11 @@ manage(Window w, XWindowAttributes *wa) CWOverrideRedirect | CWBackPixmap | CWEventMask, &twa); grabbuttons(c, False); - if((tc = getclient(trans))) /* inherit tags */ - for(i = 0; i < ntags; i++) - c->tags[i] = tc->tags[i]; - else - settags(c); + settags(c, getclient(trans)); if(!c->isfloat) c->isfloat = trans || (c->maxw && c->minw && c->maxw == c->minw && c->maxh == c->minh); - if(c->isfloat) - c->weight = ntags; if(clients) clients->prev = c;