pinosaur
/
dwm.git
/ blobdiff
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
applied anydots remark of togglefloating()
[dwm.git]
/
client.c
diff --git
a/client.c
b/client.c
index
3db14f5
..
3e9b239
100644
(file)
--- a/
client.c
+++ b/
client.c
@@
-152,6
+152,14
@@
focus(Client *c) {
XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime);
}
XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime);
}
+void
+focustopvisible(void) {
+ Client *c;
+
+ for(c = stack; c && !isvisible(c); c = c->snext);
+ focus(c);
+}
+
void
killclient(const char *arg) {
XEvent ev;
void
killclient(const char *arg) {
XEvent ev;
@@
-296,7
+304,7
@@
void
togglefloating(const char *arg) {
if(!sel || lt->arrange == floating)
return;
togglefloating(const char *arg) {
if(!sel || lt->arrange == floating)
return;
- sel->isfloating = !sel->isfloating;
+ sel->isfloating = !sel->isfloating
|| sel->isfixed
;
lt->arrange();
}
lt->arrange();
}
@@
-381,7
+389,6
@@
updatetitle(Client *c) {
void
unmanage(Client *c) {
void
unmanage(Client *c) {
- Client *nc;
XWindowChanges wc;
wc.border_width = c->oldborder;
XWindowChanges wc;
wc.border_width = c->oldborder;
@@
-391,10
+398,8
@@
unmanage(Client *c) {
XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
detach(c);
detachstack(c);
XConfigureWindow(dpy, c->win, CWBorderWidth, &wc); /* restore border */
detach(c);
detachstack(c);
- if(sel == c) {
- for(nc = stack; nc && !isvisible(nc); nc = nc->snext);
- focus(nc);
- }
+ if(sel == c)
+ focustopvisible();
XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
setclientstate(c, WithdrawnState);
free(c->tags);
XUngrabButton(dpy, AnyButton, AnyModifier, c->win);
setclientstate(c, WithdrawnState);
free(c->tags);