Make the new --prune-tags option work properly when git-fetch is
invoked with a <url> parameter instead of a <remote name>
parameter.

This change is split off from the introduction of --prune-tags due to
the relative complexity of munging the incoming argv, which is easier
to review as a separate change.

Signed-off-by: Ævar Arnfjörð Bjarmason <ava...@gmail.com>
---
 Documentation/git-fetch.txt | 21 ++++++---------------
 builtin/fetch.c             | 17 ++++++++++++++---
 t/t5510-fetch.sh            |  6 +++---
 3 files changed, 23 insertions(+), 21 deletions(-)

diff --git a/Documentation/git-fetch.txt b/Documentation/git-fetch.txt
index 574206d139..03666f6215 100644
--- a/Documentation/git-fetch.txt
+++ b/Documentation/git-fetch.txt
@@ -175,24 +175,15 @@ It's reasonable to e.g. configure `fetch.pruneTags=true` 
in
 run, without making every invocation of `git fetch` without `--prune`
 an error.
 
-Another special case of `--prune-tags` is that
-`refs/tags/*:refs/tags/*` will not be implicitly provided if an URL is
-being fetched. I.e.:
-
-------------------------------------------------
-$ git fetch <url> --prune --prune-tags
-------------------------------------------------
-
-Will prune no tags, as opposed to:
+Pruning tags with `--prune-tags` also works when fetching a URL
+instead of a named remote. These will all prune tags not found on
+origin:
 
 ------------------------------------------------
 $ git fetch origin --prune --prune-tags
-------------------------------------------------
-
-To prune tags given a URL supply the refspec explicitly:
-
-------------------------------------------------
-$ git fetch <url> --prune 'refs/tags/*:refs/tags/*'
+$ git fetch origin --prune 'refs/tags/*:refs/tags/*'
+$ git fetch <url of origin> --prune --prune-tags
+$ git fetch <url of origin> --prune 'refs/tags/*:refs/tags/*'
 ------------------------------------------------
 
 OUTPUT
diff --git a/builtin/fetch.c b/builtin/fetch.c
index 55a0fc37be..c96f17a9a3 100644
--- a/builtin/fetch.c
+++ b/builtin/fetch.c
@@ -1283,7 +1283,10 @@ static int fetch_one(struct remote *remote, int argc, 
const char **argv, int pru
        static const char **refs = NULL;
        struct refspec *refspec;
        int ref_nr = 0;
+       int j = 0;
        int exit_code;
+       int maybe_prune_tags;
+       int remote_via_config = remote_is_configured(remote, 0);
 
        if (!remote)
                die(_("No remote repository specified.  Please, specify either 
a URL or a\n"
@@ -1311,13 +1314,21 @@ static int fetch_one(struct remote *remote, int argc, 
const char **argv, int pru
                        prune_tags = PRUNE_TAGS_BY_DEFAULT;
        }
 
-       if (prune_tags_ok && prune_tags && remote_is_configured(remote, 0))
+       maybe_prune_tags = prune_tags_ok && prune_tags;
+       if (maybe_prune_tags && remote_via_config)
                add_prune_tags_to_fetch_refspec(remote);
 
+       if (argc > 0 || (maybe_prune_tags && !remote_via_config)) {
+               size_t nr_alloc = st_add3(argc, maybe_prune_tags, 1);
+               refs = xcalloc(nr_alloc, sizeof(const char *));
+               if (maybe_prune_tags) {
+                       refs[j++] = xstrdup("refs/tags/*:refs/tags/*");
+                       ref_nr++;
+               }
+       }
+
        if (argc > 0) {
-               int j = 0;
                int i;
-               refs = xcalloc(st_add(argc, 1), sizeof(const char *));
                for (i = 0; i < argc; i++) {
                        if (!strcmp(argv[i], "tag")) {
                                i++;
diff --git a/t/t5510-fetch.sh b/t/t5510-fetch.sh
index 6f3ab7695a..297590814d 100755
--- a/t/t5510-fetch.sh
+++ b/t/t5510-fetch.sh
@@ -748,9 +748,9 @@ test_configured_prune unset unset unset true pruned  kept \
 test_configured_prune_type unset unset unset unset kept kept     "origin 
--prune-tags" "name"
 test_configured_prune_type unset unset unset unset kept kept     "origin 
--prune-tags" "link"
 test_configured_prune_type unset unset unset unset pruned pruned "origin 
--prune --prune-tags" "name"
-test_configured_prune_type unset unset unset unset kept   kept   "origin 
--prune --prune-tags" "link"
+test_configured_prune_type unset unset unset unset kept   pruned "origin 
--prune --prune-tags" "link"
 test_configured_prune_type unset unset unset unset pruned pruned "--prune 
--prune-tags origin" "name"
-test_configured_prune_type unset unset unset unset kept   kept   "--prune 
--prune-tags origin" "link"
+test_configured_prune_type unset unset unset unset kept   pruned "--prune 
--prune-tags origin" "link"
 test_configured_prune_type unset unset true  unset pruned pruned "--prune 
origin" "name"
 test_configured_prune_type unset unset true  unset kept   pruned "--prune 
origin" "link"
 test_configured_prune_type unset unset unset true  pruned pruned "--prune 
origin" "name"
@@ -772,7 +772,7 @@ test_expect_success 'remove remote.origin.fetch "one"' '
        )
 '
 test_configured_prune_type unset unset unset unset kept pruned "origin --prune 
--prune-tags" "name"
-test_configured_prune_type unset unset unset unset kept kept   "origin --prune 
--prune-tags" "link"
+test_configured_prune_type unset unset unset unset kept pruned "origin --prune 
--prune-tags" "link"
 
 test_expect_success 'all boundary commits are excluded' '
        test_commit base &&
-- 
2.15.1.424.g9478a66081

Reply via email to