From: Junio C Hamano Date: Sun, 16 Oct 2011 03:46:38 +0000 (-0700) Subject: Merge branch 'jk/maint-fetch-submodule-check-fix' into maint X-Git-Tag: v1.7.7.1~19 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e2d0a2e440bcf3d3f4134317ba539d79d4092918;p=git Merge branch 'jk/maint-fetch-submodule-check-fix' into maint * jk/maint-fetch-submodule-check-fix: fetch: avoid quadratic loop checking for updated submodules --- e2d0a2e440bcf3d3f4134317ba539d79d4092918 diff --cc submodule.c index ad86534ba1,9431c42dfb..08756387e2 --- a/submodule.c +++ b/submodule.c @@@ -478,16 -426,17 +534,21 @@@ static void calculate_changed_submodule { struct rev_info rev; struct commit *commit; - const char *argv[] = {NULL, NULL, "--not", "--all", NULL}; - int argc = ARRAY_SIZE(argv) - 1; + struct argv_array argv; + /* No need to check if there are no submodules configured */ + if (!config_name_for_path.nr) + return; + init_revisions(&rev, NULL); - argv[1] = xstrdup(sha1_to_hex(new_sha1)); - setup_revisions(argc, argv, &rev, NULL); + init_argv(&argv); + push_argv(&argv, "--"); /* argv[0] program name */ + sha1_array_for_each_unique(&ref_tips_after_fetch, + add_sha1_to_argv, &argv); + push_argv(&argv, "--not"); + sha1_array_for_each_unique(&ref_tips_before_fetch, + add_sha1_to_argv, &argv); + setup_revisions(argv.argc, argv.argv, &rev, NULL); if (prepare_revision_walk(&rev)) die("revision walk setup failed");