]> gitweb.ps.run Git - ps-cgit/blobdiff - ui-repolist.c
Merge branch 'repogroups'
[ps-cgit] / ui-repolist.c
index d7311e4d492768c689d7a35196dfe45108b23d74..33e3e7fdcc45690aad81d66ebee33d31cdd84dcf 100644 (file)
@@ -12,11 +12,17 @@ void cgit_print_repolist(struct cacheitem *item)
 {
        struct repoinfo *repo;
        int i;
+       char *last_group = NULL;
 
        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='4' class='include-block'>");
+               html_include(cgit_index_header);
+               html("</td></tr>");
+       }
        html("<tr class='nohover'>"
             "<th class='left'>Name</th>"
             "<th class='left'>Description</th>"
@@ -25,6 +31,15 @@ void cgit_print_repolist(struct cacheitem *item)
 
        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);
+                       html("</td></tr>");
+                       last_group = repo->group;
+               }
                html("<tr><td>");
                html_link_open(cgit_repourl(repo->url), NULL, NULL);
                html_txt(repo->name);