notes: dry-run and verbose options for prune

Introduce -n and -v options for "git notes prune" in complete analogy to
"git prune" so that one can check for dangling notes easily.

The output is a list of names of objects whose notes would be resp.
are removed so that one can check the object ("git show sha1") as well as
the note ("git notes show sha1").

Signed-off-by: Michael J Gruber <git@drmicha.warpmail.net>
Acked-by: Johan Herland <johan@herland.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Michael J Gruber 2010-05-14 23:42:07 +02:00 committed by Junio C Hamano
parent 0e4607c09d
commit a9f2adff80
5 changed files with 72 additions and 10 deletions

View File

@ -15,7 +15,7 @@ SYNOPSIS
'git notes' edit [<object>] 'git notes' edit [<object>]
'git notes' show [<object>] 'git notes' show [<object>]
'git notes' remove [<object>] 'git notes' remove [<object>]
'git notes' prune 'git notes' prune [-n | -v]
DESCRIPTION DESCRIPTION
@ -121,6 +121,13 @@ OPTIONS
GIT_NOTES_REF and the "core.notesRef" configuration. The ref GIT_NOTES_REF and the "core.notesRef" configuration. The ref
is taken to be in `refs/notes/` if it is not qualified. is taken to be in `refs/notes/` if it is not qualified.
-n::
Do not remove anything; just report the object names whose notes
would be removed.
-v::
Report all object names whose notes are removed.
NOTES NOTES
----- -----

View File

@ -26,7 +26,7 @@ static const char * const git_notes_usage[] = {
"git notes [--ref <notes_ref>] edit [<object>]", "git notes [--ref <notes_ref>] edit [<object>]",
"git notes [--ref <notes_ref>] show [<object>]", "git notes [--ref <notes_ref>] show [<object>]",
"git notes [--ref <notes_ref>] remove [<object>]", "git notes [--ref <notes_ref>] remove [<object>]",
"git notes [--ref <notes_ref>] prune", "git notes [--ref <notes_ref>] prune [-n | -v]",
NULL NULL
}; };
@ -67,7 +67,7 @@ static const char * const git_notes_remove_usage[] = {
}; };
static const char * const git_notes_prune_usage[] = { static const char * const git_notes_prune_usage[] = {
"git notes prune", "git notes prune [<options>]",
NULL NULL
}; };
@ -792,7 +792,10 @@ static int remove_cmd(int argc, const char **argv, const char *prefix)
static int prune(int argc, const char **argv, const char *prefix) static int prune(int argc, const char **argv, const char *prefix)
{ {
struct notes_tree *t; struct notes_tree *t;
int show_only = 0, verbose = 0;
struct option options[] = { struct option options[] = {
OPT_BOOLEAN('n', NULL, &show_only, "do not remove, show only"),
OPT_BOOLEAN('v', NULL, &verbose, "report pruned notes"),
OPT_END() OPT_END()
}; };
@ -806,8 +809,10 @@ static int prune(int argc, const char **argv, const char *prefix)
t = init_notes_check("prune"); t = init_notes_check("prune");
prune_notes(t); prune_notes(t, (verbose ? NOTES_PRUNE_VERBOSE : 0) |
commit_notes(t, "Notes removed by 'git notes prune'"); (show_only ? NOTES_PRUNE_VERBOSE|NOTES_PRUNE_DRYRUN : 0) );
if (!show_only)
commit_notes(t, "Notes removed by 'git notes prune'");
free_notes(t); free_notes(t);
return 0; return 0;
} }

View File

