aboutsummaryrefslogtreecommitdiff
path: root/src/rc/rc-plugin.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/rc/rc-plugin.c')
-rw-r--r--src/rc/rc-plugin.c29
1 files changed, 18 insertions, 11 deletions
diff --git a/src/rc/rc-plugin.c b/src/rc/rc-plugin.c
index 8599af6f..55112f4a 100644
--- a/src/rc/rc-plugin.c
+++ b/src/rc/rc-plugin.c
@@ -120,18 +120,25 @@ void rc_plugin_load(void)
int rc_waitpid(pid_t pid)
{
- int status = 0;
+ int status;
pid_t savedpid = pid;
- int retval = EXIT_FAILURE;
-
- do {
- pid = waitpid(savedpid, &status, 0);
- if (pid == -1 && errno != EINTR)
- return EXIT_FAILURE;
- } while (!WIFEXITED(status) && !WIFSIGNALED(status));
- if (pid == savedpid)
- retval = WIFEXITED(status) ? WEXITSTATUS(status) : EXIT_FAILURE;
- return retval;
+
+loop:
+ pid = waitpid(savedpid, &status, 0);
+ if (pid == -1) {
+ /* Our signal hander should take appropriate action. */
+ if (errno == EINTR)
+ goto loop;
+ return EXIT_FAILURE;
+ }
+
+ if (pid == savedpid) {
+ if (WIFEXITED(status))
+ return WEXITSTATUS(status);
+ return EXIT_FAILURE;
+ }
+
+ return EXIT_SUCCESS;
}
void rc_plugin_run(RC_HOOK hook, const char *value)