Xinqi Bao's Git
projects
/
dwm.git
/ blobdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
inline
| side by side
seems to preserve floating client z-layer order (even with reorder() calls)
[dwm.git]
/
client.c
diff --git
a/client.c
b/client.c
index
4f2a69c
..
46693cd
100644
(file)
--- a/
client.c
+++ b/
client.c
@@
-99,6
+99,14
@@
focus(Client *c)
}
}
if(c) {
}
}
if(c) {
+ if((c->isfloat || arrange == dofloat) && (c != clients)) {
+ detach(c);
+ if(clients) {
+ clients->prev = c;
+ c->next = clients;
+ }
+ clients = c;
+ }
grabbuttons(c, True);
drawtitle(c);
XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime);
grabbuttons(c, True);
drawtitle(c);
XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime);
@@
-199,7
+207,7
@@
void
manage(Window w, XWindowAttributes *wa)
{
unsigned int i;
manage(Window w, XWindowAttributes *wa)
{
unsigned int i;
- Client *c
, *tc
;
+ Client *c;
Window trans;
XSetWindowAttributes twa;
Window trans;
XSetWindowAttributes twa;
@@
-238,11
+246,7
@@
manage(Window w, XWindowAttributes *wa)
CWOverrideRedirect | CWBackPixmap | CWEventMask, &twa);
grabbuttons(c, False);
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 &&
if(!c->isfloat)
c->isfloat = trans
|| (c->maxw && c->minw &&