summaryrefslogtreecommitdiffabout
path: root/ui-repolist.c
Unidiff
Diffstat (limited to 'ui-repolist.c') (more/less context) (ignore whitespace changes)
-rw-r--r--ui-repolist.c39
1 files changed, 8 insertions, 31 deletions
diff --git a/ui-repolist.c b/ui-repolist.c
index bd4af59..011ec95 100644
--- a/ui-repolist.c
+++ b/ui-repolist.c
@@ -12,8 +12,5 @@ void cgit_print_repolist(struct cacheitem *item)
12{ 12{
13 DIR *d; 13 struct repoinfo *repo;
14 struct dirent *de; 14 int i;
15 struct stat st;
16 char *name;
17 15
18 chdir(cgit_root);
19 cgit_print_docstart(cgit_root_title, item); 16 cgit_print_docstart(cgit_root_title, item);
@@ -21,9 +18,2 @@ void cgit_print_repolist(struct cacheitem *item)
21 18
22 if (!(d = opendir("."))) {
23 cgit_print_error(fmt("Unable to scan repository directory: %s",
24 strerror(errno)));
25 cgit_print_docend();
26 return;
27 }
28
29 html("<h2>Repositories</h2>\n"); 19 html("<h2>Repositories</h2>\n");
@@ -34,26 +24,15 @@ void cgit_print_repolist(struct cacheitem *item)
34 "<th class='left'>Owner</th></tr>\n"); 24 "<th class='left'>Owner</th></tr>\n");
35 while ((de = readdir(d)) != NULL) {
36 if (de->d_name[0] == '.')
37 continue;
38 if (stat(de->d_name, &st) < 0)
39 continue;
40 if (!S_ISDIR(st.st_mode))
41 continue;
42
43 cgit_repo_name = cgit_repo_desc = cgit_repo_owner = NULL;
44 name = fmt("%s/info/cgit", de->d_name);
45 if (cgit_read_config(name, cgit_repo_config_cb))
46 continue;
47 25
26 for (i=0; i<cgit_repolist.count; i++) {
27 repo = &cgit_repolist.repos[i];
48 html("<tr><td>"); 28 html("<tr><td>");
49 html_link_open(cgit_repourl(de->d_name), NULL, NULL); 29 html_link_open(cgit_repourl(repo->url), NULL, NULL);
50 html_txt(cgit_repo_name); 30 html_txt(repo->name);
51 html_link_close(); 31 html_link_close();
52 html("</td><td>"); 32 html("</td><td>");
53 html_txt(cgit_repo_desc); 33 html_txt(repo->desc);
54 html("</td><td>"); 34 html("</td><td>");
55 html_txt(cgit_repo_owner); 35 html_txt(repo->owner);
56 html("</td></tr>\n"); 36 html("</td></tr>\n");
57 } 37 }
58 closedir(d);
59 html("</table>"); 38 html("</table>");
@@ -61,3 +40 @@ void cgit_print_repolist(struct cacheitem *item)
61} }
62
63