remote prune: print the list of pruned branches
authorOlivier Marin <dkr@freesurf.fr>
Tue, 10 Jun 2008 14:51:35 +0000 (16:51 +0200)
committerJunio C Hamano <gitster@pobox.com>
Wed, 11 Jun 2008 06:17:41 +0000 (23:17 -0700)
This command is really too quiet which make it unconfortable to use.

Also implement a --dry-run option, in place of the original -n one, to
list stale tracking branches that will be pruned, but do not actually
prune them.

Add a test case for --dry-run.

Signed-off-by: Olivier Marin <dkr@freesurf.fr>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Documentation/git-remote.txt
builtin-remote.c
t/t5505-remote.sh
index 7bd024eeba36f0c54b7fed2b57d3b18bf800a608..345943a26466dab73034b41698c54ca317cc4d75 100644 (file)
@@ -13,7 +13,7 @@ SYNOPSIS
 'git-remote' add [-t <branch>] [-m <master>] [-f] [--mirror] <name> <url>
 'git-remote' rm <name>
 'git-remote' show [-n] <name>
-'git-remote' prune <name>
+'git-remote' prune [-n | --dry-run] <name>
 'git-remote' update [group]
 
 DESCRIPTION
@@ -80,9 +80,8 @@ These stale branches have already been removed from the remote repository
 referenced by <name>, but are still locally available in
 "remotes/<name>".
 +
-With `-n` option, the remote heads are not confirmed first with `git
-ls-remote <name>`; cached information is used instead.  Use with
-caution.
+With `--dry-run` option, report what branches will be pruned, but do no
+actually prune them.
 
 'update'::
 
index 745a4ee6c503666bf763327d845c4210a728261f..6bce55cd53c062bebcee3d085f1ae74eae9c299e 100644 (file)
@@ -523,10 +523,10 @@ static int show(int argc, const char **argv)
 
 static int prune(int argc, const char **argv)
 {
-       int no_query = 0, result = 0;
+       int dry_run = 0, result = 0;
        struct option options[] = {
                OPT_GROUP("prune specific options"),
-               OPT_BOOLEAN('n', NULL, &no_query, "do not query remotes"),
+               OPT__DRY_RUN(&dry_run),
                OPT_END()
        };
        struct ref_states states;
@@ -540,11 +540,23 @@ static int prune(int argc, const char **argv)
        for (; argc; argc--, argv++) {
                int i;
 
-               get_remote_ref_states(*argv, &states, !no_query);
+               get_remote_ref_states(*argv, &states, 1);
+
+               printf("Pruning %s\n", *argv);
+               if (states.stale.nr)
+                       printf("URL: %s\n",
+                              states.remote->url_nr
+                              ? states.remote->url[0]
+                              : "(no URL)");
 
                for (i = 0; i < states.stale.nr; i++) {
                        const char *refname = states.stale.items[i].util;
-                       result |= delete_ref(refname, NULL);
+
+                       if (!dry_run)
+                               result |= delete_ref(refname, NULL);
+
+                       printf(" * [%s] %s\n", dry_run ? "would prune" : "pruned",
+                              skip_prefix(refname, "refs/remotes/"));
                }
 
                /* NEEDSWORK: free remote */
index c6a7bfb4480327ec2db69df5cc0a93a0019faed7..c17d9dcc74e02eb9f7bfc743df85e1e99ae6bd77 100755 (executable)
@@ -165,6 +165,24 @@ test_expect_success 'prune' '
         ! git rev-parse refs/remotes/origin/side)
 '
 
+cat > test/expect << EOF
+Pruning origin
+URL: $(pwd)/one/.git
+ * [would prune] origin/side2
+EOF
+
+test_expect_success 'prune --dry-run' '
+       (cd one &&
+        git branch -m side2 side) &&
+       (cd test &&
+        git remote prune --dry-run origin > output &&
+        git rev-parse refs/remotes/origin/side2 &&
+        ! git rev-parse refs/remotes/origin/side &&
+       (cd ../one &&
+        git branch -m side side2) &&
+        test_cmp expect output)
+'
+
 test_expect_success 'add --mirror && prune' '
        (mkdir mirror &&
         cd mirror &&