reverted spawn
authorarg@localhost.localdomain <unknown>
Sat, 6 Dec 2008 09:16:48 +0000 (09:16 +0000)
committerarg@localhost.localdomain <unknown>
Sat, 6 Dec 2008 09:16:48 +0000 (09:16 +0000)
dwm.c

diff --git a/dwm.c b/dwm.c
index b390294c23ccdc20f6e198290c767b7ccd4fa5c6..f7b9477dfcb07004aecc47afcfa68f284de5b1f2 100644 (file)
--- a/dwm.c
+++ b/dwm.c
@@ -182,7 +182,6 @@ static void setlayout(const Arg *arg);
 static void setmfact(const Arg *arg);
 static void setup(void);
 static void showhide(Client *c);
-static void sigchld(int signal);
 static void spawn(const Arg *arg);
 static void tag(const Arg *arg);
 static int textnw(const char *text, unsigned int len);
@@ -1392,24 +1391,22 @@ showhide(Client *c) {
        }
 }
 
-
-void
-sigchld(int signal) {
-       while(0 < waitpid(-1, NULL, WNOHANG));
-}
-
 void
 spawn(const Arg *arg) {
-       signal(SIGCHLD, sigchld);
+       /* The double-fork construct avoids zombie processes and keeps the code
+        * clean from stupid signal handlers. */
        if(fork() == 0) {
-               if(dpy)
-                       close(ConnectionNumber(dpy));
-               setsid();
-               execvp(((char **)arg->v)[0], (char **)arg->v);
-               fprintf(stderr, "dwm: execvp %s", ((char **)arg->v)[0]);
-               perror(" failed");
+               if(fork() == 0) {
+                       if(dpy)
+                               close(ConnectionNumber(dpy));
+                       setsid();
+                       execvp(((char **)arg->v)[0], (char **)arg->v);
+                       fprintf(stderr, "dwm: execvp %s", ((char **)arg->v)[0]);
+                       perror(" failed");
+               }
                exit(0);
        }
+       wait(0);
 }
 
 void