sequencer: rename reset_for_rollback to reset_merge
[gitweb.git] / builtin / upload-pack.c
index 2cb5cb35b06d9946ea7c5b3043249736b260737d..6da8fa2607c6b831c69a76c5bb2ec5caec444d54 100644 (file)
@@ -1,10 +1,11 @@
 #include "cache.h"
 #include "builtin.h"
-#include "exec_cmd.h"
+#include "exec-cmd.h"
 #include "pkt-line.h"
 #include "parse-options.h"
 #include "protocol.h"
 #include "upload-pack.h"
+#include "serve.h"
 
 static const char * const upload_pack_usage[] = {
        N_("git upload-pack [<options>] <dir>"),
@@ -16,6 +17,7 @@ int cmd_upload_pack(int argc, const char **argv, const char *prefix)
        const char *dir;
        int strict = 0;
        struct upload_pack_options opts = { 0 };
+       struct serve_options serve_opts = SERVE_OPTIONS_INIT;
        struct option options[] = {
                OPT_BOOL(0, "stateless-rpc", &opts.stateless_rpc,
                         N_("quit after a single request/response exchange")),
@@ -29,9 +31,9 @@ int cmd_upload_pack(int argc, const char **argv, const char *prefix)
        };
 
        packet_trace_identity("upload-pack");
-       check_replace_refs = 0;
+       read_replace_refs = 0;
 
-       argc = parse_options(argc, argv, NULL, options, upload_pack_usage, 0);
+       argc = parse_options(argc, argv, prefix, options, upload_pack_usage, 0);
 
        if (argc != 1)
                usage_with_options(upload_pack_usage, options);
@@ -47,6 +49,11 @@ int cmd_upload_pack(int argc, const char **argv, const char *prefix)
                die("'%s' does not appear to be a git repository", dir);
 
        switch (determine_protocol_version_server()) {
+       case protocol_v2:
+               serve_opts.advertise_capabilities = opts.advertise_refs;
+               serve_opts.stateless_rpc = opts.stateless_rpc;
+               serve(&serve_opts);
+               break;
        case protocol_v1:
                /*
                 * v1 is just the original protocol with a version string,