X-Git-Url: http://git.marmaro.de/?p=mmh;a=blobdiff_plain;f=sbr%2Fpidwait.c;h=ba9bae21bf996a84eb74b49642a72e04f9c48c15;hp=a1555bbe666f412107f33aaa359d856d9acc308c;hb=641a9d953e86685f9ca2f3da72e9a94e5bcfd69e;hpb=6c42153ad9362cc676ea66563bf400d7511b3b68 diff --git a/sbr/pidwait.c b/sbr/pidwait.c index a1555bb..ba9bae2 100644 --- a/sbr/pidwait.c +++ b/sbr/pidwait.c @@ -1,56 +1,38 @@ - /* - * pidwait.c -- wait for child to exit - * - * $Id$ - * - * 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. - */ +** 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 -# include -#endif +#include int -pidwait (pid_t id, int sigsok) +pidwait(pid_t id, int sigsok) { - pid_t pid; - SIGNAL_HANDLER istat, qstat; - -#ifdef WAITINT - int status; -#else - union wait status; -#endif - - 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); -#else - while ((pid = wait(&status)) != -1 && pid != id) - continue; -#endif - - if (sigsok == -1) { - /* reset the signal handlers */ - SIGNAL (SIGINT, istat); - SIGNAL (SIGQUIT, qstat); - } - -#ifdef WAITINT - return (pid == -1 ? -1 : status); -#else - return (pid == -1 ? -1 : status.w_status); -#endif + pid_t pid; + SIGNAL_HANDLER istat = NULL, qstat = NULL; + int status; + + if (sigsok == -1) { + /* ignore a couple of signals */ + istat = SIGNAL(SIGINT, SIG_IGN); + qstat = SIGNAL(SIGQUIT, SIG_IGN); + } + + while ((pid = waitpid(id, &status, 0)) == -1 && errno == EINTR) + ; + + if (sigsok == -1) { + /* reset the signal handlers */ + SIGNAL(SIGINT, istat); + SIGNAL(SIGQUIT, qstat); + } + + return (pid == -1 ? -1 : status); }