This is much cleaner and portable way of using SIGCHLD. It also disallow
existence of defunct processes, one which are executed for example from
.Xsession before (on the end) exec /path/../dwm
--- dwm.c | 8 +++++--- 1 files changed, 5 insertions(+), 3 deletions(-) diff --git a/dwm.c b/dwm.c index 873b794..3cb4a8e 100644 --- a/dwm.c +++ b/dwm.c @@ -207,7 +207,7 @@ 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 sigchld(int unused); static void spawn(const Arg *arg); static void tag(const Arg *arg); static void tagmon(const Arg *arg); @@ -1428,6 +1428,8 @@ setup(void) { int w; XSetWindowAttributes wa; + signal(SIGCHLD, sigchld); + /* init screen */ screen = DefaultScreen(dpy); root = RootWindow(dpy, screen); @@ -1496,13 +1498,13 @@ showhide(Client *c) { void -sigchld(int signal) { +sigchld(int unusedl) { 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)); -- 1.6.3.3Received on Tue Aug 11 2009 - 21:43:58 UTC
This archive was generated by hypermail 2.2.0 : Sun Aug 16 2009 - 14:18:42 UTC