X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=daemon.c;h=5547e6432e208633590dc431bf6a891055ba6bc1;hb=9048fe1c50499d562dcf73094f173b12bdb084c4;hp=b1fd60dd0c6ea5915340675a9f9691b027ca87e5;hpb=b5cf3c8b7767e5f2c8b0df718ef91ccfc36c61fe;p=git.git diff --git a/daemon.c b/daemon.c index b1fd60dd..5547e643 100644 --- a/daemon.c +++ b/daemon.c @@ -7,13 +7,15 @@ #include #include #include +#include +static int log_syslog; static int verbose; -static const char daemon_usage[] = "git-daemon [--verbose] [--inetd | --port=n]"; +static const char daemon_usage[] = "git-daemon [--verbose] [--syslog] [--inetd | --port=n]"; -static void logreport(const char *err, va_list params) +static void logreport(int priority, const char *err, va_list params) { /* We should do a single write so that it is atomic and output * of several processes do not get intermingled. */ @@ -27,6 +29,11 @@ static void logreport(const char *err, va_list params) maxlen = sizeof(buf) - buflen - 1; /* -1 for our own LF */ msglen = vsnprintf(buf + buflen, maxlen, err, params); + if (log_syslog) { + syslog(priority, "%s", buf); + return; + } + /* maxlen counted our own LF but also counts space given to * vsnprintf for the terminating NUL. We want to make sure that * we have space for our own LF and NUL after the "meat" of the @@ -48,7 +55,7 @@ void logerror(const char *err, ...) { va_list params; va_start(params, err); - logreport(err, params); + logreport(LOG_ERR, err, params); va_end(params); } @@ -58,7 +65,7 @@ void lognotice(const char *err, ...) if (!verbose) return; va_start(params, err); - logreport(err, params); + logreport(LOG_INFO, err, params); va_end(params); } @@ -285,15 +292,23 @@ static void handle(int incoming, struct sockaddr *addr, int addrlen) static void child_handler(int signo) { for (;;) { - pid_t pid = waitpid(-1, NULL, WNOHANG); + int status; + pid_t pid = waitpid(-1, &status, WNOHANG); if (pid > 0) { unsigned reaped = children_reaped; dead_child[reaped % MAX_CHILDREN] = pid; children_reaped = reaped + 1; /* XXX: Custom logging, since we don't wanna getpid() */ - if (verbose) - fprintf(stderr, "[%d] Disconnected\n", pid); + if (verbose) { + char *dead = ""; + if (!WIFEXITED(status) || WEXITSTATUS(status) > 0) + dead = " (with error)"; + if (log_syslog) + syslog(LOG_INFO, "[%d] Disconnected%s", pid, dead); + else + fprintf(stderr, "[%d] Disconnected%s\n", pid, dead); + } continue; } break; @@ -435,6 +450,11 @@ int main(int argc, char **argv) verbose = 1; continue; } + if (!strcmp(arg, "--syslog")) { + log_syslog = 1; + openlog("git-daemon", 0, LOG_DAEMON); + continue; + } usage(daemon_usage); }