annotate key.c @ 74:5370ef170cc9

sanitized names
author Anselm R. Garbe <garbeam@wmii.de>
date Fri, 14 Jul 2006 22:54:09 +0200
parents c2ddb9dbbd10
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
73
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
1 /*
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
2 * (C)opyright MMVI Anselm R. Garbe <garbeam at gmail dot com>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
3 * See LICENSE file for license details.
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
4 */
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
5
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
6 #include <fcntl.h>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
7 #include <stdio.h>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
8 #include <stdlib.h>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
9 #include <string.h>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
10 #include <unistd.h>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
11 #include <X11/keysym.h>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
12 #include <X11/Xatom.h>
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
13
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
14 #include "dwm.h"
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
15
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
16 static void ckill(Arg *arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
17 static void nextc(Arg *arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
18 static void prevc(Arg *arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
19 static void max(Arg *arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
20 static void ttrunc(Arg *arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
21 static void tappend(Arg *arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
22 static void zoom(Arg *arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
23
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
24 /********** CUSTOMIZE **********/
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
25
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
26 const char *term[] = {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
27 "urxvtc", "-tr", "+sb", "-bg", "black", "-fg", "white", "-fn",
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
28 "-*-terminus-medium-*-*-*-13-*-*-*-*-*-iso10646-*",NULL
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
29 };
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
30 const char *browse[] = { "firefox", NULL };
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
31 const char *xlock[] = { "xlock", NULL };
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
32
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
33 Key key[] = {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
34 /* modifier key function arguments */
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
35 { Mod1Mask, XK_Return, zoom, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
36 { Mod1Mask, XK_k, prevc, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
37 { Mod1Mask, XK_j, nextc, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
38 { Mod1Mask, XK_m, max, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
39 { Mod1Mask, XK_0, view, { .i = Tscratch } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
40 { Mod1Mask, XK_1, view, { .i = Tdev } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
41 { Mod1Mask, XK_2, view, { .i = Twww } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
42 { Mod1Mask, XK_3, view, { .i = Twork } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
43 { Mod1Mask, XK_space, tiling, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
44 { Mod1Mask|ShiftMask, XK_space, floating, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
45 { Mod1Mask|ShiftMask, XK_0, ttrunc, { .i = Tscratch } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
46 { Mod1Mask|ShiftMask, XK_1, ttrunc, { .i = Tdev } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
47 { Mod1Mask|ShiftMask, XK_2, ttrunc, { .i = Twww } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
48 { Mod1Mask|ShiftMask, XK_3, ttrunc, { .i = Twork } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
49 { Mod1Mask|ShiftMask, XK_c, ckill, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
50 { Mod1Mask|ShiftMask, XK_q, quit, { 0 } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
51 { Mod1Mask|ShiftMask, XK_Return, spawn, { .argv = term } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
52 { Mod1Mask|ShiftMask, XK_w, spawn, { .argv = browse } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
53 { Mod1Mask|ShiftMask, XK_l, spawn, { .argv = xlock } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
54 { ControlMask, XK_0, tappend, { .i = Tscratch } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
55 { ControlMask, XK_1, tappend, { .i = Tdev } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
56 { ControlMask, XK_2, tappend, { .i = Twww } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
57 { ControlMask, XK_3, tappend, { .i = Twork } },
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
58 };
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
59
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
60 /********** CUSTOMIZE **********/
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
61
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
62 void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
63 grabkeys()
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
64 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
65 static unsigned int len = key ? sizeof(key) / sizeof(key[0]) : 0;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
66 unsigned int i;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
67 KeyCode code;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
68
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
69 for(i = 0; i < len; i++) {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
70 code = XKeysymToKeycode(dpy, key[i].keysym);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
71 XUngrabKey(dpy, code, key[i].mod, root);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
72 XGrabKey(dpy, code, key[i].mod, root, True,
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
73 GrabModeAsync, GrabModeAsync);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
74 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
75 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
76
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
77 void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
78 keypress(XEvent *e)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
79 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
80 XKeyEvent *ev = &e->xkey;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
81 static unsigned int len = key ? sizeof(key) / sizeof(key[0]) : 0;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
82 unsigned int i;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
83 KeySym keysym;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
84
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
85 keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
86 for(i = 0; i < len; i++)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
87 if((keysym == key[i].keysym) && (key[i].mod == ev->state)) {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
88 if(key[i].func)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
89 key[i].func(&key[i].arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
90 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
91 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
92 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
93
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
94 static void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
95 zoom(Arg *arg)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
96 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
97 Client **l, *c;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
98
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
99 if(!sel)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
100 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
101
74
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
102 if(sel == getnext(clients) && sel->next) {
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
103 if((c = getnext(sel->next)))
73
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
104 sel = c;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
105 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
106
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
107 for(l = &clients; *l && *l != sel; l = &(*l)->next);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
108 *l = sel->next;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
109
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
110 sel->next = clients; /* pop */
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
111 clients = sel;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
112 arrange(NULL);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
113 focus(sel);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
114 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
115
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
116 static void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
117 max(Arg *arg)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
118 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
119 if(!sel)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
120 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
121 sel->x = sx;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
122 sel->y = sy + bh;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
123 sel->w = sw - 2 * sel->border;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
124 sel->h = sh - 2 * sel->border - bh;
74
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
125 higher(sel);
73
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
126 resize(sel, False);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
127 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
128
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
129 static void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
130 tappend(Arg *arg)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
131 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
132 if(!sel)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
133 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
134
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
135 sel->tags[arg->i] = tags[arg->i];
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
136 arrange(NULL);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
137 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
138
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
139 static void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
140 ttrunc(Arg *arg)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
141 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
142 int i;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
143 if(!sel)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
144 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
145
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
146 for(i = 0; i < TLast; i++)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
147 sel->tags[i] = NULL;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
148 tappend(arg);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
149 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
150
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
151 static void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
152 prevc(Arg *arg)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
153 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
154 Client *c;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
155
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
156 if(!sel)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
157 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
158
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
159 if((c = sel->revert && sel->revert->tags[tsel] ? sel->revert : NULL)) {
74
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
160 higher(c);
73
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
161 focus(c);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
162 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
163 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
164
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
165 static void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
166 nextc(Arg *arg)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
167 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
168 Client *c;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
169
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
170 if(!sel)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
171 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
172
74
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
173 if(!(c = getnext(sel->next)))
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
174 c = getnext(clients);
73
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
175 if(c) {
74
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
176 higher(c);
73
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
177 c->revert = sel;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
178 focus(c);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
179 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
180 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
181
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
182 static void
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
183 ckill(Arg *arg)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
184 {
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
185 if(!sel)
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
186 return;
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
187 if(sel->proto & WM_PROTOCOL_DELWIN)
74
5370ef170cc9 sanitized names
Anselm R. Garbe <garbeam@wmii.de>
parents: 73
diff changeset
188 sendevent(sel->win, wm_atom[WMProtocols], wm_atom[WMDelete]);
73
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
189 else
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
190 XKillClient(dpy, sel->win);
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
191 }
c2ddb9dbbd10 rearranged
Anselm R. Garbe <garbeam@wmii.de>
parents:
diff changeset
192