X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=client.c;h=b89264c2f43ec7e23e7bb91c80a1db5ce220917f;hb=87836d79ef90e6c764d94c229183179a36eb699a;hp=5c69718257ae0990c7f887ed6e2aac82677dc5ab;hpb=17ec726b494c2ee6e6b5dbe00bb83b2d931b3fc0;p=dwm.git diff --git a/client.c b/client.c index 5c69718..b89264c 100644 --- a/client.c +++ b/client.c @@ -81,25 +81,26 @@ void focus(Client *c) { if(c && !isvisible(c)) return; - 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; stack = c; grabbuttons(c, True); + } + sel = c; + drawstatus(); + if(!selscreen) + return; + if(c) { XSetWindowBorder(dpy, c->win, dc.sel[ColBorder]); XSetInputFocus(dpy, c->win, RevertToPointerRoot, CurrentTime); } else XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); - drawstatus(); } Client * @@ -156,6 +157,7 @@ manage(Window w, XWindowAttributes *wa) { StructureNotifyMask | PropertyChangeMask | EnterWindowMask); XGetTransientForHint(dpy, c->win, &trans); grabbuttons(c, False); + XSetWindowBorder(dpy, c->win, dc.norm[ColBorder]); updatetitle(c); settags(c, getclient(trans)); if(!c->isfloat)