X-Git-Url: http://git.marmaro.de/?p=mmh;a=blobdiff_plain;f=sbr%2Fpidwait.c;h=ebee02ecdcb8e001ec8aa4f0888b080d73c145d6;hp=4bd02e3e576669007d3963ac6e827870c12479e9;hb=714b5c530ece27ea2835a313013f5b770163403c;hpb=1691e80890e5d8ba258c51c214a3e91880e1db2b diff --git a/sbr/pidwait.c b/sbr/pidwait.c index 4bd02e3..ebee02e 100644 --- a/sbr/pidwait.c +++ b/sbr/pidwait.c @@ -1,12 +1,14 @@ - /* - * pidwait.c -- wait for child to exit - * - * $Id$ - */ +** pidwait.c -- wait for child to exit +** +** This code is Copyright (c) 2002, by the authors of nmh. See the +** COPYRIGHT file in the root directory of the nmh distribution for +** complete copyright information. +*/ #include #include +#include #include #ifdef HAVE_SYS_WAIT_H @@ -14,40 +16,40 @@ #endif int -pidwait (pid_t id, int sigsok) +pidwait(pid_t id, int sigsok) { - pid_t pid; - sigset_t set, oset; + pid_t pid; + SIGNAL_HANDLER istat = NULL, qstat = NULL; -#ifdef WAITINT - int status; +#ifdef HAVE_UNION_WAIT + union wait status; #else - union wait status; + int status; #endif - if (sigsok == -1) { - /* block a couple of signals */ - sigemptyset (&set); - sigaddset (&set, SIGINT); - sigaddset (&set, SIGQUIT); - SIGPROCMASK (SIG_BLOCK, &set, &oset); - } + if (sigsok == -1) { + /* ignore a couple of signals */ + istat = SIGNAL(SIGINT, SIG_IGN); + qstat = SIGNAL(SIGQUIT, SIG_IGN); + } #ifdef HAVE_WAITPID - pid = waitpid(id, &status, 0); + while ((pid = waitpid(id, &status, 0)) == -1 && errno == EINTR) + ; #else - while ((pid = wait(&status)) != -1 && pid != id) - continue; + while ((pid = wait(&status)) != -1 && pid != id) + continue; #endif - if (sigsok == -1) { - /* reset the signal mask */ - SIGPROCMASK (SIG_SETMASK, &oset, &set); - } + if (sigsok == -1) { + /* reset the signal handlers */ + SIGNAL(SIGINT, istat); + SIGNAL(SIGQUIT, qstat); + } -#ifdef WAITINT - return (pid == -1 ? -1 : status); +#ifdef HAVE_UNION_WAIT + return (pid == -1 ? -1 : status.w_status); #else - return (pid == -1 ? -1 : status.w_status); + return (pid == -1 ? -1 : status); #endif }