safe_create_leading_directories: fix race that could give a false negative
[gitweb.git] / builtin / fetch-pack.c
index bc7a0f9e7f6fe0ec89854405731a25aae5d874a4..fdda36f1497eaa971e81cc1df0fb21ada6d21120 100644 (file)
@@ -787,6 +787,8 @@ static struct ref *do_fetch_pack(int fd[2],
 {
        struct ref *ref = copy_ref_list(orig_ref);
        unsigned char sha1[20];
+       const char *agent_feature;
+       int agent_len;
 
        sort_ref_list(&ref, ref_compare_name);
 
@@ -818,13 +820,24 @@ static struct ref *do_fetch_pack(int fd[2],
                        fprintf(stderr, "Server supports side-band\n");
                use_sideband = 1;
        }
+       if (!server_supports("thin-pack"))
+               args.use_thin_pack = 0;
+       if (!server_supports("no-progress"))
+               args.no_progress = 0;
+       if (!server_supports("include-tag"))
+               args.include_tag = 0;
        if (server_supports("ofs-delta")) {
                if (args.verbose)
                        fprintf(stderr, "Server supports ofs-delta\n");
        } else
                prefer_ofs_delta = 0;
-       if (server_supports("agent"))
+
+       if ((agent_feature = server_feature_value("agent", &agent_len))) {
                agent_supported = 1;
+               if (args.verbose && agent_len)
+                       fprintf(stderr, "Server version is %.*s\n",
+                               agent_len, agent_feature);
+       }
 
        if (everything_local(&ref, nr_match, match)) {
                packet_flush(fd[1]);