summaryrefslogtreecommitdiffstats
path: root/notes.h
diff options
context:
space:
mode:
authorThomas Rast <trast@student.ethz.ch>2010-03-12 18:04:31 +0100
committerJunio C Hamano <gitster@pobox.com>2010-03-13 06:55:39 +0100
commit160baa0d9cbdfcdb6251aa5ede77c59c0d53edfd (patch)
tree278241bc0737a69c78be1a15655ff05c66261a46 /notes.h
parentrebase -i: invoke post-rewrite hook (diff)
downloadgit-160baa0d9cbdfcdb6251aa5ede77c59c0d53edfd.tar.xz
git-160baa0d9cbdfcdb6251aa5ede77c59c0d53edfd.zip
notes: implement 'git notes copy --stdin'
This implements a mass-copy command that takes a sequence of lines in the format <from-sha1> SP <to-sha1> [ SP <rest> ] LF on stdin, and copies each <from-sha1>'s notes to the <to-sha1>. The <rest> is ignored. The intent, of course, is that this can read the same input that the 'post-rewrite' hook gets. The copy_note() function is exposed for everyone's and in particular the next commit's use. Signed-off-by: Thomas Rast <trast@student.ethz.ch> Acked-by: Johan Herland <johan@herland.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'notes.h')
-rw-r--r--notes.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/notes.h b/notes.h
index 2cc07409db..b7fafb448b 100644
--- a/notes.h
+++ b/notes.h
@@ -100,6 +100,15 @@ const unsigned char *get_note(struct notes_tree *t,
const unsigned char *object_sha1);
/*
+ * Copy a note from one object to another in the given notes_tree.
+ *
+ * Fails if the to_obj already has a note unless 'force' is true.
+ */
+int copy_note(struct notes_tree *t,
+ const unsigned char *from_obj, const unsigned char *to_obj,
+ int force, combine_notes_fn combine_fn);
+
+/*
* Flags controlling behaviour of for_each_note()
*
* Default behaviour of for_each_note() is to traverse every single note object