diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/GlobalHotkeysLinux.cpp | 19 | ||||
-rw-r--r-- | src/main.cpp | 7 |
2 files changed, 21 insertions, 5 deletions
diff --git a/src/GlobalHotkeysLinux.cpp b/src/GlobalHotkeysLinux.cpp index b0e8e52..f3ec2b3 100644 --- a/src/GlobalHotkeysLinux.cpp +++ b/src/GlobalHotkeysLinux.cpp @@ -2,6 +2,7 @@ #include <signal.h> #include <sys/wait.h> #include <fcntl.h> +#include <limits.h> #include <string.h> #define PIPE_READ 0 @@ -31,6 +32,14 @@ namespace gsr { } bool GlobalHotkeysLinux::start() { + const bool inside_flatpak = getenv("FLATPAK_ID") != NULL; + const char *user_homepath = getenv("HOME"); + if(!user_homepath) + user_homepath = "/tmp"; + + char gsr_global_hotkeys_flatpak[PATH_MAX]; + snprintf(gsr_global_hotkeys_flatpak, sizeof(gsr_global_hotkeys_flatpak), "%s/.local/share/gpu-screen-recorder/gsr-global-hotkeys", user_homepath); + if(process_id > 0) return false; @@ -51,8 +60,14 @@ namespace gsr { close(pipes[i]); } - const char *args[] = { "gsr-global-hotkeys", NULL }; - execvp(args[0], (char* const*)args); + if(inside_flatpak) { + const char *args[] = { "flatpak-spawn", "--host", "--", gsr_global_hotkeys_flatpak, NULL }; + execvp(args[0], (char* const*)args); + } else { + const char *args[] = { "gsr-global-hotkeys", NULL }; + execvp(args[0], (char* const*)args); + } + perror("execvp"); _exit(127); } else { /* parent */ diff --git a/src/main.cpp b/src/main.cpp index ae08bb8..9c2802b 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -177,12 +177,13 @@ int main(int argc, char **argv) { if(argc == 1) { launch_action = LaunchAction::LAUNCH_HIDE; } else if(argc == 2) { - if(strcmp(argv[1], "launch-show") == 0) { + const char *launch_action_opt = argv[1]; + if(strcmp(launch_action_opt, "launch-show") == 0) { launch_action = LaunchAction::LAUNCH_SHOW; - } else if(strcmp(argv[1], "launch-hide") == 0) { + } else if(strcmp(launch_action_opt, "launch-hide") == 0) { launch_action = LaunchAction::LAUNCH_HIDE; } else { - printf("error: invalid action \"%s\", expected \"launch-show\" or \"launch-hide\".\n", argv[1]); + printf("error: invalid action \"%s\", expected \"launch-show\" or \"launch-hide\".\n", launch_action_opt); usage(); } } else { |