diff options
author | Richard Maw <richard.maw@gmail.com> | 2016-06-25 22:49:35 +0100 |
---|---|---|
committer | Richard Maw <richard.maw@gmail.com> | 2016-07-13 20:09:37 +0100 |
commit | 5817a8f70370c0d41950fb2e7516389866da89b7 (patch) | |
tree | 27540f4f14d49d77dbe88287ac1e4efc95e66fa1 | |
parent | d25bfb99f9d1f02dcaf1cae3ffce35b9ea5471fd (diff) | |
download | cgit-5817a8f70370c0d41950fb2e7516389866da89b7.tar.gz cgit-5817a8f70370c0d41950fb2e7516389866da89b7.tar.bz2 cgit-5817a8f70370c0d41950fb2e7516389866da89b7.zip |
Add cgit_for_each_namespaced_ref_in helper
libgit has a for_each_namespaced_ref,
but lacks equivalents for just branches, tags or remotes.
Rather than implementing all of those helpers,
it's more convenient to implement just one
that prepends the namespace to the provided ref base.
Signed-off-by: Richard Maw <richard.maw@gmail.com>
-rw-r--r-- | cgit.h | 2 | ||||
-rw-r--r-- | shared.c | 10 |
2 files changed, 12 insertions, 0 deletions
@@ -394,4 +394,6 @@ extern char *get_mimetype_for_filename(const char *filename); extern int cgit_get_sha1(const char *name, unsigned char *sha1); +extern int cgit_for_each_namespaced_ref_in(const char *prefix, each_ref_fn fn, void *cb_data); + #endif /* CGIT_H */ @@ -651,3 +651,13 @@ int cgit_get_sha1(const char *name, unsigned char *sha1) return get_sha1(name, sha1); } } + +int cgit_for_each_namespaced_ref_in(const char *prefix, each_ref_fn fn, void *cb_data) +{ + struct strbuf strbuf = STRBUF_INIT; + int ret; + strbuf_addf(&strbuf, "%s%s", get_git_namespace(), prefix); + ret = for_each_ref_in(strbuf.buf, fn, cb_data); + strbuf_release(&strbuf); + return ret; +} |