From 77dd32a3ff82180b15447e1d9ab4e9a7c622f531 Mon Sep 17 00:00:00 2001 From: dec05eba Date: Thu, 9 Jan 2025 13:08:12 +0100 Subject: Revert "Dont use dlopen in gsr-global-hotkeys" This reverts commit b0def958c705ffadeca365753f18aa24ebe85e01. --- tools/gsr-global-hotkeys/keyboard_event.h | 29 +++++++++++++++++++++++------ 1 file changed, 23 insertions(+), 6 deletions(-) (limited to 'tools/gsr-global-hotkeys/keyboard_event.h') diff --git a/tools/gsr-global-hotkeys/keyboard_event.h b/tools/gsr-global-hotkeys/keyboard_event.h index cd5e119..9904237 100644 --- a/tools/gsr-global-hotkeys/keyboard_event.h +++ b/tools/gsr-global-hotkeys/keyboard_event.h @@ -12,14 +12,31 @@ /* POSIX */ #include -/* Linux */ +/* LINUX */ #include -/* System */ -#include - #define MAX_EVENT_POLLS 32 +typedef struct { + union { + int type; + unsigned char data[192]; + }; +} XEvent; + +typedef unsigned long (*XKeycodeToKeysym_FUNC)(void *display, unsigned char keycode, int index); +typedef int (*XPending_FUNC)(void *display); +typedef int (*XNextEvent_FUNC)(void *display, XEvent *event_return); +typedef int (*XRefreshKeyboardMapping_FUNC)(void* event_map); + +typedef struct { + void *display; + XKeycodeToKeysym_FUNC XKeycodeToKeysym; + XPending_FUNC XPending; + XNextEvent_FUNC XNextEvent; + XRefreshKeyboardMapping_FUNC XRefreshKeyboardMapping; +} x11_context; + typedef enum { KEYBOARD_MODKEY_LALT = 1 << 0, KEYBOARD_MODKEY_RALT = 1 << 2, @@ -55,7 +72,7 @@ typedef struct { int uinput_fd; bool stdout_failed; keyboard_grab_type grab_type; - Display *display; + x11_context x_context; hotplug_event hotplug_ev; @@ -73,7 +90,7 @@ typedef struct { /* Return true to allow other applications to receive the key input (when using exclusive grab) */ typedef bool (*key_callback)(uint32_t key, uint32_t modifiers, int press_status, void *userdata); -bool keyboard_event_init(keyboard_event *self, bool poll_stdout_error, bool exclusive_grab, keyboard_grab_type grab_type, Display *display); +bool keyboard_event_init(keyboard_event *self, bool poll_stdout_error, bool exclusive_grab, keyboard_grab_type grab_type, x11_context x_context); void keyboard_event_deinit(keyboard_event *self); /* If |timeout_milliseconds| is -1 then wait until an event is received */ -- cgit v1.2.3