From 9ef1d6aa2b611fdc2b6146d705dec44aacc92893 Mon Sep 17 00:00:00 2001 From: Tobias Langendorf Date: Thu, 26 Aug 2021 02:31:21 +0200 Subject: [PATCH] Fix exec_before/after leaving a zombie process behind --- src/screencast/screencast.c | 36 +++++++++++++++++++++++------------- 1 file changed, 23 insertions(+), 13 deletions(-) diff --git a/src/screencast/screencast.c b/src/screencast/screencast.c index 676dd821..1e7785d4 100644 --- a/src/screencast/screencast.c +++ b/src/screencast/screencast.c @@ -19,20 +19,30 @@ static const char object_path[] = "/org/freedesktop/portal/desktop"; static const char interface_name[] = "org.freedesktop.impl.portal.ScreenCast"; void exec_with_shell(char *command) { - pid_t pid = fork(); - if (pid < 0) { + pid_t pid1 = fork(); + if (pid1 < 0) { perror("fork"); - } else if (pid == 0) { - char *const argv[] = { - "sh", - "-c", - command, - NULL, - }; - execvp("sh", argv); - - perror("execvp"); - exit(127); + return; + } else if (pid1 == 0) { + pid_t pid2 = fork(); + if (pid2 < 0) { + perror("fork"); + } else if (pid2 == 0) { + char *const argv[] = { + "sh", + "-c", + command, + NULL, + }; + execvp("sh", argv); + perror("execvp"); + _exit(127); + } + _exit(0); + } + int stat; + if (waitpid(pid1, &stat, 0) < 0) { + perror("waitpid"); } }