summaryrefslogtreecommitdiffabout
path: root/cgit.c
Unidiff
Diffstat (limited to 'cgit.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/cgit.c b/cgit.c
index 9dbc608..372b436 100644
--- a/cgit.c
+++ b/cgit.c
@@ -13,70 +13,74 @@ const char cgit_version[] = CGIT_VERSION;
13static void cgit_print_repo_page(struct cacheitem *item) 13static void cgit_print_repo_page(struct cacheitem *item)
14{ 14{
15 if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) || 15 if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) ||
16 cgit_read_config("info/cgit", cgit_repo_config_cb)) { 16 cgit_read_config("info/cgit", cgit_repo_config_cb)) {
17 char *title = fmt("%s - %s", cgit_root_title, "Bad request"); 17 char *title = fmt("%s - %s", cgit_root_title, "Bad request");
18 cgit_print_docstart(title, item); 18 cgit_print_docstart(title, item);
19 cgit_print_pageheader(title); 19 cgit_print_pageheader(title);
20 cgit_print_error(fmt("Unable to scan repository: %s", 20 cgit_print_error(fmt("Unable to scan repository: %s",
21 strerror(errno))); 21 strerror(errno)));
22 cgit_print_docend(); 22 cgit_print_docend();
23 return; 23 return;
24 } 24 }
25 setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1); 25 setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1);
26 char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc); 26 char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc);
27 cgit_print_docstart(title, item); 27 cgit_print_docstart(title, item);
28 cgit_print_pageheader(title); 28 cgit_print_pageheader(title);
29 if (!cgit_query_page) { 29 if (!cgit_query_page) {
30 cgit_print_summary(); 30 cgit_print_summary();
31 } else if (!strcmp(cgit_query_page, "log")) { 31 } else if (!strcmp(cgit_query_page, "log")) {
32 cgit_print_log(cgit_query_head, cgit_query_ofs, 100); 32 cgit_print_log(cgit_query_head, cgit_query_ofs, 100);
33 } else if (!strcmp(cgit_query_page, "tree")) { 33 } else if (!strcmp(cgit_query_page, "tree")) {
34 cgit_print_tree(cgit_query_sha1); 34 cgit_print_tree(cgit_query_sha1);
35 } else if (!strcmp(cgit_query_page, "commit")) { 35 } else if (!strcmp(cgit_query_page, "commit")) {
36 cgit_print_commit(cgit_query_sha1); 36 cgit_print_commit(cgit_query_sha1);
37 } else if (!strcmp(cgit_query_page, "view")) { 37 } else if (!strcmp(cgit_query_page, "view")) {
38 cgit_print_view(cgit_query_sha1); 38 cgit_print_view(cgit_query_sha1);
39 } 39 }
40 cgit_print_docend(); 40 cgit_print_docend();
41} 41}
42 42
43static void cgit_fill_cache(struct cacheitem *item) 43static void cgit_fill_cache(struct cacheitem *item)
44{ 44{
45 static char buf[PATH_MAX];
46
47 getcwd(buf, sizeof(buf));
45 htmlfd = item->fd; 48 htmlfd = item->fd;
46 item->st.st_mtime = time(NULL); 49 item->st.st_mtime = time(NULL);
47 if (cgit_query_repo) 50 if (cgit_query_repo)
48 cgit_print_repo_page(item); 51 cgit_print_repo_page(item);
49 else 52 else
50 cgit_print_repolist(item); 53 cgit_print_repolist(item);
54 chdir(buf);
51} 55}
52 56
53static void cgit_check_cache(struct cacheitem *item) 57static void cgit_check_cache(struct cacheitem *item)
54{ 58{
55 int i = 0; 59 int i = 0;
56 60
57 cache_prepare(item); 61 cache_prepare(item);
58 top: 62 top:
59 if (++i > cgit_max_lock_attempts) { 63 if (++i > cgit_max_lock_attempts) {
60 die("cgit_refresh_cache: unable to lock %s: %s", 64 die("cgit_refresh_cache: unable to lock %s: %s",
61 item->name, strerror(errno)); 65 item->name, strerror(errno));
62 } 66 }
63 if (!cache_exist(item)) { 67 if (!cache_exist(item)) {
64 if (!cache_lock(item)) { 68 if (!cache_lock(item)) {
65 sleep(1); 69 sleep(1);
66 goto top; 70 goto top;
67 } 71 }
68 if (!cache_exist(item)) { 72 if (!cache_exist(item)) {
69 cgit_fill_cache(item); 73 cgit_fill_cache(item);
70 cache_unlock(item); 74 cache_unlock(item);
71 } else { 75 } else {
72 cache_cancel_lock(item); 76 cache_cancel_lock(item);
73 } 77 }
74 } else if (cache_expired(item) && cache_lock(item)) { 78 } else if (cache_expired(item) && cache_lock(item)) {
75 if (cache_expired(item)) { 79 if (cache_expired(item)) {
76 cgit_fill_cache(item); 80 cgit_fill_cache(item);
77 cache_unlock(item); 81 cache_unlock(item);
78 } else { 82 } else {
79 cache_cancel_lock(item); 83 cache_cancel_lock(item);
80 } 84 }
81 } 85 }
82} 86}