diff options
author | arg@10ksloc.org <unknown> | 2006-08-01 12:41:38 +0200 |
---|---|---|
committer | arg@10ksloc.org <unknown> | 2006-08-01 12:41:38 +0200 |
commit | 57416beefec4db451a75a1d25434b69cf50badad (patch) | |
tree | 14f9a0a7db23ba48e6ea986364fecae205d62c40 /event.c | |
parent | 1b63f832c528958042d72fddc318af5aefdcb68a (diff) | |
download | dwm-57416beefec4db451a75a1d25434b69cf50badad.tar.gz |
applied Cedric's NumLock patch
Diffstat (limited to 'event.c')
-rw-r--r-- | event.c | 18 |
1 files changed, 17 insertions, 1 deletions
@@ -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); + } } } |