From bbfa006e6eb93d56842c1d90bbba1c5484afb855 Mon Sep 17 00:00:00 2001 From: John Keeping Date: Fri, 1 Aug 2014 22:14:17 +0100 Subject: Extract clone URL printing to ui-shared.c This will allow us to reuse the same logic to add clone URL elements to the header of all repo-specific pages in order to support the rel-vcs microformat. Signed-off-by: John Keeping --- ui-shared.c | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) (limited to 'ui-shared.c') diff --git a/ui-shared.c b/ui-shared.c index 6243d1b..4e317d0 100644 --- a/ui-shared.c +++ b/ui-shared.c @@ -727,6 +727,43 @@ void cgit_print_docend() html("\n\n"); } +static void add_clone_urls(void (*fn)(const char *), char *txt, char *suffix) +{ + struct strbuf buf = STRBUF_INIT; + char *h = txt, *t, c; + + while (h && *h) { + while (h && *h == ' ') + h++; + if (!*h) + break; + t = h; + while (t && *t && *t != ' ') + t++; + c = *t; + *t = 0; + + if (suffix && *suffix) { + strbuf_reset(&buf); + strbuf_addf(&buf, "%s/%s", h, suffix); + h = buf.buf; + } + fn(h); + *t = c; + h = t; + } + + strbuf_release(&buf); +} + +void cgit_add_clone_urls(void (*fn)(const char *)) +{ + if (ctx.repo->clone_url) + add_clone_urls(fn, expand_macros(ctx.repo->clone_url), NULL); + else if (ctx.cfg.clone_prefix) + add_clone_urls(fn, ctx.cfg.clone_prefix, ctx.repo->url); +} + static int print_branch_option(const char *refname, const unsigned char *sha1, int flags, void *cb_data) { -- cgit v1.2.1