about summary refs log tree commit diff stats
path: root/event.c
diff options
context:
space:
mode:
authorarg@10ksloc.org <unknown>2006-08-01 12:41:38 +0200
committerarg@10ksloc.org <unknown>2006-08-01 12:41:38 +0200
commit57416beefec4db451a75a1d25434b69cf50badad (patch)
tree14f9a0a7db23ba48e6ea986364fecae205d62c40 /event.c
parent1b63f832c528958042d72fddc318af5aefdcb68a (diff)
downloaddwm-57416beefec4db451a75a1d25434b69cf50badad.tar.gz
applied Cedric's NumLock patch
Diffstat (limited to 'event.c')
-rw-r--r--event.c18
1 files changed, 17 insertions, 1 deletions
diff --git a/event.c b/event.c
index 2cebc9e..f177cbe 100644
--- a/event.c
+++ b/event.c
@@ -57,6 +57,9 @@ static Key key[] = {
 	{ MODKEY|ShiftMask,	XK_w,		spawn,		{ .argv = browse } },
 };
 
+#define NumLockMask Mod2Mask
+unsigned int valid_mask =  255 &  ~( NumLockMask | LockMask);
+
 /* END CUSTOMIZE */
 
 /* static */
@@ -271,10 +274,11 @@ keypress(XEvent *e)
 	unsigned int i;
 	KeySym keysym;
 	XKeyEvent *ev = &e->xkey;
+	ev->state &= valid_mask;
 
 	keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0);
 	for(i = 0; i < len; i++)
-		if((keysym == key[i].keysym) && (key[i].mod == ev->state)) {
+		if((keysym == key[i].keysym) && ((key[i].mod & valid_mask) == ev->state)) {
 			if(key[i].func)
 				key[i].func(&key[i].arg);
 			return;
@@ -377,7 +381,19 @@ grabkeys()
 	for(i = 0; i < len; i++) {
 		code = XKeysymToKeycode(dpy, key[i].keysym);
 		XUngrabKey(dpy, code, key[i].mod, root);
+		if (NumLockMask)
+		{
+			XUngrabKey(dpy, code, key[i].mod | NumLockMask, root);
+			XUngrabKey(dpy, code, key[i].mod | NumLockMask | LockMask, root);
+		}
 		XGrabKey(dpy, code, key[i].mod, root, True,
 				GrabModeAsync, GrabModeAsync);
+		if (NumLockMask)
+		{
+			XGrabKey(dpy, code, key[i].mod | NumLockMask, root, True,
+					GrabModeAsync, GrabModeAsync);
+			XGrabKey(dpy, code, key[i].mod | NumLockMask | LockMask, root, True,
+					GrabModeAsync, GrabModeAsync);
+		}
 	}
 }