From: Andreas Ericsson Date: Wed, 16 Nov 2005 23:38:29 +0000 (+0100) Subject: daemon.c: fix arg parsing bugs X-Git-Tag: v0.99.9k~3^2~2 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=a8883288fa1240996a9c5715e060a88a03796fe0;p=git.git daemon.c: fix arg parsing bugs Allow --init-timeout and --timeout to be specified without falling through to usage(). Make sure openlog() is called even if implied by --inetd, or messages will be sent to wherever LOG_USER ends up. Signed-off-by: Andreas Ericsson Signed-off-by: Junio C Hamano --- diff --git a/daemon.c b/daemon.c index e18475229..2b81152d7 100644 --- a/daemon.c +++ b/daemon.c @@ -594,6 +594,7 @@ int main(int argc, char **argv) } if (!strcmp(arg, "--inetd")) { inetd_mode = 1; + log_syslog = 1; continue; } if (!strcmp(arg, "--verbose")) { @@ -602,7 +603,6 @@ int main(int argc, char **argv) } if (!strcmp(arg, "--syslog")) { log_syslog = 1; - openlog("git-daemon", 0, LOG_DAEMON); continue; } if (!strcmp(arg, "--export-all")) { @@ -611,9 +611,11 @@ int main(int argc, char **argv) } if (!strncmp(arg, "--timeout=", 10)) { timeout = atoi(arg+10); + continue; } if (!strncmp(arg, "--init-timeout=", 15)) { init_timeout = atoi(arg+15); + continue; } if (!strcmp(arg, "--")) { ok_paths = &argv[i+1]; @@ -626,9 +628,11 @@ int main(int argc, char **argv) usage(daemon_usage); } + if (log_syslog) + openlog("git-daemon", 0, LOG_DAEMON); + if (inetd_mode) { fclose(stderr); //FIXME: workaround - log_syslog = 1; return execute(); }