applied Cedric's NumLock patch
authorarg@10ksloc.org <unknown>
Tue, 1 Aug 2006 10:41:38 +0000 (12:41 +0200)
committerarg@10ksloc.org <unknown>
Tue, 1 Aug 2006 10:41:38 +0000 (12:41 +0200)
event.c

diff --git a/event.c b/event.c
index 2cebc9e576e9ce99050484a9034315f43b091280..f177cbe9a90d715977d84b80ab7c0bf26e1194fc 100644 (file)
--- 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);
+               }
        }
 }