diff options
author | Anselm R. Garbe <arg@suckless.org> | 2007-01-22 10:35:58 +0100 |
---|---|---|
committer | Anselm R. Garbe <arg@suckless.org> | 2007-01-22 10:35:58 +0100 |
commit | fcd98308ba65c8872b485ac7f1800841b0a29e5c (patch) | |
tree | 5a3edcf206d73c9135d3839d0c47b02a91c7d2db /client.c | |
parent | b233089815367983e07939b2aabb999fdc359f91 (diff) |
this variant is known to work, but focus() is ugly - we need in general a better way to handle multihead, this issel-stuff looks awkward (maybe it might be a good idea to set sel to NULL but to introduce a Client *revert which is set if a screen is unfocused, have to think about it further).
Diffstat (limited to 'client.c')
-rw-r--r-- | client.c | 20 |
1 files changed, 12 insertions, 8 deletions
@@ -81,7 +81,7 @@ void focus(Client *c) { Client *old = sel; - if(!issel || (c && !isvisible(c))) + if(c && !isvisible(c)) return; if(old && old != c) { @@ -89,14 +89,18 @@ focus(Client *c) { XSetWindowBorder(dpy, old->win, dc.norm[ColBorder]); } if(c) { - detachstack(c); - c->snext = stack; - stack = c; - grabbuttons(c, True); - XSetWindowBorder(dpy, c->win, dc.sel[ColBorder]); - XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); + if(issel) { + detachstack(c); + c->snext = stack; + stack = c; + grabbuttons(c, True); + XSetWindowBorder(dpy, c->win, dc.sel[ColBorder]); + XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); + } + else + XSetWindowBorder(dpy, c->win, dc.norm[ColBorder]); } - else + else if(issel) XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); sel = c; drawstatus(); |