mirror of
https://git.zx2c4.com/cgit
synced 2024-11-26 02:18:42 +00:00
Teach cgit how to group repositories by category
The new parameter 'repo.group' is used to set the repository group for the following repositores. Whenever this parameter changes value, a subheading is generated in the index page (printing the current value of repo.group). Signed-off-by: Lars Hjemli <hjemli@gmail.com>
This commit is contained in:
parent
08cc2e5f0e
commit
5877c49f68
5
cgit.css
5
cgit.css
@ -353,3 +353,8 @@ table.diff td div.del {
|
|||||||
.right {
|
.right {
|
||||||
text-align: right;
|
text-align: right;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
table.list td.repogroup {
|
||||||
|
padding-top: 1em;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
2
cgit.h
2
cgit.h
@ -36,6 +36,7 @@ struct repoinfo {
|
|||||||
char *desc;
|
char *desc;
|
||||||
char *owner;
|
char *owner;
|
||||||
char *defbranch;
|
char *defbranch;
|
||||||
|
char *group;
|
||||||
char *module_link;
|
char *module_link;
|
||||||
int snapshots;
|
int snapshots;
|
||||||
int enable_log_filecount;
|
int enable_log_filecount;
|
||||||
@ -80,6 +81,7 @@ extern char *cgit_module_link;
|
|||||||
extern char *cgit_virtual_root;
|
extern char *cgit_virtual_root;
|
||||||
extern char *cgit_script_name;
|
extern char *cgit_script_name;
|
||||||
extern char *cgit_cache_root;
|
extern char *cgit_cache_root;
|
||||||
|
extern char *cgit_repo_group;
|
||||||
|
|
||||||
extern int cgit_nocache;
|
extern int cgit_nocache;
|
||||||
extern int cgit_snapshots;
|
extern int cgit_snapshots;
|
||||||
|
4
shared.c
4
shared.c
@ -19,6 +19,7 @@ char *cgit_module_link = "./?repo=%s&page=commit&id=%s";
|
|||||||
char *cgit_virtual_root = NULL;
|
char *cgit_virtual_root = NULL;
|
||||||
char *cgit_script_name = CGIT_SCRIPT_NAME;
|
char *cgit_script_name = CGIT_SCRIPT_NAME;
|
||||||
char *cgit_cache_root = "/var/cache/cgit";
|
char *cgit_cache_root = "/var/cache/cgit";
|
||||||
|
char *cgit_repo_group = NULL;
|
||||||
|
|
||||||
int cgit_nocache = 0;
|
int cgit_nocache = 0;
|
||||||
int cgit_snapshots = 0;
|
int cgit_snapshots = 0;
|
||||||
@ -85,6 +86,7 @@ struct repoinfo *add_repo(const char *url)
|
|||||||
ret->path = NULL;
|
ret->path = NULL;
|
||||||
ret->desc = NULL;
|
ret->desc = NULL;
|
||||||
ret->owner = NULL;
|
ret->owner = NULL;
|
||||||
|
ret->group = cgit_repo_group;
|
||||||
ret->defbranch = "master";
|
ret->defbranch = "master";
|
||||||
ret->snapshots = cgit_snapshots;
|
ret->snapshots = cgit_snapshots;
|
||||||
ret->enable_log_filecount = cgit_enable_log_filecount;
|
ret->enable_log_filecount = cgit_enable_log_filecount;
|
||||||
@ -131,6 +133,8 @@ void cgit_global_config_cb(const char *name, const char *value)
|
|||||||
cgit_max_repodesc_len = atoi(value);
|
cgit_max_repodesc_len = atoi(value);
|
||||||
else if (!strcmp(name, "max-commit-count"))
|
else if (!strcmp(name, "max-commit-count"))
|
||||||
cgit_max_commit_count = atoi(value);
|
cgit_max_commit_count = atoi(value);
|
||||||
|
else if (!strcmp(name, "repo.group"))
|
||||||
|
cgit_repo_group = xstrdup(value);
|
||||||
else if (!strcmp(name, "repo.url"))
|
else if (!strcmp(name, "repo.url"))
|
||||||
cgit_repo = add_repo(value);
|
cgit_repo = add_repo(value);
|
||||||
else if (!strcmp(name, "repo.name"))
|
else if (!strcmp(name, "repo.name"))
|
||||||
|
@ -12,6 +12,7 @@ void cgit_print_repolist(struct cacheitem *item)
|
|||||||
{
|
{
|
||||||
struct repoinfo *repo;
|
struct repoinfo *repo;
|
||||||
int i;
|
int i;
|
||||||
|
char *last_group = NULL;
|
||||||
|
|
||||||
cgit_print_docstart(cgit_root_title, item);
|
cgit_print_docstart(cgit_root_title, item);
|
||||||
cgit_print_pageheader(cgit_root_title, 0);
|
cgit_print_pageheader(cgit_root_title, 0);
|
||||||
@ -25,6 +26,15 @@ void cgit_print_repolist(struct cacheitem *item)
|
|||||||
|
|
||||||
for (i=0; i<cgit_repolist.count; i++) {
|
for (i=0; i<cgit_repolist.count; i++) {
|
||||||
repo = &cgit_repolist.repos[i];
|
repo = &cgit_repolist.repos[i];
|
||||||
|
if ((last_group == NULL && repo->group != NULL) ||
|
||||||
|
(last_group != NULL && repo->group == NULL) ||
|
||||||
|
(last_group != NULL && repo->group!= NULL &&
|
||||||
|
strcmp(repo->group, last_group))) {
|
||||||
|
html("<tr><td colspan='4' class='repogroup'>");
|
||||||
|
html_txt(repo->group);
|
||||||
|
html("</td></tr>");
|
||||||
|
last_group = repo->group;
|
||||||
|
}
|
||||||
html("<tr><td>");
|
html("<tr><td>");
|
||||||
html_link_open(cgit_repourl(repo->url), NULL, NULL);
|
html_link_open(cgit_repourl(repo->url), NULL, NULL);
|
||||||
html_txt(repo->name);
|
html_txt(repo->name);
|
||||||
|
Loading…
Reference in New Issue
Block a user