-rw-r--r-- | Makefile | 4 | ||||
-rw-r--r-- | cgit.c | 2 | ||||
-rw-r--r-- | cgit.h | 1 | ||||
-rw-r--r-- | shared.c | 2 | ||||
-rw-r--r-- | ui-shared.c | 4 |
5 files changed, 9 insertions, 4 deletions
@@ -1,83 +1,85 @@ | |||
1 | CGIT_VERSION = 0.4 | 1 | CGIT_VERSION = 0.4 |
2 | 2 | ||
3 | prefix = /var/www/htdocs/cgit | 3 | prefix = /var/www/htdocs/cgit |
4 | 4 | ||
5 | SHA1_HEADER = <openssl/sha.h> | 5 | SHA1_HEADER = <openssl/sha.h> |
6 | CACHE_ROOT = /var/cache/cgit | 6 | CACHE_ROOT = /var/cache/cgit |
7 | CGIT_CONFIG = /etc/cgitrc | 7 | CGIT_CONFIG = /etc/cgitrc |
8 | CGIT_SCRIPT_NAME = cgit.cgi | ||
8 | 9 | ||
9 | EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto | 10 | EXTLIBS = git/libgit.a git/xdiff/lib.a -lz -lcrypto |
10 | OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \ | 11 | OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \ |
11 | ui-summary.o ui-log.o ui-view.o ui-tree.o ui-commit.o ui-diff.o \ | 12 | ui-summary.o ui-log.o ui-view.o ui-tree.o ui-commit.o ui-diff.o \ |
12 | ui-snapshot.o ui-blob.o | 13 | ui-snapshot.o ui-blob.o |
13 | 14 | ||
14 | CFLAGS += -Wall | 15 | CFLAGS += -Wall |
15 | 16 | ||
16 | ifdef DEBUG | 17 | ifdef DEBUG |
17 | CFLAGS += -g | 18 | CFLAGS += -g |
18 | endif | 19 | endif |
19 | 20 | ||
20 | CFLAGS += -Igit | 21 | CFLAGS += -Igit |
21 | CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' | 22 | CFLAGS += -DSHA1_HEADER='$(SHA1_HEADER)' |
22 | CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' | 23 | CFLAGS += -DCGIT_VERSION='"$(CGIT_VERSION)"' |
23 | CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' | 24 | CFLAGS += -DCGIT_CONFIG='"$(CGIT_CONFIG)"' |
25 | CFLAGS += -DCGIT_SCRIPT_NAME='"$(CGIT_SCRIPT_NAME)"' | ||
24 | 26 | ||
25 | 27 | ||
26 | # | 28 | # |
27 | # If make is run on a nongit platform, we need to get the git sources as a tarball. | 29 | # If make is run on a nongit platform, we need to get the git sources as a tarball. |
28 | # But there is currently no recent enough tarball available on kernel.org, so download | 30 | # But there is currently no recent enough tarball available on kernel.org, so download |
29 | # a zipfile from hjemli.net instead | 31 | # a zipfile from hjemli.net instead |
30 | # | 32 | # |
31 | GITVER = $(shell git version 2>/dev/null || echo nogit) | 33 | GITVER = $(shell git version 2>/dev/null || echo nogit) |
32 | ifeq ($(GITVER),nogit) | 34 | ifeq ($(GITVER),nogit) |
33 | GITURL = http://hjemli.net/git/git/snapshot/?id=v1.5.2-rc2 | 35 | GITURL = http://hjemli.net/git/git/snapshot/?id=v1.5.2-rc2 |
34 | INITGIT = test -e git/git.c || (curl "$(GITURL)" > tmp.zip && unzip tmp.zip) | 36 | INITGIT = test -e git/git.c || (curl "$(GITURL)" > tmp.zip && unzip tmp.zip) |
35 | else | 37 | else |
36 | INITGIT = ./submodules.sh -i | 38 | INITGIT = ./submodules.sh -i |
37 | endif | 39 | endif |
38 | 40 | ||
39 | 41 | ||
40 | # | 42 | # |
41 | # basic build rules | 43 | # basic build rules |
42 | # | 44 | # |
43 | all: cgit | 45 | all: cgit |
44 | 46 | ||
45 | cgit: cgit.c cgit.h $(OBJECTS) | 47 | cgit: cgit.c cgit.h $(OBJECTS) |
46 | $(CC) $(CFLAGS) cgit.c -o cgit $(OBJECTS) $(EXTLIBS) | 48 | $(CC) $(CFLAGS) cgit.c -o cgit $(OBJECTS) $(EXTLIBS) |
47 | 49 | ||
48 | $(OBJECTS): cgit.h git/libgit.a | 50 | $(OBJECTS): cgit.h git/libgit.a |
49 | 51 | ||
50 | git/libgit.a: | 52 | git/libgit.a: |
51 | $(INITGIT) | 53 | $(INITGIT) |
52 | $(MAKE) -C git | 54 | $(MAKE) -C git |
53 | 55 | ||
54 | # | 56 | # |
55 | # phony targets | 57 | # phony targets |
56 | # | 58 | # |
57 | install: all clean-cache | 59 | install: all clean-cache |
58 | mkdir -p $(prefix) | 60 | mkdir -p $(prefix) |
59 | install cgit $(prefix)/cgit.cgi | 61 | install cgit $(prefix)/$(CGIT_SCRIPT_NAME) |
60 | install cgit.css $(prefix)/cgit.css | 62 | install cgit.css $(prefix)/cgit.css |
61 | install add.png del.png $(prefix)/ | 63 | install add.png del.png $(prefix)/ |
62 | 64 | ||
63 | clean-cgit: | 65 | clean-cgit: |
64 | rm -f cgit *.o | 66 | rm -f cgit *.o |
65 | 67 | ||
66 | distclean-cgit: clean-cgit | 68 | distclean-cgit: clean-cgit |
67 | git clean -d -x | 69 | git clean -d -x |
68 | 70 | ||
69 | clean-sub: | 71 | clean-sub: |
70 | $(MAKE) -C git clean | 72 | $(MAKE) -C git clean |
71 | 73 | ||
72 | distclean-sub: clean-sub | 74 | distclean-sub: clean-sub |
73 | $(shell cd git && git clean -d -x) | 75 | $(shell cd git && git clean -d -x) |
74 | 76 | ||
75 | clean-cache: | 77 | clean-cache: |
76 | rm -rf $(CACHE_ROOT)/* | 78 | rm -rf $(CACHE_ROOT)/* |
77 | 79 | ||
78 | clean: clean-cgit clean-sub | 80 | clean: clean-cgit clean-sub |
79 | 81 | ||
80 | distclean: distclean-cgit distclean-sub | 82 | distclean: distclean-cgit distclean-sub |
81 | 83 | ||
82 | .PHONY: all install clean clean-cgit clean-sub clean-cache \ | 84 | .PHONY: all install clean clean-cgit clean-sub clean-cache \ |
83 | distclean distclean-cgit distclean-sub | 85 | distclean distclean-cgit distclean-sub |
@@ -215,46 +215,48 @@ static void cgit_parse_args(int argc, const char **argv) | |||
215 | } | 215 | } |
216 | if (!strncmp(argv[i], "--repo=", 7)) { | 216 | if (!strncmp(argv[i], "--repo=", 7)) { |
217 | cgit_query_repo = xstrdup(argv[i]+7); | 217 | cgit_query_repo = xstrdup(argv[i]+7); |
218 | } | 218 | } |
219 | if (!strncmp(argv[i], "--page=", 7)) { | 219 | if (!strncmp(argv[i], "--page=", 7)) { |
220 | cgit_query_page = xstrdup(argv[i]+7); | 220 | cgit_query_page = xstrdup(argv[i]+7); |
221 | } | 221 | } |
222 | if (!strncmp(argv[i], "--head=", 7)) { | 222 | if (!strncmp(argv[i], "--head=", 7)) { |
223 | cgit_query_head = xstrdup(argv[i]+7); | 223 | cgit_query_head = xstrdup(argv[i]+7); |
224 | cgit_query_has_symref = 1; | 224 | cgit_query_has_symref = 1; |
225 | } | 225 | } |
226 | if (!strncmp(argv[i], "--sha1=", 7)) { | 226 | if (!strncmp(argv[i], "--sha1=", 7)) { |
227 | cgit_query_sha1 = xstrdup(argv[i]+7); | 227 | cgit_query_sha1 = xstrdup(argv[i]+7); |
228 | cgit_query_has_sha1 = 1; | 228 | cgit_query_has_sha1 = 1; |
229 | } | 229 | } |
230 | if (!strncmp(argv[i], "--ofs=", 6)) { | 230 | if (!strncmp(argv[i], "--ofs=", 6)) { |
231 | cgit_query_ofs = atoi(argv[i]+6); | 231 | cgit_query_ofs = atoi(argv[i]+6); |
232 | } | 232 | } |
233 | } | 233 | } |
234 | } | 234 | } |
235 | 235 | ||
236 | int main(int argc, const char **argv) | 236 | int main(int argc, const char **argv) |
237 | { | 237 | { |
238 | struct cacheitem item; | 238 | struct cacheitem item; |
239 | 239 | ||
240 | htmlfd = STDOUT_FILENO; | 240 | htmlfd = STDOUT_FILENO; |
241 | item.st.st_mtime = time(NULL); | 241 | item.st.st_mtime = time(NULL); |
242 | cgit_repolist.length = 0; | 242 | cgit_repolist.length = 0; |
243 | cgit_repolist.count = 0; | 243 | cgit_repolist.count = 0; |
244 | cgit_repolist.repos = NULL; | 244 | cgit_repolist.repos = NULL; |
245 | 245 | ||
246 | cgit_read_config(CGIT_CONFIG, cgit_global_config_cb); | 246 | cgit_read_config(CGIT_CONFIG, cgit_global_config_cb); |
247 | if (getenv("SCRIPT_NAME")) | ||
248 | cgit_script_name = xstrdup(getenv("SCRIPT_NAME")); | ||
247 | if (getenv("QUERY_STRING")) | 249 | if (getenv("QUERY_STRING")) |
248 | cgit_querystring = xstrdup(getenv("QUERY_STRING")); | 250 | cgit_querystring = xstrdup(getenv("QUERY_STRING")); |
249 | cgit_parse_args(argc, argv); | 251 | cgit_parse_args(argc, argv); |
250 | cgit_parse_query(cgit_querystring, cgit_querystring_cb); | 252 | cgit_parse_query(cgit_querystring, cgit_querystring_cb); |
251 | if (!cgit_prepare_cache(&item)) | 253 | if (!cgit_prepare_cache(&item)) |
252 | return 0; | 254 | return 0; |
253 | if (cgit_nocache) { | 255 | if (cgit_nocache) { |
254 | cgit_fill_cache(&item, 0); | 256 | cgit_fill_cache(&item, 0); |
255 | } else { | 257 | } else { |
256 | cgit_check_cache(&item); | 258 | cgit_check_cache(&item); |
257 | cgit_print_cache(&item); | 259 | cgit_print_cache(&item); |
258 | } | 260 | } |
259 | return 0; | 261 | return 0; |
260 | } | 262 | } |
@@ -46,64 +46,65 @@ struct repolist { | |||
46 | }; | 46 | }; |
47 | 47 | ||
48 | struct commitinfo { | 48 | struct commitinfo { |
49 | struct commit *commit; | 49 | struct commit *commit; |
50 | char *author; | 50 | char *author; |
51 | char *author_email; | 51 | char *author_email; |
52 | unsigned long author_date; | 52 | unsigned long author_date; |
53 | char *committer; | 53 | char *committer; |
54 | char *committer_email; | 54 | char *committer_email; |
55 | unsigned long committer_date; | 55 | unsigned long committer_date; |
56 | char *subject; | 56 | char *subject; |
57 | char *msg; | 57 | char *msg; |
58 | }; | 58 | }; |
59 | 59 | ||
60 | struct taginfo { | 60 | struct taginfo { |
61 | char *tagger; | 61 | char *tagger; |
62 | char *tagger_email; | 62 | char *tagger_email; |
63 | int tagger_date; | 63 | int tagger_date; |
64 | char *msg; | 64 | char *msg; |
65 | }; | 65 | }; |
66 | 66 | ||
67 | extern const char cgit_version[]; | 67 | extern const char cgit_version[]; |
68 | 68 | ||
69 | extern struct repolist cgit_repolist; | 69 | extern struct repolist cgit_repolist; |
70 | extern struct repoinfo *cgit_repo; | 70 | extern struct repoinfo *cgit_repo; |
71 | 71 | ||
72 | extern char *cgit_root_title; | 72 | extern char *cgit_root_title; |
73 | extern char *cgit_css; | 73 | extern char *cgit_css; |
74 | extern char *cgit_logo; | 74 | extern char *cgit_logo; |
75 | extern char *cgit_logo_link; | 75 | extern char *cgit_logo_link; |
76 | extern char *cgit_module_link; | 76 | extern char *cgit_module_link; |
77 | extern char *cgit_virtual_root; | 77 | extern char *cgit_virtual_root; |
78 | extern char *cgit_script_name; | ||
78 | extern char *cgit_cache_root; | 79 | extern char *cgit_cache_root; |
79 | 80 | ||
80 | extern int cgit_nocache; | 81 | extern int cgit_nocache; |
81 | extern int cgit_snapshots; | 82 | extern int cgit_snapshots; |
82 | extern int cgit_max_lock_attempts; | 83 | extern int cgit_max_lock_attempts; |
83 | extern int cgit_cache_root_ttl; | 84 | extern int cgit_cache_root_ttl; |
84 | extern int cgit_cache_repo_ttl; | 85 | extern int cgit_cache_repo_ttl; |
85 | extern int cgit_cache_dynamic_ttl; | 86 | extern int cgit_cache_dynamic_ttl; |
86 | extern int cgit_cache_static_ttl; | 87 | extern int cgit_cache_static_ttl; |
87 | extern int cgit_cache_max_create_time; | 88 | extern int cgit_cache_max_create_time; |
88 | 89 | ||
89 | extern int cgit_max_msg_len; | 90 | extern int cgit_max_msg_len; |
90 | extern int cgit_max_commit_count; | 91 | extern int cgit_max_commit_count; |
91 | 92 | ||
92 | extern char *cgit_repo_name; | 93 | extern char *cgit_repo_name; |
93 | extern char *cgit_repo_desc; | 94 | extern char *cgit_repo_desc; |
94 | extern char *cgit_repo_owner; | 95 | extern char *cgit_repo_owner; |
95 | 96 | ||
96 | extern int cgit_query_has_symref; | 97 | extern int cgit_query_has_symref; |
97 | extern int cgit_query_has_sha1; | 98 | extern int cgit_query_has_sha1; |
98 | 99 | ||
99 | extern char *cgit_querystring; | 100 | extern char *cgit_querystring; |
100 | extern char *cgit_query_repo; | 101 | extern char *cgit_query_repo; |
101 | extern char *cgit_query_page; | 102 | extern char *cgit_query_page; |
102 | extern char *cgit_query_search; | 103 | extern char *cgit_query_search; |
103 | extern char *cgit_query_head; | 104 | extern char *cgit_query_head; |
104 | extern char *cgit_query_sha1; | 105 | extern char *cgit_query_sha1; |
105 | extern char *cgit_query_sha2; | 106 | extern char *cgit_query_sha2; |
106 | extern char *cgit_query_path; | 107 | extern char *cgit_query_path; |
107 | extern char *cgit_query_name; | 108 | extern char *cgit_query_name; |
108 | extern int cgit_query_ofs; | 109 | extern int cgit_query_ofs; |
109 | 110 | ||
@@ -1,52 +1,52 @@ | |||
1 | /* shared.c: global vars + some callback functions | 1 | /* shared.c: global vars + some callback functions |
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 | ||
11 | struct repolist cgit_repolist; | 11 | struct repolist cgit_repolist; |
12 | struct repoinfo *cgit_repo; | 12 | struct repoinfo *cgit_repo; |
13 | 13 | ||
14 | char *cgit_root_title = "Git repository browser"; | 14 | char *cgit_root_title = "Git repository browser"; |
15 | char *cgit_css = "/cgit.css"; | 15 | char *cgit_css = "/cgit.css"; |
16 | char *cgit_logo = "/git-logo.png"; | 16 | char *cgit_logo = "/git-logo.png"; |
17 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; | 17 | char *cgit_logo_link = "http://www.kernel.org/pub/software/scm/git/docs/"; |
18 | char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; | 18 | char *cgit_module_link = "./?repo=%s&page=commit&id=%s"; |
19 | char *cgit_virtual_root = NULL; | 19 | char *cgit_virtual_root = NULL; |
20 | 20 | char *cgit_script_name = CGIT_SCRIPT_NAME; | |
21 | char *cgit_cache_root = "/var/cache/cgit"; | 21 | char *cgit_cache_root = "/var/cache/cgit"; |
22 | 22 | ||
23 | int cgit_nocache = 0; | 23 | int cgit_nocache = 0; |
24 | int cgit_snapshots = 0; | 24 | int cgit_snapshots = 0; |
25 | int cgit_max_lock_attempts = 5; | 25 | int cgit_max_lock_attempts = 5; |
26 | int cgit_cache_root_ttl = 5; | 26 | int cgit_cache_root_ttl = 5; |
27 | int cgit_cache_repo_ttl = 5; | 27 | int cgit_cache_repo_ttl = 5; |
28 | int cgit_cache_dynamic_ttl = 5; | 28 | int cgit_cache_dynamic_ttl = 5; |
29 | int cgit_cache_static_ttl = -1; | 29 | int cgit_cache_static_ttl = -1; |
30 | int cgit_cache_max_create_time = 5; | 30 | int cgit_cache_max_create_time = 5; |
31 | 31 | ||
32 | int cgit_max_msg_len = 60; | 32 | int cgit_max_msg_len = 60; |
33 | int cgit_max_commit_count = 50; | 33 | int cgit_max_commit_count = 50; |
34 | 34 | ||
35 | char *cgit_repo_name = NULL; | 35 | char *cgit_repo_name = NULL; |
36 | char *cgit_repo_desc = NULL; | 36 | char *cgit_repo_desc = NULL; |
37 | char *cgit_repo_owner = NULL; | 37 | char *cgit_repo_owner = NULL; |
38 | 38 | ||
39 | int cgit_query_has_symref = 0; | 39 | int cgit_query_has_symref = 0; |
40 | int cgit_query_has_sha1 = 0; | 40 | int cgit_query_has_sha1 = 0; |
41 | 41 | ||
42 | char *cgit_querystring = NULL; | 42 | char *cgit_querystring = NULL; |
43 | char *cgit_query_repo = NULL; | 43 | char *cgit_query_repo = NULL; |
44 | char *cgit_query_page = NULL; | 44 | char *cgit_query_page = NULL; |
45 | char *cgit_query_head = NULL; | 45 | char *cgit_query_head = NULL; |
46 | char *cgit_query_search = NULL; | 46 | char *cgit_query_search = NULL; |
47 | char *cgit_query_sha1 = NULL; | 47 | char *cgit_query_sha1 = NULL; |
48 | char *cgit_query_sha2 = NULL; | 48 | char *cgit_query_sha2 = NULL; |
49 | char *cgit_query_path = NULL; | 49 | char *cgit_query_path = NULL; |
50 | char *cgit_query_name = NULL; | 50 | char *cgit_query_name = NULL; |
51 | int cgit_query_ofs = 0; | 51 | int cgit_query_ofs = 0; |
52 | 52 | ||
diff --git a/ui-shared.c b/ui-shared.c index 6f5cf2b..b0cff7d 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
@@ -16,91 +16,91 @@ static char *http_date(time_t t) | |||
16 | { | 16 | { |
17 | static char day[][4] = | 17 | static char day[][4] = |
18 | {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"}; | 18 | {"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"}; |
19 | static char month[][4] = | 19 | static char month[][4] = |
20 | {"Jan", "Feb", "Mar", "Apr", "May", "Jun", | 20 | {"Jan", "Feb", "Mar", "Apr", "May", "Jun", |
21 | "Jul", "Aug", "Sep", "Oct", "Now", "Dec"}; | 21 | "Jul", "Aug", "Sep", "Oct", "Now", "Dec"}; |
22 | struct tm *tm = gmtime(&t); | 22 | struct tm *tm = gmtime(&t); |
23 | return fmt("%s, %02d %s %04d %02d:%02d:%02d GMT", day[tm->tm_wday], | 23 | return fmt("%s, %02d %s %04d %02d:%02d:%02d GMT", day[tm->tm_wday], |
24 | tm->tm_mday, month[tm->tm_mon], 1900+tm->tm_year, | 24 | tm->tm_mday, month[tm->tm_mon], 1900+tm->tm_year, |
25 | tm->tm_hour, tm->tm_min, tm->tm_sec); | 25 | tm->tm_hour, tm->tm_min, tm->tm_sec); |
26 | } | 26 | } |
27 | 27 | ||
28 | static long ttl_seconds(long ttl) | 28 | static long ttl_seconds(long ttl) |
29 | { | 29 | { |
30 | if (ttl<0) | 30 | if (ttl<0) |
31 | return 60 * 60 * 24 * 365; | 31 | return 60 * 60 * 24 * 365; |
32 | else | 32 | else |
33 | return ttl * 60; | 33 | return ttl * 60; |
34 | } | 34 | } |
35 | 35 | ||
36 | void cgit_print_error(char *msg) | 36 | void cgit_print_error(char *msg) |
37 | { | 37 | { |
38 | html("<div class='error'>"); | 38 | html("<div class='error'>"); |
39 | html_txt(msg); | 39 | html_txt(msg); |
40 | html("</div>\n"); | 40 | html("</div>\n"); |
41 | } | 41 | } |
42 | 42 | ||
43 | char *cgit_rooturl() | 43 | char *cgit_rooturl() |
44 | { | 44 | { |
45 | if (cgit_virtual_root) | 45 | if (cgit_virtual_root) |
46 | return fmt("%s/", cgit_virtual_root); | 46 | return fmt("%s/", cgit_virtual_root); |
47 | else | 47 | else |
48 | return "./cgit.cgi"; | 48 | return cgit_script_name; |
49 | } | 49 | } |
50 | 50 | ||
51 | char *cgit_repourl(const char *reponame) | 51 | char *cgit_repourl(const char *reponame) |
52 | { | 52 | { |
53 | if (cgit_virtual_root) { | 53 | if (cgit_virtual_root) { |
54 | return fmt("%s/%s/", cgit_virtual_root, reponame); | 54 | return fmt("%s/%s/", cgit_virtual_root, reponame); |
55 | } else { | 55 | } else { |
56 | return fmt("?r=%s", reponame); | 56 | return fmt("?r=%s", reponame); |
57 | } | 57 | } |
58 | } | 58 | } |
59 | 59 | ||
60 | char *cgit_pageurl(const char *reponame, const char *pagename, | 60 | char *cgit_pageurl(const char *reponame, const char *pagename, |
61 | const char *query) | 61 | const char *query) |
62 | { | 62 | { |
63 | if (cgit_virtual_root) { | 63 | if (cgit_virtual_root) { |
64 | return fmt("%s/%s/%s/?%s", cgit_virtual_root, reponame, | 64 | return fmt("%s/%s/%s/?%s", cgit_virtual_root, reponame, |
65 | pagename, query); | 65 | pagename, query); |
66 | } else { | 66 | } else { |
67 | return fmt("?r=%s&p=%s&%s", reponame, pagename, query); | 67 | return fmt("?r=%s&p=%s&%s", reponame, pagename, query); |
68 | } | 68 | } |
69 | } | 69 | } |
70 | 70 | ||
71 | char *cgit_currurl() | 71 | char *cgit_currurl() |
72 | { | 72 | { |
73 | if (!cgit_virtual_root) | 73 | if (!cgit_virtual_root) |
74 | return "./cgit.cgi"; | 74 | return cgit_script_name; |
75 | else if (cgit_query_page) | 75 | else if (cgit_query_page) |
76 | return fmt("%s/%s/%s/", cgit_virtual_root, cgit_query_repo, cgit_query_page); | 76 | return fmt("%s/%s/%s/", cgit_virtual_root, cgit_query_repo, cgit_query_page); |
77 | else if (cgit_query_repo) | 77 | else if (cgit_query_repo) |
78 | return fmt("%s/%s/", cgit_virtual_root, cgit_query_repo); | 78 | return fmt("%s/%s/", cgit_virtual_root, cgit_query_repo); |
79 | else | 79 | else |
80 | return fmt("%s/", cgit_virtual_root); | 80 | return fmt("%s/", cgit_virtual_root); |
81 | } | 81 | } |
82 | 82 | ||
83 | 83 | ||
84 | void cgit_print_date(unsigned long secs) | 84 | void cgit_print_date(unsigned long secs) |
85 | { | 85 | { |
86 | char buf[32]; | 86 | char buf[32]; |
87 | struct tm *time; | 87 | struct tm *time; |
88 | 88 | ||
89 | time = gmtime(&secs); | 89 | time = gmtime(&secs); |
90 | strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M:%S", time); | 90 | strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M:%S", time); |
91 | html_txt(buf); | 91 | html_txt(buf); |
92 | } | 92 | } |
93 | 93 | ||
94 | void cgit_print_docstart(char *title, struct cacheitem *item) | 94 | void cgit_print_docstart(char *title, struct cacheitem *item) |
95 | { | 95 | { |
96 | html("Content-Type: text/html; charset=utf-8\n"); | 96 | html("Content-Type: text/html; charset=utf-8\n"); |
97 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); | 97 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); |
98 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + | 98 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + |
99 | ttl_seconds(item->ttl))); | 99 | ttl_seconds(item->ttl))); |
100 | html("\n"); | 100 | html("\n"); |
101 | html(cgit_doctype); | 101 | html(cgit_doctype); |
102 | html("<html>\n"); | 102 | html("<html>\n"); |
103 | html("<head>\n"); | 103 | html("<head>\n"); |
104 | html("<title>"); | 104 | html("<title>"); |
105 | html_txt(title); | 105 | html_txt(title); |
106 | html("</title>\n"); | 106 | html("</title>\n"); |