aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordec05eba <dec05eba@protonmail.com>2024-11-25 18:16:21 +0100
committerdec05eba <dec05eba@protonmail.com>2024-11-25 18:16:21 +0100
commitef7eb26ea5ff807258cf504ee9b66435b0d680f4 (patch)
treec1986810e4988e158e711e820e6792c56015e99b
parent9467abb0a25a1277f2744cb1ac30c5b3b6491df3 (diff)
Fix global hotkeys not working when connecting input after startup
-rw-r--r--src/GlobalHotkeysLinux.cpp12
-rw-r--r--tools/gsr-global-hotkeys/main.c63
2 files changed, 50 insertions, 25 deletions
diff --git a/src/GlobalHotkeysLinux.cpp b/src/GlobalHotkeysLinux.cpp
index 08803d7..b0e8e52 100644
--- a/src/GlobalHotkeysLinux.cpp
+++ b/src/GlobalHotkeysLinux.cpp
@@ -15,12 +15,6 @@ namespace gsr {
}
GlobalHotkeysLinux::~GlobalHotkeysLinux() {
- if(process_id > 0) {
- kill(process_id, SIGKILL);
- int status;
- waitpid(process_id, &status, 0);
- }
-
for(int i = 0; i < 2; ++i) {
if(pipes[i] > 0)
close(pipes[i]);
@@ -28,6 +22,12 @@ namespace gsr {
if(read_file)
fclose(read_file);
+
+ if(process_id > 0) {
+ kill(process_id, SIGKILL);
+ int status;
+ waitpid(process_id, &status, 0);
+ }
}
bool GlobalHotkeysLinux::start() {
diff --git a/tools/gsr-global-hotkeys/main.c b/tools/gsr-global-hotkeys/main.c
index 98ec6cf..2823487 100644
--- a/tools/gsr-global-hotkeys/main.c
+++ b/tools/gsr-global-hotkeys/main.c
@@ -146,18 +146,29 @@ static int handle_events(struct libinput *libinput, key_mapper *mapper) {
}
static int run_mainloop(struct libinput *libinput, key_mapper *mapper) {
- struct pollfd fd;
- fd.fd = libinput_get_fd(libinput);
- fd.events = POLLIN;
- fd.revents = 0;
+ struct pollfd fds[2] = {
+ {
+ .fd = libinput_get_fd(libinput),
+ .events = POLLIN,
+ .revents = 0
+ },
+ {
+ .fd = STDOUT_FILENO,
+ .events = 0,
+ .revents = 0
+ }
+ };
if(handle_events(libinput, mapper) != 0) {
fprintf(stderr, "error: didn't receive device added events. Is this program not running as root?\n");
return -1;
}
- while(poll(&fd, 1, -1) >= 0) {
- handle_events(libinput, mapper);
+ while(poll(fds, 2, -1) >= 0) {
+ if(fds[0].revents & POLLIN)
+ handle_events(libinput, mapper);
+ if(fds[1].revents & (POLLHUP|POLLERR))
+ break;
}
return 0;
@@ -197,6 +208,10 @@ static bool mapper_refresh_keymap(key_mapper *mapper) {
}
int main(void) {
+ int result = 0;
+ struct udev *udev = NULL;
+ struct libinput *libinput = NULL;
+
const uid_t user_id = getuid();
if(geteuid() != 0) {
if(setuid(0) == -1) {
@@ -205,43 +220,53 @@ int main(void) {
}
}
- struct udev *udev = udev_new();
+ udev = udev_new();
if(!udev) {
fprintf(stderr, "error: udev_new failed\n");
- return 1;
+ result = 1;
+ goto done;
}
- struct libinput *libinput = libinput_udev_create_context(&interface, NULL, udev);
+ libinput = libinput_udev_create_context(&interface, NULL, udev);
if(!libinput) {
fprintf(stderr, "error: libinput_udev_create_context failed\n");
- return 1;
+ result = 1;
+ goto done;
}
if(libinput_udev_assign_seat(libinput, "seat0") != 0) {
fprintf(stderr, "error: libinput_udev_assign_seat with seat0 failed\n");
- return 1;
+ result = 1;
+ goto done;
}
key_mapper mapper;
mapper.xkb_context = xkb_context_new(XKB_CONTEXT_NO_FLAGS);
if(!mapper.xkb_context) {
fprintf(stderr, "error: xkb_context_new failed\n");
- return 1;
+ result = 1;
+ goto done;
}
if(!mapper_refresh_keymap(&mapper)) {
fprintf(stderr, "error: key mapper failed\n");
- return 1;
+ result = 1;
+ goto done;
}
- setuid(user_id);
-
if(run_mainloop(libinput, &mapper) < 0) {
fprintf(stderr, "error: failed to start main loop\n");
- return 1;
+ result = 1;
+ goto done;
}
- libinput_unref(libinput);
- udev_unref(udev);
- return 0;
+ done:
+ if(libinput)
+ libinput_unref(libinput);
+
+ if(udev)
+ udev_unref(udev);
+
+ setuid(user_id);
+ return result;
}