summaryrefslogtreecommitdiffabout
path: root/cgit.c
Side-by-side diff
Diffstat (limited to 'cgit.c') (more/less context) (ignore whitespace changes)
-rw-r--r--cgit.c39
1 files changed, 32 insertions, 7 deletions
diff --git a/cgit.c b/cgit.c
index 0fa203c..2795ecc 100644
--- a/cgit.c
+++ b/cgit.c
@@ -79,4 +79,11 @@ static void cgit_print_repo_page(struct cacheitem *item)
show_search = 0;
setenv("GIT_DIR", cgit_repo->path, 1);
+
+ if (cgit_query_page && !strcmp(cgit_query_page, "snapshot")) {
+ cgit_print_snapshot(item, cgit_query_sha1, "zip",
+ cgit_repo->url, cgit_query_name);
+ return;
+ }
+
if (cgit_query_page && !strcmp(cgit_query_page, "log"))
show_search = 1;
@@ -86,5 +93,6 @@ static void cgit_print_repo_page(struct cacheitem *item)
cgit_print_summary();
} else if (!strcmp(cgit_query_page, "log")) {
- cgit_print_log(cgit_query_head, cgit_query_ofs, 100, cgit_query_search);
+ cgit_print_log(cgit_query_head, cgit_query_ofs, 100,
+ cgit_query_search);
} else if (!strcmp(cgit_query_page, "tree")) {
cgit_print_tree(cgit_query_sha1, cgit_query_path);
@@ -95,19 +103,37 @@ static void cgit_print_repo_page(struct cacheitem *item)
} else if (!strcmp(cgit_query_page, "diff")) {
cgit_print_diff(cgit_query_sha1, cgit_query_sha2);
+ } else {
+ cgit_print_error("Invalid request");
}
cgit_print_docend();
}
-static void cgit_fill_cache(struct cacheitem *item)
+static void cgit_fill_cache(struct cacheitem *item, int use_cache)
{
static char buf[PATH_MAX];
+ int stdout2;
getcwd(buf, sizeof(buf));
- htmlfd = item->fd;
item->st.st_mtime = time(NULL);
+
+ if (use_cache) {
+ stdout2 = chk_positive(dup(STDOUT_FILENO),
+ "Preserving STDOUT");
+ chk_zero(close(STDOUT_FILENO), "Closing STDOUT");
+ chk_positive(dup2(item->fd, STDOUT_FILENO), "Dup2(cachefile)");
+ }
+
if (cgit_query_repo)
cgit_print_repo_page(item);
else
cgit_print_repolist(item);
+
+ if (use_cache) {
+ chk_zero(close(STDOUT_FILENO), "Close redirected STDOUT");
+ chk_positive(dup2(stdout2, STDOUT_FILENO),
+ "Restoring original STDOUT");
+ chk_zero(close(stdout2), "Closing temporary STDOUT");
+ }
+
chdir(buf);
}
@@ -128,5 +154,5 @@ static void cgit_check_cache(struct cacheitem *item)
}
if (!cache_exist(item)) {
- cgit_fill_cache(item);
+ cgit_fill_cache(item, 1);
cache_unlock(item);
} else {
@@ -135,5 +161,5 @@ static void cgit_check_cache(struct cacheitem *item)
} else if (cache_expired(item) && cache_lock(item)) {
if (cache_expired(item)) {
- cgit_fill_cache(item);
+ cgit_fill_cache(item, 1);
cache_unlock(item);
} else {
@@ -210,6 +236,5 @@ int main(int argc, const char **argv)
return 0;
if (cgit_nocache) {
- item.fd = STDOUT_FILENO;
- cgit_fill_cache(&item);
+ cgit_fill_cache(&item, 0);
} else {
cgit_check_cache(&item);