X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/0b8b6a317654dce2aa8c7ec5bf55717f624af14f..1a63cfcc3d83919e790e7e279eb35fc75adb0e3c:/ui-repolist.c diff --git a/ui-repolist.c b/ui-repolist.c index f5e087f..e5c6c20 100644 --- a/ui-repolist.c +++ b/ui-repolist.c @@ -7,6 +7,40 @@ */ #include "cgit.h" +#include + + +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) { @@ -19,7 +53,7 @@ void cgit_print_repolist(struct cacheitem *item) html(""); if (cgit_index_header) { - html(""); } @@ -27,6 +61,7 @@ void cgit_print_repolist(struct cacheitem *item) "" "" "" + "" "\n"); for (i=0; i
"); + html("
"); html_include(cgit_index_header); html("
NameDescriptionOwnerIdleLinks
"); html_txt(repo->owner); html(""); + print_modtime(repo); + html(""); html_link_open(cgit_repourl(repo->url), "Summary", "button"); html("S");