diff options
author | Anselm R. Garbe | 2007-01-23 12:00:49 +0100 |
---|---|---|
committer | Anselm R. Garbe | 2007-01-23 12:00:49 +0100 |
commit | 17ec726b494c2ee6e6b5dbe00bb83b2d931b3fc0 (patch) | |
tree | d42812e3d2cc53d435abc200b0aa77a7ba331895 /client.c | |
parent | 373b11de11fd5cee875ef521e3ac0527565c4721 (diff) |
this version should also work with cornercases (like unmanage during !issel, etc.)
Diffstat (limited to 'client.c')
-rw-r--r-- | client.c | 14 |
1 files changed, 7 insertions, 7 deletions
@@ -79,15 +79,16 @@ configure(Client *c) { void focus(Client *c) { - Client *old = sel; - if(c && !isvisible(c)) return; - if(old && old != c) { - grabbuttons(old, False); - XSetWindowBorder(dpy, old->win, dc.norm[ColBorder]); + if(sel && sel != c) { + grabbuttons(sel, False); + XSetWindowBorder(dpy, sel->win, dc.norm[ColBorder]); } + sel = c; + if(!issel) + return; if(c) { detachstack(c); c->snext = stack; @@ -96,9 +97,8 @@ focus(Client *c) { XSetWindowBorder(dpy, c->win, dc.sel[ColBorder]); XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); } - else if(issel) + else XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); - sel = c; drawstatus(); } |