From 54eb3329681d8fa7c5bbd5e7eb871421cf6e5a2b Mon Sep 17 00:00:00 2001 From: tobias Date: Tue, 6 May 2008 15:12:04 +0000 Subject: Signal handler of SIGCHLD calls waitpid() which sets errno on error. To avoid clubbering of errno in normal context, save_errno got introduced. ok oga --- calmwm.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'calmwm.c') diff --git a/calmwm.c b/calmwm.c index 84bff28..d4e20ef 100644 --- a/calmwm.c +++ b/calmwm.c @@ -15,7 +15,7 @@ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. * - * $Id: calmwm.c,v 1.16 2008/04/15 20:24:41 oga Exp $ + * $Id: calmwm.c,v 1.17 2008/05/06 15:12:04 tobias Exp $ */ #include "headers.h" @@ -300,12 +300,15 @@ static void _sigchld_cb(int which) { pid_t pid; + int save_errno = errno; int status; /* Collect dead children. */ while ((pid = waitpid(-1, &status, WNOHANG)) > 0 || (pid < 0 && errno == EINTR)) ; + + errno = save_errno; } __dead void -- cgit v1.2.3-2-gb3c3