Add submodule links in tree listing
When a submodule occurs in a tree, generate a link to show the module/commit. The link is specified as a sprintf string in /etc/cgitrc, using parameters 'module-link' and 'repo.module-link'. This should probably be extended with repo.module-link.$path. Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
parent
cc1dbd1b5d
commit
ded9393b17
2
cgit.css
2
cgit.css
@ -141,7 +141,7 @@ div.error {
|
||||
margin: 1em 2em;
|
||||
}
|
||||
|
||||
div.ls-blob, div.ls-dir {
|
||||
td.ls-blob, td.ls-dir, td.ls-mod {
|
||||
font-family: monospace;
|
||||
}
|
||||
|
||||
|
2
cgit.h
2
cgit.h
@ -33,6 +33,7 @@ struct repoinfo {
|
||||
char *path;
|
||||
char *desc;
|
||||
char *owner;
|
||||
char *module_link;
|
||||
int snapshots;
|
||||
};
|
||||
|
||||
@ -70,6 +71,7 @@ extern char *cgit_root_title;
|
||||
extern char *cgit_css;
|
||||
extern char *cgit_logo;
|
||||
extern char *cgit_logo_link;
|
||||
extern char *cgit_module_link;
|
||||
extern char *cgit_virtual_root;
|
||||
extern char *cgit_cache_root;
|
||||
|
||||
|
7
cgitrc
7
cgitrc
@ -47,6 +47,10 @@
|
||||
#logo-link=http://www.kernel.org/pub/software/scm/git/docs/
|
||||
|
||||
|
||||
## Url loaded when clicking a submodule link
|
||||
#module-link=./?repo=%s&page=commit&id=%s
|
||||
|
||||
|
||||
## Number of chars shown of commit subject message (in log view)
|
||||
#max-message-length=60
|
||||
|
||||
@ -81,4 +85,5 @@
|
||||
#repo.desc=the caching cgi for git
|
||||
#repo.path=/pub/git/cgit
|
||||
#repo.owner=Lars Hjemli
|
||||
#repo.snapshots=1 # override a sitewide snapshot-setting
|
||||
#repo.snapshots=1 # override a sitewide snapshot-setting
|
||||
#repo.module-link=/git/%s/commit/?id=%s # override the standard module-link
|
||||
|
3
html.c
3
html.c
@ -158,10 +158,11 @@ void html_filemode(unsigned short mode)
|
||||
html("d");
|
||||
else if (S_ISLNK(mode))
|
||||
html("l");
|
||||
else if (S_ISDIRLNK(mode))
|
||||
html("m");
|
||||
else
|
||||
html("-");
|
||||
html_fileperm(mode >> 6);
|
||||
html_fileperm(mode >> 3);
|
||||
html_fileperm(mode);
|
||||
}
|
||||
|
||||
|
6
shared.c
6
shared.c
@ -15,6 +15,7 @@ char *cgit_root_title = "Git repository browser";
|
||||
char *cgit_css = "/cgit.css";
|
||||
char *cgit_logo = "/git-logo.png";
|
||||
char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/";
|
||||
char *cgit_module_link = "./?repo=%s&page=commit&id=%s";
|
||||
char *cgit_virtual_root = NULL;
|
||||
|
||||
char *cgit_cache_root = "/var/cache/cgit";
|
||||
@ -85,6 +86,7 @@ struct repoinfo *add_repo(const char *url)
|
||||
ret->desc = NULL;
|
||||
ret->owner = NULL;
|
||||
ret->snapshots = cgit_snapshots;
|
||||
ret->module_link = cgit_module_link;
|
||||
return ret;
|
||||
}
|
||||
|
||||
@ -98,6 +100,8 @@ void cgit_global_config_cb(const char *name, const char *value)
|
||||
cgit_logo = xstrdup(value);
|
||||
else if (!strcmp(name, "logo-link"))
|
||||
cgit_logo_link = xstrdup(value);
|
||||
else if (!strcmp(name, "module-link"))
|
||||
cgit_module_link = xstrdup(value);
|
||||
else if (!strcmp(name, "virtual-root"))
|
||||
cgit_virtual_root = xstrdup(value);
|
||||
else if (!strcmp(name, "nocache"))
|
||||
@ -128,6 +132,8 @@ void cgit_global_config_cb(const char *name, const char *value)
|
||||
cgit_repo->owner = xstrdup(value);
|
||||
else if (cgit_repo && !strcmp(name, "repo.snapshots"))
|
||||
cgit_repo->snapshots = atoi(value);
|
||||
else if (cgit_repo && !strcmp(name, "repo.module-link"))
|
||||
cgit_repo->module_link= xstrdup(value);
|
||||
}
|
||||
|
||||
void cgit_repo_config_cb(const char *name, const char *value)
|
||||
|
19
ui-tree.c
19
ui-tree.c
@ -15,11 +15,11 @@ static int print_entry(const unsigned char *sha1, const char *base,
|
||||
{
|
||||
char *name;
|
||||
enum object_type type;
|
||||
unsigned long size;
|
||||
unsigned long size = 0;
|
||||
|
||||
name = xstrdup(pathname);
|
||||
type = sha1_object_info(sha1, &size);
|
||||
if (type == OBJ_BAD) {
|
||||
if (type == OBJ_BAD && !S_ISDIRLNK(mode)) {
|
||||
htmlf("<tr><td colspan='3'>Bad object: %s %s</td></tr>",
|
||||
name,
|
||||
sha1_to_hex(sha1));
|
||||
@ -27,26 +27,27 @@ static int print_entry(const unsigned char *sha1, const char *base,
|
||||
}
|
||||
html("<tr><td class='filemode'>");
|
||||
html_filemode(mode);
|
||||
html("</td><td>");
|
||||
html("</td><td ");
|
||||
if (S_ISDIRLNK(mode)) {
|
||||
htmlf("<div class='ls-dirlnk'>%s => submodule</div>", name);
|
||||
htmlf("class='ls-mod'><a href='");
|
||||
html_attr(fmt(cgit_repo->module_link,
|
||||
name,
|
||||
sha1_to_hex(sha1)));
|
||||
} else if (S_ISDIR(mode)) {
|
||||
html("<div class='ls-dir'><a href='");
|
||||
html("class='ls-dir'><a href='");
|
||||
html_attr(cgit_pageurl(cgit_query_repo, "tree",
|
||||
fmt("id=%s&path=%s%s/",
|
||||
sha1_to_hex(sha1),
|
||||
cgit_query_path ? cgit_query_path : "",
|
||||
pathname)));
|
||||
htmlf("'>%s</a></div>", name);
|
||||
} else {
|
||||
html("<div class='ls-blob'><a href='");
|
||||
html("class='ls-blob'><a href='");
|
||||
html_attr(cgit_pageurl(cgit_query_repo, "view",
|
||||
fmt("id=%s&path=%s%s", sha1_to_hex(sha1),
|
||||
cgit_query_path ? cgit_query_path : "",
|
||||
pathname)));
|
||||
htmlf("'>%s</a></div>", name);
|
||||
}
|
||||
html("</div></td>");
|
||||
htmlf("'>%s</a></div></td>", name);
|
||||
htmlf("<td class='filesize'>%li</td>", size);
|
||||
html("</tr>\n");
|
||||
free(name);
|
||||
|
Loading…
Reference in New Issue
Block a user