diff options
author | Anselm R. Garbe <arg@10kloc.org> | 2006-09-07 17:53:40 +0200 |
---|---|---|
committer | Anselm R. Garbe <arg@10kloc.org> | 2006-09-07 17:53:40 +0200 |
commit | 15abade2720158fd35dcf59aa2cd5cbb325a849c (patch) | |
tree | f6255eca60e10fe5c305054e6adac07274c5a513 | |
parent | 7ab8c8728168234f6b9e99d1be384323d1246b10 (diff) | |
download | dwm-15abade2720158fd35dcf59aa2cd5cbb325a849c.tar.gz dwm-15abade2720158fd35dcf59aa2cd5cbb325a849c.tar.bz2 dwm-15abade2720158fd35dcf59aa2cd5cbb325a849c.zip |
using a global stack for focus recovery on arrange() - seems to work great
-rw-r--r-- | client.c | 16 | ||||
-rw-r--r-- | dwm.h | 3 | ||||
-rw-r--r-- | main.c | 1 | ||||
-rw-r--r-- | view.c | 14 |
4 files changed, 26 insertions, 8 deletions
@@ -11,6 +11,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) { XUngrabButton(dpy, AnyButton, AnyModifier, c->win); @@ -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; @@ -247,7 +257,8 @@ manage(Window w, XWindowAttributes *wa) if(clients) clients->prev = c; c->next = clients; - clients = c; + c->snext = stack; + stack = clients = c; settitle(c); ban(c); @@ -421,6 +432,7 @@ unmanage(Client *c) XUngrabButton(dpy, AnyButton, AnyModifier, c->win); XDestroyWindow(dpy, c->twin); + detachstack(c); free(c->tags); free(c); @@ -61,6 +61,7 @@ struct Client { Bool *tags; Client *next; Client *prev; + Client *snext; Window win; Window twin; }; @@ -73,7 +74,7 @@ extern void (*handler[LASTEvent])(XEvent *); extern void (*arrange)(Arg *); extern Atom wmatom[WMLast], netatom[NetLast]; extern Bool running, issel, maximized, *seltag; -extern Client *clients, *sel; +extern Client *clients, *sel, *stack; extern Cursor cursor[CurLast]; extern DC dc; extern Display *dpy; @@ -27,6 +27,7 @@ Bool issel = True; Bool maximized = False; Client *clients = NULL; Client *sel = NULL; +Client *stack = NULL; Cursor cursor[CurLast]; Display *dpy; DC dc = {0}; @@ -76,8 +76,10 @@ dofloat(Arg *arg) else ban(c); } - if(!sel || !isvisible(sel)) - focus(getnext(clients)); + if(!sel || !isvisible(sel)) { + for(sel = stack; sel && !isvisible(sel); sel = sel->snext); + focus(sel); + } restack(); } @@ -138,8 +140,10 @@ dotile(Arg *arg) else ban(c); } - if(!sel || !isvisible(sel)) - focus(getnext(clients)); + if(!sel || !isvisible(sel)) { + for(sel = stack; sel && !isvisible(sel); sel = sel->snext); + focus(sel); + } restack(); } @@ -227,7 +231,7 @@ restack() XRaiseWindow(dpy, sel->win); XRaiseWindow(dpy, sel->twin); } - if(arrange != dofloat) + if(arrange != dofloat) for(c = nexttiled(clients); c; c = nexttiled(c->next)) { XLowerWindow(dpy, c->twin); XLowerWindow(dpy, c->win); |