Adds --inetd command line argument that makes server run in inetd mode.

Signed-off-by: Alexey Nezhdanov <[EMAIL PROTECTED]>
---

diff --git a/daemon.c b/daemon.c
--- a/daemon.c
+++ b/daemon.c
@@ -3,7 +3,7 @@
 #include <sys/socket.h>
 #include <netinet/in.h>
 
-static const char daemon_usage[] = "git-daemon [--port=n]";
+static const char daemon_usage[] = "git-daemon [--inetd | --port=n]";
 
 static int upload(char *dir, int dirlen)
 {
@@ -37,11 +37,21 @@ static int execute(char *line, int len)
        return -1;
 }
 
-static void handle(int incoming, struct sockaddr_in *addr, int addrlen)
+static int handle_stdio()
 {
        static char line[1000];
        int len;
 
+       len = packet_read_line(0, line, sizeof(line));
+
+       if (len && line[len-1] == '\n')
+               line[--len] = 0;
+
+       return execute(line, len);
+}
+
+static void handle(int incoming, struct sockaddr_in *addr, int addrlen)
+{
        if (fork()) {
                close(incoming);
                return;
@@ -50,12 +60,8 @@ static void handle(int incoming, struct 
        dup2(incoming, 0);
        dup2(incoming, 1);
        close(incoming);
-       len = packet_read_line(0, line, sizeof(line));
-
-       if (len && line[len-1] == '\n')
-               line[--len] = 0;
 
-       exit(execute(line, len));
+       exit(handle_stdio());
 }
 
 static int serve(int port)
@@ -97,6 +103,7 @@ int main(int argc, char **argv)
 {
        int port = DEFAULT_GIT_PORT;
        int i;
+       int inetd_mode = 0;
 
        for (i = 1; i < argc; i++) {
                char *arg = argv[i];
@@ -110,8 +117,17 @@ int main(int argc, char **argv)
                                continue;
                        }
                }
+
+               if (!strncmp(arg, "--inetd", 7)) {
+                       inetd_mode = 1;
+                       continue;
+               }
+
                usage(daemon_usage);
        }
 
-       return serve(port);
+       if (inetd_mode)
+               return handle_stdio();
+       else
+               return serve(port);
 }
-
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to