@ -1083,7 +1083,7 @@ int write_notes_tree(struct notes_tree *t, unsigned char *result)
return ret; return ret;
} }
void prune_notes(struct notes_tree *t) void prune_notes(struct notes_tree *t, int flags)
{ {
struct note_delete_list *l = NULL; struct note_delete_list *l = NULL;
@ -1094,7 +1094,10 @@ void prune_notes(struct notes_tree *t)
for_each_note(t, 0, prune_notes_helper, &l); for_each_note(t, 0, prune_notes_helper, &l);
while (l) { while (l) {
remove_note(t, l->sha1); if (flags & NOTES_PRUNE_VERBOSE)
printf("%s\n", sha1_to_hex(l->sha1));
if (!(flags & NOTES_PRUNE_DRYRUN))
remove_note(t, l->sha1);
l = l->next; l = l->next;
} }
} }

View File

@ -171,6 +171,9 @@ int for_each_note(struct notes_tree *t, int flags, each_note_fn fn,
*/ */
int write_notes_tree(struct notes_tree *t, unsigned char *result); int write_notes_tree(struct notes_tree *t, unsigned char *result);
/* Flags controlling the operation of prune */
#define NOTES_PRUNE_VERBOSE 1
#define NOTES_PRUNE_DRYRUN 2
/* /*
* Remove all notes annotating non-existing objects from the given notes tree * Remove all notes annotating non-existing objects from the given notes tree
* *
@ -181,7 +184,7 @@ int write_notes_tree(struct notes_tree *t, unsigned char *result);
* structure are not persistent until a subsequent call to write_notes_tree() * structure are not persistent until a subsequent call to write_notes_tree()
* returns zero. * returns zero.
*/ */
void prune_notes(struct notes_tree *t); void prune_notes(struct notes_tree *t, int flags);
/* /*
* Free (and de-initialize) the given notes_tree structure * Free (and de-initialize) the given notes_tree structure

View File

@ -60,7 +60,7 @@ test_expect_success 'verify commits and notes' '
test_expect_success 'remove some commits' ' test_expect_success 'remove some commits' '
git reset --hard HEAD~2 && git reset --hard HEAD~1 &&
git reflog expire --expire=now HEAD && git reflog expire --expire=now HEAD &&
git gc --prune=now git gc --prune=now
' '
@ -68,7 +68,7 @@ test_expect_success 'remove some commits' '
test_expect_success 'verify that commits are gone' ' test_expect_success 'verify that commits are gone' '
! git cat-file -p 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 && ! git cat-file -p 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
! git cat-file -p 08341ad9e94faa089d60fd3f523affb25c6da189 && git cat-file -p 08341ad9e94faa089d60fd3f523affb25c6da189 &&
git cat-file -p ab5f302035f2e7aaf04265f08b42034c23256e1f git cat-file -p ab5f302035f2e7aaf04265f08b42034c23256e1f
' '
@ -79,11 +79,55 @@ test_expect_success 'verify that notes are still present' '
git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
' '
test_expect_success 'prune -n does not remove notes' '
git notes list > expect &&
git notes prune -n &&
git notes list > actual &&
test_cmp expect actual
'
cat > expect <<EOF
5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29
EOF
test_expect_success 'prune -n lists prunable notes' '
git notes prune -n > actual &&
test_cmp expect actual
'
test_expect_success 'prune notes' ' test_expect_success 'prune notes' '
git notes prune git notes prune
' '
test_expect_success 'verify that notes are gone' '
! git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&
git notes show 08341ad9e94faa089d60fd3f523affb25c6da189 &&
git notes show ab5f302035f2e7aaf04265f08b42034c23256e1f
'
test_expect_success 'remove some commits' '
git reset --hard HEAD~1 &&
git reflog expire --expire=now HEAD &&
git gc --prune=now
'
cat > expect <<EOF
08341ad9e94faa089d60fd3f523affb25c6da189
EOF
test_expect_success 'prune -v notes' '
git notes prune -v > actual &&
test_cmp expect actual
'
test_expect_success 'verify that notes are gone' ' test_expect_success 'verify that notes are gone' '
! git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 && ! git notes show 5ee1c35e83ea47cd3cc4f8cbee0568915fbbbd29 &&