]> gitweb.ps.run Git - ps-cgit/blobdiff - ui-repolist.c
Remove unused variable from ui-repolist.c:read_agefile()
[ps-cgit] / ui-repolist.c
index 8e367a2e34e386944bf9b2915c68945f1f886acb..e5c6c207818669ddb034bb2012ab6e44c6616498 100644 (file)
@@ -7,18 +7,53 @@
  */
 
 #include "cgit.h"
+#include <time.h>
+
+
+time_t read_agefile(char *path)
+{
+       FILE *f;
+       static char buf[64], buf2[64];
+
+       if (!(f = fopen(path, "r")))
+               return -1;
+       fgets(buf, sizeof(buf), f);
+       fclose(f);
+       if (parse_date(buf, buf2, sizeof(buf2)))
+               return strtoul(buf2, NULL, 10);
+       else
+               return 0;
+}
+
+static void print_modtime(struct repoinfo *repo)
+{
+       char *path;
+       struct stat s;
+
+       path = fmt("%s/%s", repo->path, cgit_agefile);
+       if (stat(path, &s) == 0) {
+               cgit_print_age(read_agefile(path), -1, NULL);
+               return;
+       }
+
+       path = fmt("%s/refs/heads/%s", repo->path, repo->defbranch);
+       if (stat(path, &s) != 0)
+               return;
+       cgit_print_age(s.st_mtime, -1, NULL);
+}
 
 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("<tr class='nohover'><td colspan='5' class='include-block'>");
                html_include(cgit_index_header);
                html("</td></tr>");
        }
@@ -26,12 +61,23 @@ 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'>Links</th></tr>\n");
+            "<th class='left'>Idle</th>"
+            "<th>Links</th></tr>\n");
 
        for (i=0; i<cgit_repolist.count; i++) {
                repo = &cgit_repolist.repos[i];
-               html("<tr><td>");
-               html_link_open(cgit_repourl(repo->url), NULL, NULL);
+               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;
+               }
+               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);
                html_link_close();
                html("</td><td>");
@@ -39,18 +85,17 @@ void cgit_print_repolist(struct cacheitem *item)
                html("</td><td>");
                html_txt(repo->owner);
                html("</td><td>");
-               html_link_open(cgit_pageurl(repo->name, "commit", NULL),
-                              "Commit: display last commit", NULL);
-               html("C</a> ");
-               html_link_open(cgit_pageurl(repo->name, "diff", NULL),
-                              "Diff: see changes introduced by last commit", NULL);
-               html("D</a> ");
+               print_modtime(repo);
+               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: show history of the main branch", NULL);
-               html("L</a> ");
+                              "Log", "button");
+               html("L</a>");
                html_link_open(cgit_pageurl(repo->name, "tree", NULL),
-                              "Tree: browse the files in the main branch", NULL);
-               html("T</a>");
+                              "Files", "button");
+               html("F</a>");
                html("</td></tr>\n");
        }
        html("</table>");