Extract clone URL printing to ui-shared.c
This will allow us to reuse the same logic to add clone URL <link/> elements to the header of all repo-specific pages in order to support the rel-vcs microformat. Signed-off-by: John Keeping <john@keeping.me.uk>
This commit is contained in:
parent
485b09925c
commit
bbfa006e6e
37
ui-shared.c
37
ui-shared.c
@ -727,6 +727,43 @@ void cgit_print_docend()
|
|||||||
html("</body>\n</html>\n");
|
html("</body>\n</html>\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,
|
static int print_branch_option(const char *refname, const unsigned char *sha1,
|
||||||
int flags, void *cb_data)
|
int flags, void *cb_data)
|
||||||
{
|
{
|
||||||
|
@ -11,6 +11,8 @@ extern char *cgit_fileurl(const char *reponame, const char *pagename,
|
|||||||
extern char *cgit_pageurl(const char *reponame, const char *pagename,
|
extern char *cgit_pageurl(const char *reponame, const char *pagename,
|
||||||
const char *query);
|
const char *query);
|
||||||
|
|
||||||
|
extern void cgit_add_clone_urls(void (*fn)(const char *));
|
||||||
|
|
||||||
extern void cgit_index_link(const char *name, const char *title,
|
extern void cgit_index_link(const char *name, const char *title,
|
||||||
const char *class, const char *pattern, const char *sort, int ofs);
|
const char *class, const char *pattern, const char *sort, int ofs);
|
||||||
extern void cgit_summary_link(const char *name, const char *title,
|
extern void cgit_summary_link(const char *name, const char *title,
|
||||||
|
58
ui-summary.c
58
ui-summary.c
@ -12,62 +12,30 @@
|
|||||||
#include "ui-log.h"
|
#include "ui-log.h"
|
||||||
#include "ui-refs.h"
|
#include "ui-refs.h"
|
||||||
#include "ui-blob.h"
|
#include "ui-blob.h"
|
||||||
|
#include "ui-shared.h"
|
||||||
#include <libgen.h>
|
#include <libgen.h>
|
||||||
|
|
||||||
static void print_url(char *base, char *suffix)
|
static int urls;
|
||||||
|
|
||||||
|
static void print_url(const char *url)
|
||||||
{
|
{
|
||||||
int columns = 3;
|
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;
|
|
||||||
}
|
|
||||||
htmlf("<tr><td colspan='%d'><a href='", columns);
|
|
||||||
html_url_path(base);
|
|
||||||
html("'>");
|
|
||||||
html_txt(base);
|
|
||||||
html("</a></td></tr>\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)
|
if (ctx.repo->enable_log_filecount)
|
||||||
columns++;
|
columns++;
|
||||||
if (ctx.repo->enable_log_linecount)
|
if (ctx.repo->enable_log_linecount)
|
||||||
columns++;
|
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) {
|
if (urls++ == 0) {
|
||||||
htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns);
|
htmlf("<tr class='nohover'><td colspan='%d'> </td></tr>", columns);
|
||||||
htmlf("<tr><th class='left' colspan='%d'>Clone</th></tr>\n", columns);
|
htmlf("<tr><th class='left' colspan='%d'>Clone</th></tr>\n", columns);
|
||||||
}
|
}
|
||||||
print_url(h, suffix);
|
|
||||||
*t = c;
|
htmlf("<tr><td colspan='%d'><a href='", columns);
|
||||||
h = t;
|
html_url_path(url);
|
||||||
}
|
html("'>");
|
||||||
|
html_txt(url);
|
||||||
|
html("</a></td></tr>\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
void cgit_print_summary()
|
void cgit_print_summary()
|
||||||
@ -88,10 +56,8 @@ void cgit_print_summary()
|
|||||||
cgit_print_log(ctx.qry.head, 0, ctx.cfg.summary_log, NULL,
|
cgit_print_log(ctx.qry.head, 0, ctx.cfg.summary_log, NULL,
|
||||||
NULL, NULL, 0, 0, 0);
|
NULL, NULL, 0, 0, 0);
|
||||||
}
|
}
|
||||||
if (ctx.repo->clone_url)
|
urls = 0;
|
||||||
print_urls(expand_macros(ctx.repo->clone_url), NULL);
|
cgit_add_clone_urls(print_url);
|
||||||
else if (ctx.cfg.clone_prefix)
|
|
||||||
print_urls(ctx.cfg.clone_prefix, ctx.repo->url);
|
|
||||||
html("</table>");
|
html("</table>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user