diff options
author | okan | 2014-09-06 16:24:32 +0000 |
---|---|---|
committer | okan | 2014-09-06 16:24:32 +0000 |
commit | 4326d975991d0479deaa355b4b8695b4ea2744d4 (patch) | |
tree | 79e0639fbbf3163eccc935dd888f11fd115019f9 /calmwm.c | |
parent | 42beee08a73cd56e75481b5b32865d2b42d5f257 (diff) | |
download | cwm-4326d975991d0479deaa355b4b8695b4ea2744d4.tar.gz |
generic sighandler
Diffstat (limited to 'calmwm.c')
-rw-r--r-- | calmwm.c | 25 |
1 files changed, 14 insertions, 11 deletions
@@ -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. * - * $OpenBSD: calmwm.c,v 1.89 2014/02/02 16:29:04 okan Exp $ + * $OpenBSD: calmwm.c,v 1.90 2014/09/06 16:24:32 okan Exp $ */ #include <sys/param.h> @@ -48,7 +48,7 @@ struct conf Conf; const char *homedir; volatile sig_atomic_t cwm_status; -static void sigchld_cb(int); +static void sighdlr(int); static int x_errorhandler(Display *, XErrorEvent *); static void x_init(const char *); static void x_restart(char **); @@ -84,7 +84,7 @@ main(int argc, char **argv) argc -= optind; argv += optind; - if (signal(SIGCHLD, sigchld_cb) == SIG_ERR) + if (signal(SIGCHLD, sighdlr) == SIG_ERR) err(1, "signal"); if ((homedir = getenv("HOME")) == NULL || *homedir == '\0') { @@ -205,16 +205,19 @@ x_errorhandler(Display *dpy, XErrorEvent *e) } static void -sigchld_cb(int which) +sighdlr(int sig) { pid_t pid; - int save_errno = errno; - int status; - - /* Collect dead children. */ - while ((pid = waitpid(-1, &status, WNOHANG)) > 0 || - (pid < 0 && errno == EINTR)) - ; + int save_errno = errno, status; + + switch (sig) { + case SIGCHLD: + /* Collect dead children. */ + while ((pid = waitpid(WAIT_ANY, &status, WNOHANG)) > 0 || + (pid < 0 && errno == EINTR)) + ; + break; + } errno = save_errno; } |