summaryrefslogtreecommitdiffabout
path: root/cgit.c
Unidiff
Diffstat (limited to 'cgit.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/cgit.c b/cgit.c
index 0f72f2d..ada488b 100644
--- a/cgit.c
+++ b/cgit.c
@@ -5,52 +5,54 @@
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 "cgit.h" 9#include "cgit.h"
10 10
11const char cgit_version[] = CGIT_VERSION; 11const char cgit_version[] = CGIT_VERSION;
12 12
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, 0, 100); 32 cgit_print_log(cgit_query_head, 0, 100);
33 } else if (!strcmp(cgit_query_page, "tree")) {
34 cgit_print_tree(cgit_query_sha1);
33 } else if (!strcmp(cgit_query_page, "view")) { 35 } else if (!strcmp(cgit_query_page, "view")) {
34 cgit_print_view(cgit_query_sha1); 36 cgit_print_view(cgit_query_sha1);
35 } 37 }
36 cgit_print_docend(); 38 cgit_print_docend();
37} 39}
38 40
39static void cgit_fill_cache(struct cacheitem *item) 41static void cgit_fill_cache(struct cacheitem *item)
40{ 42{
41 htmlfd = item->fd; 43 htmlfd = item->fd;
42 item->st.st_mtime = time(NULL); 44 item->st.st_mtime = time(NULL);
43 if (cgit_query_repo) 45 if (cgit_query_repo)
44 cgit_print_repo_page(item); 46 cgit_print_repo_page(item);
45 else 47 else
46 cgit_print_repolist(item); 48 cgit_print_repolist(item);
47} 49}
48 50
49static void cgit_check_cache(struct cacheitem *item) 51static void cgit_check_cache(struct cacheitem *item)
50{ 52{
51 int i = 0; 53 int i = 0;
52 54
53 cache_prepare(item); 55 cache_prepare(item);
54 top: 56 top:
55 if (++i > cgit_max_lock_attempts) { 57 if (++i > cgit_max_lock_attempts) {
56 die("cgit_refresh_cache: unable to lock %s: %s", 58 die("cgit_refresh_cache: unable to lock %s: %s",