summaryrefslogtreecommitdiffstats
path: root/commit.h
diff options
context:
space:
mode:
authorChristian Couder <chriscool@tuxfamily.org>2014-07-07 08:35:37 +0200
committerJunio C Hamano <gitster@pobox.com>2014-07-08 00:32:21 +0200
commit063da62b02aeafe58fdacce0ea48c0761b06df60 (patch)
tree56b0db184d387b64fb3e12cdf5cd7d857216f655 /commit.h
parentMerge branch 'dt/refs-check-refname-component-sse' (diff)
downloadgit-063da62b02aeafe58fdacce0ea48c0761b06df60.tar.xz
git-063da62b02aeafe58fdacce0ea48c0761b06df60.zip
commit: add for_each_mergetag()
In the same way as there is for_each_ref() to iterate on refs, for_each_mergetag() allows the caller to iterate on the mergetags of a given commit. Use it to rewrite show_mergetag() used in "git log". Signed-off-by: Christian Couder <chriscool@tuxfamily.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'commit.h')
-rw-r--r--commit.h5
1 files changed, 5 insertions, 0 deletions
diff --git a/commit.h b/commit.h
index 2e1492a6e4..b695aa4a5b 100644
--- a/commit.h
+++ b/commit.h
@@ -312,6 +312,11 @@ extern struct commit_extra_header *read_commit_extra_headers(struct commit *, co
extern void free_commit_extra_headers(struct commit_extra_header *extra);
+typedef void (*each_mergetag_fn)(struct commit *commit, struct commit_extra_header *extra,
+ void *cb_data);
+
+extern void for_each_mergetag(each_mergetag_fn fn, struct commit *commit, void *data);
+
struct merge_remote_desc {
struct object *obj; /* the named object, could be a tag */
const char *name;