|
|
@ -19,7 +19,7 @@ typedef struct { |
|
|
|
|
|
|
|
|
|
|
|
KEYS |
|
|
|
KEYS |
|
|
|
|
|
|
|
|
|
|
|
static unsigned int valid_mask = 255 & ~(NUMLOCKMASK | LockMask); |
|
|
|
#define CLEANMASK(mask) (mask & ~(NUMLOCKMASK | LockMask)) |
|
|
|
|
|
|
|
|
|
|
|
static void |
|
|
|
static void |
|
|
|
movemouse(Client *c) |
|
|
|
movemouse(Client *c) |
|
|
@ -229,11 +229,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 & valid_mask) == ev->state)) { |
|
|
|
if(keysym == key[i].keysym && |
|
|
|
|
|
|
|
CLEANMASK(key[i].mod) == CLEANMASK(ev->state)) { |
|
|
|
if(key[i].func) |
|
|
|
if(key[i].func) |
|
|
|
key[i].func(&key[i].arg); |
|
|
|
key[i].func(&key[i].arg); |
|
|
|
return; |
|
|
|
return; |
|
|
@ -335,13 +335,20 @@ 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); |
|
|
|
|
|
|
|
/* normal */ |
|
|
|
XUngrabKey(dpy, code, key[i].mod, root); |
|
|
|
XUngrabKey(dpy, code, key[i].mod, root); |
|
|
|
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); |
|
|
|
|
|
|
|
/* capslock */ |
|
|
|
|
|
|
|
XUngrabKey(dpy, code, key[i].mod | LockMask, root); |
|
|
|
|
|
|
|
XGrabKey(dpy, code, key[i].mod | LockMask, root, True, |
|
|
|
|
|
|
|
GrabModeAsync, GrabModeAsync); |
|
|
|
|
|
|
|
/* numlock */ |
|
|
|
|
|
|
|
XUngrabKey(dpy, code, key[i].mod | NUMLOCKMASK, root); |
|
|
|
XGrabKey(dpy, code, key[i].mod | NUMLOCKMASK, root, True, |
|
|
|
XGrabKey(dpy, code, key[i].mod | NUMLOCKMASK, root, True, |
|
|
|
GrabModeAsync, GrabModeAsync); |
|
|
|
GrabModeAsync, GrabModeAsync); |
|
|
|
|
|
|
|
/* capslock & numlock */ |
|
|
|
|
|
|
|
XUngrabKey(dpy, code, key[i].mod | NUMLOCKMASK | LockMask, root); |
|
|
|
XGrabKey(dpy, code, key[i].mod | NUMLOCKMASK | LockMask, root, True, |
|
|
|
XGrabKey(dpy, code, key[i].mod | NUMLOCKMASK | LockMask, root, True, |
|
|
|
GrabModeAsync, GrabModeAsync); |
|
|
|
GrabModeAsync, GrabModeAsync); |
|
|
|
} |
|
|
|
} |
|
|
|