Dolda2000 GitWeb
/
ashd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
lib: Added variants of sendfd and sendreq that take sendmsg flags.
[ashd.git]
/
src
/
dirplex
/
dirplex.c
diff --git
a/src/dirplex/dirplex.c
b/src/dirplex/dirplex.c
index
c6da4b6
..
d687957
100644
(file)
--- a/
src/dirplex/dirplex.c
+++ b/
src/dirplex/dirplex.c
@@
-59,8
+59,13
@@
static void handle(struct hthead *req, int fd, char *path, struct pattern *pat)
{
struct child *ch;
struct config *ccf;
{
struct child *ch;
struct config *ccf;
+ struct headmod *head;
char *twd;
char *twd;
+ for(head = pat->headers; head != NULL; head = head->next) {
+ headrmheader(req, head->name);
+ headappheader(req, head->name, head->value);
+ }
if(!strncmp(path, "./", 2) && path[2])
path += 2;
if(pat->fchild) {
if(!strncmp(path, "./", 2) && path[2])
path += 2;
if(pat->fchild) {
@@
-239,7
+244,7
@@
static int checkdir(struct hthead *req, int fd, char *path, char *rest)
struct child *ch;
cf = getconfig(path);
struct child *ch;
cf = getconfig(path);
- if(
cf->capture != NULL
) {
+ if(
(cf->capture != NULL) && (cf->caproot || !cf->path || strcmp(cf->path, "."))
) {
cpath = sprintf2("%s/", path);
if((ch = findchild(cpath, cf->capture, &ccf)) == NULL) {
free(cpath);
cpath = sprintf2("%s/", path);
if((ch = findchild(cpath, cf->capture, &ccf)) == NULL) {
free(cpath);
@@
-315,10
+320,12
@@
static void serve(struct hthead *req, int fd)
static void chldhandler(int sig)
{
pid_t pid;
static void chldhandler(int sig)
{
pid_t pid;
+ int st;
- do {
- pid = waitpid(-1, NULL, WNOHANG);
- } while(pid > 0);
+ while((pid = waitpid(-1, &st, WNOHANG)) > 0) {
+ if(WCOREDUMP(st))
+ flog(LOG_WARNING, "child process %i dumped core", pid);
+ }
}
static void sighandler(int sig)
}
static void sighandler(int sig)