author | Lars Hjemli <hjemli@gmail.com> | 2008-11-14 08:29:22 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2008-11-14 08:29:22 (UTC) |
commit | c7d1402b177f4cf835e81f962e2faa3c9e28c549 (patch) (side-by-side diff) | |
tree | 0e245a9ac0d422259116d222b2899d90c1fef327 | |
parent | 5b27248301db4b246bcd9977c6c3d2d4497b9ecb (diff) | |
download | cgit-c7d1402b177f4cf835e81f962e2faa3c9e28c549.zip cgit-c7d1402b177f4cf835e81f962e2faa3c9e28c549.tar.gz cgit-c7d1402b177f4cf835e81f962e2faa3c9e28c549.tar.bz2 |
ui-repolist: handle empty agefiles
When the agefile was empty the old code would happily reuse the static
buffer filled by a previous call to read_agefile().
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | ui-repolist.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/ui-repolist.c b/ui-repolist.c index ab050c7..c23232c 100644 --- a/ui-repolist.c +++ b/ui-repolist.c @@ -1,46 +1,47 @@ /* ui-repolist.c: functions for generating the repolist page * * Copyright (C) 2006 Lars Hjemli * * Licensed under GNU General Public License v2 * (see COPYING for full license text) */ #include <time.h> #include "cgit.h" #include "html.h" #include "ui-shared.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); + if (fgets(buf, sizeof(buf), f) == NULL) + return -1; fclose(f); if (parse_date(buf, buf2, sizeof(buf2))) return strtoul(buf2, NULL, 10); else return 0; } static void print_modtime(struct cgit_repo *repo) { char *path; struct stat s; path = fmt("%s/%s", repo->path, ctx.cfg.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); } |