Fix exec_before/after leaving a zombie process behind

This commit is contained in:
Tobias Langendorf 2021-08-26 02:31:21 +02:00 committed by Simon Ser
parent 5f5a29ccfd
commit 9ef1d6aa2b

View file

@ -19,10 +19,15 @@ 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) {
return;
} else if (pid1 == 0) {
pid_t pid2 = fork();
if (pid2 < 0) {
perror("fork");
} else if (pid2 == 0) {
char *const argv[] = {
"sh",
"-c",
@ -30,9 +35,14 @@ void exec_with_shell(char *command) {
NULL,
};
execvp("sh", argv);
perror("execvp");
exit(127);
_exit(127);
}
_exit(0);
}
int stat;
if (waitpid(pid1, &stat, 0) < 0) {
perror("waitpid");
}
}