summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2008-11-14 08:29:22 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2008-11-14 08:29:22 (UTC)
commitc7d1402b177f4cf835e81f962e2faa3c9e28c549 (patch) (unidiff)
tree0e245a9ac0d422259116d222b2899d90c1fef327
parent5b27248301db4b246bcd9977c6c3d2d4497b9ecb (diff)
downloadcgit-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>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ui-repolist.c3
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,70 +1,71 @@
1/* ui-repolist.c: functions for generating the repolist page 1/* ui-repolist.c: functions for generating the repolist page
2 * 2 *
3 * Copyright (C) 2006 Lars Hjemli 3 * Copyright (C) 2006 Lars Hjemli
4 * 4 *
5 * Licensed under GNU General Public License v2 5 * Licensed under GNU General Public License v2
6 * (see COPYING for full license text) 6 * (see COPYING for full license text)
7 */ 7 */
8 8
9#include <time.h> 9#include <time.h>
10 10
11#include "cgit.h" 11#include "cgit.h"
12#include "html.h" 12#include "html.h"
13#include "ui-shared.h" 13#include "ui-shared.h"
14 14
15time_t read_agefile(char *path) 15time_t read_agefile(char *path)
16{ 16{
17 FILE *f; 17 FILE *f;
18 static char buf[64], buf2[64]; 18 static char buf[64], buf2[64];
19 19
20 if (!(f = fopen(path, "r"))) 20 if (!(f = fopen(path, "r")))
21 return -1; 21 return -1;
22 fgets(buf, sizeof(buf), f); 22 if (fgets(buf, sizeof(buf), f) == NULL)
23 return -1;
23 fclose(f); 24 fclose(f);
24 if (parse_date(buf, buf2, sizeof(buf2))) 25 if (parse_date(buf, buf2, sizeof(buf2)))
25 return strtoul(buf2, NULL, 10); 26 return strtoul(buf2, NULL, 10);
26 else 27 else
27 return 0; 28 return 0;
28} 29}
29 30
30static void print_modtime(struct cgit_repo *repo) 31static void print_modtime(struct cgit_repo *repo)
31{ 32{
32 char *path; 33 char *path;
33 struct stat s; 34 struct stat s;
34 35
35 path = fmt("%s/%s", repo->path, ctx.cfg.agefile); 36 path = fmt("%s/%s", repo->path, ctx.cfg.agefile);
36 if (stat(path, &s) == 0) { 37 if (stat(path, &s) == 0) {
37 cgit_print_age(read_agefile(path), -1, NULL); 38 cgit_print_age(read_agefile(path), -1, NULL);
38 return; 39 return;
39 } 40 }
40 41
41 path = fmt("%s/refs/heads/%s", repo->path, repo->defbranch); 42 path = fmt("%s/refs/heads/%s", repo->path, repo->defbranch);
42 if (stat(path, &s) != 0) 43 if (stat(path, &s) != 0)
43 return; 44 return;
44 cgit_print_age(s.st_mtime, -1, NULL); 45 cgit_print_age(s.st_mtime, -1, NULL);
45} 46}
46 47
47int is_match(struct cgit_repo *repo) 48int is_match(struct cgit_repo *repo)
48{ 49{
49 if (!ctx.qry.search) 50 if (!ctx.qry.search)
50 return 1; 51 return 1;
51 if (repo->url && strcasestr(repo->url, ctx.qry.search)) 52 if (repo->url && strcasestr(repo->url, ctx.qry.search))
52 return 1; 53 return 1;
53 if (repo->name && strcasestr(repo->name, ctx.qry.search)) 54 if (repo->name && strcasestr(repo->name, ctx.qry.search))
54 return 1; 55 return 1;
55 if (repo->desc && strcasestr(repo->desc, ctx.qry.search)) 56 if (repo->desc && strcasestr(repo->desc, ctx.qry.search))
56 return 1; 57 return 1;
57 if (repo->owner && strcasestr(repo->owner, ctx.qry.search)) 58 if (repo->owner && strcasestr(repo->owner, ctx.qry.search))
58 return 1; 59 return 1;
59 return 0; 60 return 0;
60} 61}
61 62
62int is_in_url(struct cgit_repo *repo) 63int is_in_url(struct cgit_repo *repo)
63{ 64{
64 if (!ctx.qry.url) 65 if (!ctx.qry.url)
65 return 1; 66 return 1;
66 if (repo->url && !prefixcmp(repo->url, ctx.qry.url)) 67 if (repo->url && !prefixcmp(repo->url, ctx.qry.url))
67 return 1; 68 return 1;
68 return 0; 69 return 0;
69} 70}
70 71