diff options
author | Xiao Pan <gky44px1999@gmail.com> | 2023-01-02 06:34:52 -0800 |
---|---|---|
committer | Xiao Pan <gky44px1999@gmail.com> | 2023-01-02 06:34:52 -0800 |
commit | 4367ceccb88d776b01688107da510d7a0cb08110 (patch) | |
tree | 9b61de14698663c999612637ba23342ace01ecbe /dwm.c | |
parent | c8cd2a9bf52359fc42bcad699bedf0ab09d7e031 (diff) | |
parent | 89f9905714c1c1b2e8b09986dfbeca15b68d8af8 (diff) |
Merge branch 'master' into fly
Diffstat (limited to 'dwm.c')
-rw-r--r-- | dwm.c | 24 |
1 files changed, 17 insertions, 7 deletions
@@ -956,16 +956,26 @@ grabkeys(void) { updatenumlockmask(); { - unsigned int i, j; + unsigned int i, j, k; unsigned int modifiers[] = { 0, LockMask, numlockmask, numlockmask|LockMask }; - KeyCode code; + int start, end, skip; + KeySym *syms; XUngrabKey(dpy, AnyKey, AnyModifier, root); - for (i = 0; i < LENGTH(keys); i++) - if ((code = XKeysymToKeycode(dpy, keys[i].keysym))) - for (j = 0; j < LENGTH(modifiers); j++) - XGrabKey(dpy, code, keys[i].mod | modifiers[j], root, - True, GrabModeAsync, GrabModeAsync); + XDisplayKeycodes(dpy, &start, &end); + syms = XGetKeyboardMapping(dpy, start, end - start + 1, &skip); + if (!syms) + return; + for (k = start; k <= end; k++) + for (i = 0; i < LENGTH(keys); i++) + /* skip modifier codes, we do that ourselves */ + if (keys[i].keysym == syms[(k - start) * skip]) + for (j = 0; j < LENGTH(modifiers); j++) + XGrabKey(dpy, k, + keys[i].mod | modifiers[j], + root, True, + GrabModeAsync, GrabModeAsync); + XFree(syms); } } |