about summary refs log tree commit diff
diff options
context:
space:
mode:
authorLars Hjemli <hjemli@gmail.com>2006-12-16 13:55:58 +0100
committerLars Hjemli <hjemli@gmail.com>2006-12-16 13:55:58 +0100
commit7c849d94ec1cfecdec5a88d49f5af5c98f96ebca (patch)
tree294acaa3368cba880dcc74aac8fb95e22156be21
parentAdd cache-root option to /cgit/rc (diff)
downloadcgit-pink-7c849d94ec1cfecdec5a88d49f5af5c98f96ebca.tar.gz
cgit-pink-7c849d94ec1cfecdec5a88d49f5af5c98f96ebca.zip
Allow relative paths for cgit_cache_root
Make sure we chdir(2) back to the original getcwd(2) when a page
has been generated. Also, if the cgit_cache_root do not exist,
try to create it.

This is a feature intended to ease testing/debugging.

Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r--cache.c4
-rw-r--r--cgit.c4
2 files changed, 8 insertions, 0 deletions
diff --git a/cache.c b/cache.c
index 39e63a5..91b89a6 100644
--- a/cache.c
+++ b/cache.c
@@ -45,6 +45,10 @@ int cache_create_dirs()
 {
 	char *path;
 
+	path = fmt("%s", cgit_cache_root);
+	if (mkdir(path, S_IRWXU) && errno!=EEXIST)
+		return 0;
+
 	if (!cgit_query_repo)
 		return 0;
 
diff --git a/cgit.c b/cgit.c
index 9dbc608..372b436 100644
--- a/cgit.c
+++ b/cgit.c
@@ -42,12 +42,16 @@ static void cgit_print_repo_page(struct cacheitem *item)
 
 static void cgit_fill_cache(struct cacheitem *item)
 {
+	static char buf[PATH_MAX];
+
+	getcwd(buf, sizeof(buf));
 	htmlfd = item->fd;
 	item->st.st_mtime = time(NULL);
 	if (cgit_query_repo)
 		cgit_print_repo_page(item);
 	else
 		cgit_print_repolist(item);
+	chdir(buf);
 }
 
 static void cgit_check_cache(struct cacheitem *item)