applied Cedric's NumLock patch
This commit is contained in:
parent
1b63f832c5
commit
57416beefe
1 changed files with 17 additions and 1 deletions
18
event.c
18
event.c
|
@ -57,6 +57,9 @@ static Key key[] = {
|
||||||
{ MODKEY|ShiftMask, XK_w, spawn, { .argv = browse } },
|
{ MODKEY|ShiftMask, XK_w, spawn, { .argv = browse } },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define NumLockMask Mod2Mask
|
||||||
|
unsigned int valid_mask = 255 & ~( NumLockMask | LockMask);
|
||||||
|
|
||||||
/* END CUSTOMIZE */
|
/* END CUSTOMIZE */
|
||||||
|
|
||||||
/* static */
|
/* static */
|
||||||
|
@ -271,10 +274,11 @@ keypress(XEvent *e)
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
KeySym keysym;
|
KeySym keysym;
|
||||||
XKeyEvent *ev = &e->xkey;
|
XKeyEvent *ev = &e->xkey;
|
||||||
|
ev->state &= valid_mask;
|
||||||
|
|
||||||
keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0);
|
keysym = XKeycodeToKeysym(dpy, (KeyCode)ev->keycode, 0);
|
||||||
for(i = 0; i < len; i++)
|
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)
|
if(key[i].func)
|
||||||
key[i].func(&key[i].arg);
|
key[i].func(&key[i].arg);
|
||||||
return;
|
return;
|
||||||
|
@ -377,7 +381,19 @@ grabkeys()
|
||||||
for(i = 0; i < len; i++) {
|
for(i = 0; i < len; i++) {
|
||||||
code = XKeysymToKeycode(dpy, key[i].keysym);
|
code = XKeysymToKeycode(dpy, key[i].keysym);
|
||||||
XUngrabKey(dpy, code, key[i].mod, root);
|
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,
|
XGrabKey(dpy, code, key[i].mod, root, True,
|
||||||
GrabModeAsync, GrabModeAsync);
|
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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue