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-summary.c | 58 ++++++++++++---------------------------------------------- 1 file changed, 12 insertions(+), 46 deletions(-) (limited to 'ui-summary.c') diff --git a/ui-summary.c b/ui-summary.c index 3728c3e..70ea908 100644 --- a/ui-summary.c +++ b/ui-summary.c @@ -12,62 +12,30 @@ #include "ui-log.h" #include "ui-refs.h" #include "ui-blob.h" +#include "ui-shared.h" #include -static void print_url(char *base, char *suffix) +static int urls; + +static void print_url(const char *url) { int columns = 3; - struct strbuf basebuf = STRBUF_INIT; if (ctx.repo->enable_log_filecount) columns++; if (ctx.repo->enable_log_linecount) columns++; - if (!base || !*base) - return; - if (suffix && *suffix) { - strbuf_addf(&basebuf, "%s/%s", base, suffix); - base = basebuf.buf; + if (urls++ == 0) { + htmlf(" ", columns); + htmlf("Clone\n", columns); } + htmlf(""); - html_txt(base); + html_txt(url); html("\n"); - strbuf_release(&basebuf); -} - -static void print_urls(char *txt, char *suffix) -{ - char *h = txt, *t, c; - int urls = 0; - int columns = 3; - - if (ctx.repo->enable_log_filecount) - columns++; - if (ctx.repo->enable_log_linecount) - columns++; - - - while (h && *h) { - while (h && *h == ' ') - h++; - if (!*h) - break; - t = h; - while (t && *t && *t != ' ') - t++; - c = *t; - *t = 0; - if (urls++ == 0) { - htmlf(" ", columns); - htmlf("Clone\n", columns); - } - print_url(h, suffix); - *t = c; - h = t; - } } void cgit_print_summary() @@ -88,10 +56,8 @@ void cgit_print_summary() cgit_print_log(ctx.qry.head, 0, ctx.cfg.summary_log, NULL, NULL, NULL, 0, 0, 0); } - if (ctx.repo->clone_url) - print_urls(expand_macros(ctx.repo->clone_url), NULL); - else if (ctx.cfg.clone_prefix) - print_urls(ctx.cfg.clone_prefix, ctx.repo->url); + urls = 0; + cgit_add_clone_urls(print_url); html(""); } -- cgit v1.2.3-59-g8ed1b