summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortsxv478 <atvx717@infraredcombat.xyz>2025-03-14 20:00:02 +0300
committertsxv478 <atvx717@infraredcombat.xyz>2025-03-14 20:00:02 +0300
commit6f57b704e7fc8c6b0b74f34a7e150e920d0b65f4 (patch)
tree664d6c5ef67df35d3335a177625c2450b3d62e34
parentb16f49712d2760b2025a334940b7ba2de96efe72 (diff)
grabkeys: Grab all keycodesHEADmaster
-rw-r--r--dwm.c26
1 files changed, 20 insertions, 6 deletions
diff --git a/dwm.c b/dwm.c
index 42c43f6..dccbc0a 100644
--- a/dwm.c
+++ b/dwm.c
@@ -1205,14 +1205,28 @@ grabkeys(void)
{
unsigned int i, j;
unsigned int modifiers[] = { 0, LockMask, numlockmask, numlockmask|LockMask };
- KeyCode code;
+ int kc, kcmin, kcmax, kcper;
+ KeySym keysym, *keysyms;
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);
+
+ /* retrieve all the keycode -> keysym mappings */
+ XDisplayKeycodes(dpy, &kcmin, &kcmax);
+ keysyms = XGetKeyboardMapping(dpy, kcmin, kcmax - kcmin + 1, &kcper);
+
+ /* only look at the first keysym for each keycode as we handle shifted states */
+ for (kc = kcmin; kc <= kcmax; kc++) {
+ keysym = keysyms[(kc - kcmin) * kcper];
+ for (i = 0; i < LENGTH(keys); i++) {
+ if (keys[i].keysym == keysym) {
+ for (j = 0; j < LENGTH(modifiers); j++) {
+ XGrabKey(dpy, kc, keys[i].mod | modifiers[j], root, True, GrabModeAsync, GrabModeAsync);
+ }
+ }
+ }
+ }
+
+ XFree(keysyms);
}
}