aboutsummaryrefslogtreecommitdiff
path: root/client.c
diff options
context:
space:
mode:
authorAnselm R. Garbe <arg@suckless.org>2007-01-23 12:00:49 +0100
committerAnselm R. Garbe <arg@suckless.org>2007-01-23 12:00:49 +0100
commit17ec726b494c2ee6e6b5dbe00bb83b2d931b3fc0 (patch)
treed42812e3d2cc53d435abc200b0aa77a7ba331895 /client.c
parent373b11de11fd5cee875ef521e3ac0527565c4721 (diff)
downloaddwm-17ec726b494c2ee6e6b5dbe00bb83b2d931b3fc0.tar
dwm-17ec726b494c2ee6e6b5dbe00bb83b2d931b3fc0.tar.gz
dwm-17ec726b494c2ee6e6b5dbe00bb83b2d931b3fc0.tar.bz2
this version should also work with cornercases (like unmanage during !issel, etc.)
Diffstat (limited to 'client.c')
-rw-r--r--client.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/client.c b/client.c
index 5309d0e..5c69718 100644
--- a/client.c
+++ b/client.c
@@ -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();
}