X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=client.c;h=3578beb31abf3d9d8f6d4749a866afac030c5a79;hb=15abade2720158fd35dcf59aa2cd5cbb325a849c;hp=cac848ee5a793be716a1e5ce538ab6137f83ccec;hpb=e8389a4cc0f1c35bcb7e7646102bd6d6a830207e;p=dwm.git diff --git a/client.c b/client.c index cac848e..3578beb 100644 --- a/client.c +++ b/client.c @@ -10,6 +10,14 @@ /* static functions */ +static void +detachstack(Client *c) +{ + Client **tc; + for(tc=&stack; *tc && *tc != c; tc=&(*tc)->snext); + *tc = c->snext; +} + static void grabbuttons(Client *c, Bool focus) { @@ -99,6 +107,9 @@ focus(Client *c) } } if(c) { + detachstack(c); + c->snext = stack; + stack = c; grabbuttons(c, True); drawtitle(c); XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); @@ -198,7 +209,6 @@ killclient(Arg *arg) void manage(Window w, XWindowAttributes *wa) { - unsigned int i; Client *c; Window trans; XSetWindowAttributes twa; @@ -243,13 +253,12 @@ manage(Window w, XWindowAttributes *wa) 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; c->next = clients; - clients = c; + c->snext = stack; + stack = clients = c; settitle(c); ban(c); @@ -423,6 +432,7 @@ unmanage(Client *c) XUngrabButton(dpy, AnyButton, AnyModifier, c->win); XDestroyWindow(dpy, c->twin); + detachstack(c); free(c->tags); free(c);