added merged patch of anydot and Neale
authorAnselm R Garbe <garbeam@gmail.com>
Thu, 13 Aug 2009 10:45:59 +0100
changeset 1478 cf5bb4e72804
parent 1477 aefd753cfe9b
child 1479 31cb815bac41
added merged patch of anydot and Neale
dwm.c
--- a/dwm.c	Mon Jul 27 12:01:58 2009 +0100
+++ b/dwm.c	Thu Aug 13 10:45:59 2009 +0100
@@ -207,7 +207,7 @@
 static void setmfact(const Arg *arg);
 static void setup(void);
 static void showhide(Client *c);
-static void sigchld(int signal);
+static void sigchld(int unused);
 static void spawn(const Arg *arg);
 static void tag(const Arg *arg);
 static void tagmon(const Arg *arg);
@@ -1428,6 +1428,10 @@
 	int w;
 	XSetWindowAttributes wa;
 
+	/* clean up any zombies immediately */
+	signal(SIGCHLD, sigchld);
+	sigchld(0);
+
 	/* init screen */
 	screen = DefaultScreen(dpy);
 	root = RootWindow(dpy, screen);
@@ -1496,13 +1500,13 @@
 
 
 void
-sigchld(int signal) {
+sigchld(int unused) {
 	while(0 < waitpid(-1, NULL, WNOHANG));
+	signal(SIGCHLD, sigchld);
 }
 
 void
 spawn(const Arg *arg) {
-	signal(SIGCHLD, sigchld);
 	if(fork() == 0) {
 		if(dpy)
 			close(ConnectionNumber(dpy));