Merge branch 'jk/maint-gc-auto-after-fetch' into jk/gc-auto-after-fetch
authorJunio C Hamano <gitster@pobox.com>
Sun, 27 Jan 2013 03:42:09 +0000 (19:42 -0800)
committerJunio C Hamano <gitster@pobox.com>
Sun, 27 Jan 2013 03:42:09 +0000 (19:42 -0800)
* jk/maint-gc-auto-after-fetch:
fetch-pack: avoid repeatedly re-scanning pack directory
fetch: run gc --auto after fetching

builtin/fetch.c
fetch-pack.c
index 4b5a89839b66f201bda42f06cabdf781d44f0192..1ddbf0d0b16490f5135584ff8d3f6acd5dfcf1ec 100644 (file)
@@ -959,6 +959,9 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
        struct string_list list = STRING_LIST_INIT_NODUP;
        struct remote *remote;
        int result = 0;
+       static const char *argv_gc_auto[] = {
+               "gc", "--auto", NULL,
+       };
 
        packet_trace_identity("fetch");
 
@@ -1026,5 +1029,7 @@ int cmd_fetch(int argc, const char **argv, const char *prefix)
        list.strdup_strings = 1;
        string_list_clear(&list, 0);
 
+       run_command_v_opt(argv_gc_auto, RUN_GIT_CMD);
+
        return result;
 }
index 099ff4ddffecee85d964bfa9f03795ed168edf5f..b4383c6dca6d10fae3e68a5bd15e094eb3bd1877 100644 (file)
@@ -594,6 +594,9 @@ static int everything_local(struct fetch_pack_args *args,
        for (ref = *refs; ref; ref = ref->next) {
                struct object *o;
 
+               if (!has_sha1_file(ref->old_sha1))
+                       continue;
+
                o = parse_object(ref->old_sha1);
                if (!o)
                        continue;