diff options
Diffstat (limited to 'ui-repolist.c')
| -rw-r--r-- | ui-repolist.c | 66 | 
1 files changed, 36 insertions, 30 deletions
| diff --git a/ui-repolist.c b/ui-repolist.c index e5c6c20..4c86543 100644 --- a/ui-repolist.c +++ b/ui-repolist.c @@ -44,16 +44,19 @@ static void print_modtime(struct repoinfo *repo)  void cgit_print_repolist(struct cacheitem *item)  { -	struct repoinfo *repo; -	int i; +	int i, columns = 4;  	char *last_group = NULL; +	if (cgit_enable_index_links) +		columns++; +  	cgit_print_docstart(cgit_root_title, item);  	cgit_print_pageheader(cgit_root_title, 0);  	html("<table class='list nowrap'>");  	if (cgit_index_header) { -		html("<tr class='nohover'><td colspan='5' class='include-block'>"); +		htmlf("<tr class='nohover'><td colspan='%d' class='include-block'>", +		      columns);  		html_include(cgit_index_header);  		html("</td></tr>");  	} @@ -61,42 +64,45 @@ void cgit_print_repolist(struct cacheitem *item)  	     "<th class='left'>Name</th>"  	     "<th class='left'>Description</th>"  	     "<th class='left'>Owner</th>" -	     "<th class='left'>Idle</th>" -	     "<th>Links</th></tr>\n"); +	     "<th class='left'>Idle</th>"); +	if (cgit_enable_index_links) +		html("<th>Links</th>"); +	html("</tr>\n");  	for (i=0; i<cgit_repolist.count; 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 class='nohover'><td colspan='4' class='repogroup'>"); -			html_txt(repo->group); +		cgit_repo = &cgit_repolist.repos[i]; +		if ((last_group == NULL && cgit_repo->group != NULL) || +		    (last_group != NULL && cgit_repo->group == NULL) || +		    (last_group != NULL && cgit_repo->group != NULL && +		     strcmp(cgit_repo->group, last_group))) { +			htmlf("<tr class='nohover'><td colspan='%d' class='repogroup'>", +			      columns); +			html_txt(cgit_repo->group);  			html("</td></tr>"); -			last_group = repo->group; +			last_group = cgit_repo->group;  		}  		htmlf("<tr><td class='%s'>", -		      repo->group ? "sublevel-repo" : "toplevel-repo"); -		html_link_open(cgit_repourl(repo->url), repo->desc, NULL); -		html_txt(repo->name); +		      cgit_repo->group ? "sublevel-repo" : "toplevel-repo"); +		html_link_open(cgit_repourl(cgit_repo->url), NULL, NULL); +		html_txt(cgit_repo->name);  		html_link_close();  		html("</td><td>"); -		html_ntxt(cgit_max_repodesc_len, repo->desc); -		html("</td><td>"); -		html_txt(repo->owner); +		html_ntxt(cgit_max_repodesc_len, cgit_repo->desc);  		html("</td><td>"); -		print_modtime(repo); +		html_txt(cgit_repo->owner);  		html("</td><td>"); -		html_link_open(cgit_repourl(repo->url), -			       "Summary", "button"); -		html("S</a>"); -		html_link_open(cgit_pageurl(repo->name, "log", NULL), -			       "Log", "button"); -		html("L</a>"); -		html_link_open(cgit_pageurl(repo->name, "tree", NULL), -			       "Files", "button"); -		html("F</a>"); -		html("</td></tr>\n"); +		print_modtime(cgit_repo); +		html("</td>"); +		if (cgit_enable_index_links) { +			html("<td>"); +			html_link_open(cgit_repourl(cgit_repo->url), +				       NULL, "button"); +			html("summary</a>"); +			cgit_log_link("log", NULL, "button", NULL, NULL, NULL, 0); +			cgit_tree_link("tree", NULL, "button", NULL, NULL, NULL); +			html("</td>"); +		} +		html("</tr>\n");  	}  	html("</table>");  	cgit_print_docend(); | 
