summaryrefslogtreecommitdiffabout
path: root/cgit.c
Unidiff
Diffstat (limited to 'cgit.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/cgit.c b/cgit.c
index d975570..a3a04d9 100644
--- a/cgit.c
+++ b/cgit.c
@@ -1,57 +1,57 @@
1/* cgit.c: cgi for the git scm 1/* cgit.c: cgi for the git scm
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 "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_prepare_cache(struct cacheitem *item) 13static void cgit_prepare_cache(struct cacheitem *item)
14{ 14{
15 if (!cgit_query_repo) { 15 if (!cgit_query_repo) {
16 item->name = xstrdup(fmt("%s/index.html", cgit_cache_root)); 16 item->name = xstrdup(fmt("%s/index.html", cgit_cache_root));
17 item->ttl = cgit_cache_root_ttl; 17 item->ttl = cgit_cache_root_ttl;
18 } else if (!cgit_query_page) { 18 } else if (!cgit_query_page) {
19 item->name = xstrdup(fmt("%s/%s/index.html", cgit_cache_root, 19 item->name = xstrdup(fmt("%s/%s/index.html", cgit_cache_root,
20 cgit_query_repo)); 20 cgit_query_repo));
21 item->ttl = cgit_cache_repo_ttl; 21 item->ttl = cgit_cache_repo_ttl;
22 } else { 22 } else {
23 item->name = xstrdup(fmt("%s/%s/%s/%s.html", cgit_cache_root, 23 item->name = xstrdup(fmt("%s/%s/%s/%s.html", cgit_cache_root,
24 cgit_query_repo, cgit_query_page, 24 cgit_query_repo, cgit_query_page,
25 cgit_querystring)); 25 cache_safe_filename(cgit_querystring)));
26 if (cgit_query_has_symref) 26 if (cgit_query_has_symref)
27 item->ttl = cgit_cache_dynamic_ttl; 27 item->ttl = cgit_cache_dynamic_ttl;
28 else if (cgit_query_has_sha1) 28 else if (cgit_query_has_sha1)
29 item->ttl = cgit_cache_static_ttl; 29 item->ttl = cgit_cache_static_ttl;
30 else 30 else
31 item->ttl = cgit_cache_repo_ttl; 31 item->ttl = cgit_cache_repo_ttl;
32 } 32 }
33} 33}
34 34
35static void cgit_print_repo_page(struct cacheitem *item) 35static void cgit_print_repo_page(struct cacheitem *item)
36{ 36{
37 if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) || 37 if (chdir(fmt("%s/%s", cgit_root, cgit_query_repo)) ||
38 cgit_read_config("info/cgit", cgit_repo_config_cb)) { 38 cgit_read_config("info/cgit", cgit_repo_config_cb)) {
39 char *title = fmt("%s - %s", cgit_root_title, "Bad request"); 39 char *title = fmt("%s - %s", cgit_root_title, "Bad request");
40 cgit_print_docstart(title, item); 40 cgit_print_docstart(title, item);
41 cgit_print_pageheader(title, 0); 41 cgit_print_pageheader(title, 0);
42 cgit_print_error(fmt("Unable to scan repository: %s", 42 cgit_print_error(fmt("Unable to scan repository: %s",
43 strerror(errno))); 43 strerror(errno)));
44 cgit_print_docend(); 44 cgit_print_docend();
45 return; 45 return;
46 } 46 }
47 setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1); 47 setenv("GIT_DIR", fmt("%s/%s", cgit_root, cgit_query_repo), 1);
48 char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc); 48 char *title = fmt("%s - %s", cgit_repo_name, cgit_repo_desc);
49 int show_search = 0; 49 int show_search = 0;
50 if (cgit_query_page && !strcmp(cgit_query_page, "log")) 50 if (cgit_query_page && !strcmp(cgit_query_page, "log"))
51 show_search = 1; 51 show_search = 1;
52 cgit_print_docstart(title, item); 52 cgit_print_docstart(title, item);
53 cgit_print_pageheader(title, show_search); 53 cgit_print_pageheader(title, show_search);
54 if (!cgit_query_page) { 54 if (!cgit_query_page) {
55 cgit_print_summary(); 55 cgit_print_summary();
56 } else if (!strcmp(cgit_query_page, "log")) { 56 } else if (!strcmp(cgit_query_page, "log")) {
57 cgit_print_log(cgit_query_head, cgit_query_ofs, 100, cgit_query_search); 57 cgit_print_log(cgit_query_head, cgit_query_ofs, 100, cgit_query_search);