diff options
author | Anselm R. Garbe <arg@suckless.org> | 2007-02-19 14:57:32 +0100 |
---|---|---|
committer | Anselm R. Garbe <arg@suckless.org> | 2007-02-19 14:57:32 +0100 |
commit | 64871a7045077bb2ec4cbcd62a74cabbe6b45096 (patch) | |
tree | 7e9d0fbab49039b32bf99924546edbe41392842e /client.c | |
parent | 2e95bc04135936ff8adc75e57e21f5edab56e0d6 (diff) | |
download | dwm-64871a7045077bb2ec4cbcd62a74cabbe6b45096.tar.gz dwm-64871a7045077bb2ec4cbcd62a74cabbe6b45096.zip |
renamed manage.c to view.c
Diffstat (limited to 'client.c')
-rw-r--r-- | client.c | 96 |
1 files changed, 85 insertions, 11 deletions
@@ -46,6 +46,21 @@ grabbuttons(Client *c, Bool focused) { GrabModeAsync, GrabModeSync, None, None); } +static Bool +isprotodel(Client *c) { + int i, n; + Atom *protocols; + Bool ret = False; + + if(XGetWMProtocols(dpy, c->win, &protocols, &n)) { + for(i = 0; !ret && i < n; i++) + if(protocols[i] == wmatom[WMDelete]) + ret = True; + XFree(protocols); + } + return ret; +} + static void setclientstate(Client *c, long state) { long data[] = {state, None}; @@ -61,6 +76,20 @@ xerrordummy(Display *dsply, XErrorEvent *ee) { /* extern */ void +attach(Client *c) { + if(clients) + clients->prev = c; + c->next = clients; + clients = c; +} + +void +attachstack(Client *c) { + c->snext = stack; + stack = c; +} + +void configure(Client *c) { XConfigureEvent ce; @@ -79,6 +108,24 @@ configure(Client *c) { } void +detach(Client *c) { + if(c->prev) + c->prev->next = c->next; + if(c->next) + c->next->prev = c->prev; + if(c == clients) + clients = c->next; + c->next = c->prev = NULL; +} + +void +detachstack(Client *c) { + Client **tc; + for(tc=&stack; *tc && *tc != c; tc=&(*tc)->snext); + *tc = c->snext; +} + +void focus(Client *c) { if(c && !isvisible(c)) return; @@ -103,19 +150,46 @@ focus(Client *c) { XSetInputFocus(dpy, root, RevertToPointerRoot, CurrentTime); } -Bool -isprotodel(Client *c) { - int i, n; - Atom *protocols; - Bool ret = False; +void +focusnext(Arg *arg) { + Client *c; + + if(!sel) + return; + for(c = sel->next; c && !isvisible(c); c = c->next); + if(!c) + for(c = clients; c && !isvisible(c); c = c->next); + if(c) { + focus(c); + restack(); + } +} - if(XGetWMProtocols(dpy, c->win, &protocols, &n)) { - for(i = 0; !ret && i < n; i++) - if(protocols[i] == wmatom[WMDelete]) - ret = True; - XFree(protocols); +void +focusprev(Arg *arg) { + Client *c; + + if(!sel) + return; + for(c = sel->prev; c && !isvisible(c); c = c->prev); + if(!c) { + for(c = clients; c && c->next; c = c->next); + for(; c && !isvisible(c); c = c->prev); } - return ret; + if(c) { + focus(c); + restack(); + } +} + +Client * +getclient(Window w) { + Client *c; + + for(c = clients; c; c = c->next) + if(c->win == w) + return c; + return NULL; } void |