diff options
author | dec05eba <dec05eba@protonmail.com> | 2024-12-17 22:52:54 +0100 |
---|---|---|
committer | dec05eba <dec05eba@protonmail.com> | 2024-12-17 22:52:54 +0100 |
commit | ec6d4090af22db59991e9c621238c96795814379 (patch) | |
tree | e2d7e239cec435f6524a5479ceaa33f073ab5264 | |
parent | 9ab0e457ab30c70d9065a246b5b891b79722c899 (diff) |
More key grab fixes, ignore mice/js/wheel
-rw-r--r-- | tools/gsr-global-hotkeys/keyboard_event.c | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/tools/gsr-global-hotkeys/keyboard_event.c b/tools/gsr-global-hotkeys/keyboard_event.c index e14bca5..5c2183f 100644 --- a/tools/gsr-global-hotkeys/keyboard_event.c +++ b/tools/gsr-global-hotkeys/keyboard_event.c @@ -136,15 +136,16 @@ static bool keyboard_event_try_add_device_if_keyboard(keyboard_event *self, cons unsigned long evbit = 0; ioctl(fd, EVIOCGBIT(0, sizeof(evbit)), &evbit); const bool is_keyboard = evbit & (1 << EV_KEY); - const bool is_pointer = (evbit & (1 << EV_REL)) || (evbit & (1 << EV_ABS)); - if(strcmp(device_name, GSR_UI_VIRTUAL_KEYBOARD_NAME) != 0 && is_keyboard && !is_pointer) { + + if(is_keyboard && strcmp(device_name, GSR_UI_VIRTUAL_KEYBOARD_NAME) != 0) { unsigned char key_bits[KEY_MAX/8 + 1] = {0}; ioctl(fd, EVIOCGBIT(EV_KEY, sizeof(key_bits)), &key_bits); - /* Test if device supports KEY_A since not all devices that support EV_KEY are keyboards, for example even a power button is an EV_KEY */ - const int key_test = KEY_A; - const bool supports_key_events = key_bits[key_test/8] & (1 << (key_test % 8)); - if(supports_key_events) { + const bool supports_key_events = key_bits[KEY_A/8] & (1 << (KEY_A % 8)); + const bool supports_mouse_events = key_bits[BTN_MOUSE/8] & (1 << (BTN_MOUSE % 8)); + const bool supports_joystick_events = key_bits[BTN_JOYSTICK/8] & (1 << (BTN_JOYSTICK % 8)); + const bool supports_wheel_events = key_bits[BTN_WHEEL/8] & (1 << (BTN_WHEEL % 8)); + if(supports_key_events && !supports_mouse_events && !supports_joystick_events && !supports_wheel_events) { if(self->num_event_polls < MAX_EVENT_POLLS) { bool grabbed = false; if(keyboard_event_has_exclusive_grab(self)) { @@ -234,6 +235,16 @@ static int setup_virtual_keyboard_input(const char *name) { success &= (ioctl(fd, UI_SET_KEYBIT, i) != -1); } + success &= (ioctl(fd, UI_SET_EVBIT, EV_REL) != -1); + success &= (ioctl(fd, UI_SET_RELBIT, REL_X) != -1); + success &= (ioctl(fd, UI_SET_RELBIT, REL_Y) != -1); + success &= (ioctl(fd, UI_SET_RELBIT, REL_Z) != -1); + + // success &= (ioctl(fd, UI_SET_EVBIT, EV_ABS) != -1); + // success &= (ioctl(fd, UI_SET_ABSBIT, ABS_X) != -1); + // success &= (ioctl(fd, UI_SET_ABSBIT, ABS_Y) != -1); + // success &= (ioctl(fd, UI_SET_ABSBIT, ABS_Z) != -1); + int ui_version = 0; success &= (ioctl(fd, UI_GET_VERSION, &ui_version) != -1); |