X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=src%2Fdirplex%2Fdirplex.c;h=d5aabea141c4253a351c73e984738f18c28eaaa5;hb=578ad6b1de34230e8fe64116b16380c1441ef9dd;hp=f8ac25a9c5c0fa4b081ff96503020da0ab36c5da;hpb=300d73d9ee0fe2fb09643a2a146711f1a8d7edd3;p=ashd.git diff --git a/src/dirplex/dirplex.c b/src/dirplex/dirplex.c index f8ac25a..d5aabea 100644 --- a/src/dirplex/dirplex.c +++ b/src/dirplex/dirplex.c @@ -25,6 +25,7 @@ #include #include #include +#include #include #ifdef HAVE_CONFIG_H @@ -296,6 +297,19 @@ static void serve(struct hthead *req, int fd) simpleerror(fd, 404, "Not Found", "The requested URL has no corresponding resource."); } +static void chldhandler(int sig) +{ + pid_t pid; + + do { + pid = waitpid(-1, NULL, WNOHANG); + } while(pid > 0); +} + +static void sighandler(int sig) +{ +} + static void usage(FILE *out) { fprintf(out, "usage: dirplex [-hN] [-c CONFIG] DIR\n"); @@ -355,7 +369,8 @@ int main(int argc, char **argv) flog(LOG_ERR, "could not change directory to %s: %s", argv[optind], strerror(errno)); exit(1); } - signal(SIGCHLD, SIG_IGN); + signal(SIGCHLD, chldhandler); + signal(SIGPIPE, sighandler); while(1) { if((fd = recvreq(0, &req)) < 0) { if(errno != 0)