Bugfix: Don't segfault, if child was killed
This commit is contained in:
parent
c8032d552d
commit
dfd566511e
|
@ -11,6 +11,7 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <sys/wait.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
@ -35,12 +36,14 @@ char *statusline_buffer = NULL;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
void cleanup() {
|
void cleanup() {
|
||||||
|
if (stdin_io != NULL) {
|
||||||
ev_io_stop(main_loop, stdin_io);
|
ev_io_stop(main_loop, stdin_io);
|
||||||
ev_child_stop(main_loop, child_sig);
|
ev_child_stop(main_loop, child_sig);
|
||||||
FREE(stdin_io);
|
FREE(stdin_io);
|
||||||
FREE(child_sig);
|
FREE(child_sig);
|
||||||
FREE(statusline_buffer);
|
FREE(statusline_buffer);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Callbalk for stdin. We read a line from stdin and store the result
|
* Callbalk for stdin. We read a line from stdin and store the result
|
||||||
|
@ -174,9 +177,12 @@ void kill_child() {
|
||||||
if (child_pid != 0) {
|
if (child_pid != 0) {
|
||||||
kill(child_pid, SIGCONT);
|
kill(child_pid, SIGCONT);
|
||||||
kill(child_pid, SIGTERM);
|
kill(child_pid, SIGTERM);
|
||||||
}
|
int status;
|
||||||
|
waitpid(child_pid, &status, 0);
|
||||||
|
child_pid = 0;
|
||||||
cleanup();
|
cleanup();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Sends a SIGSTOP to the child-process (if existent)
|
* Sends a SIGSTOP to the child-process (if existent)
|
||||||
|
|
Loading…
Reference in New Issue