summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2006-12-16 12:55:58 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2006-12-16 12:55:58 (UTC)
commit7c849d94ec1cfecdec5a88d49f5af5c98f96ebca (patch) (unidiff)
tree294acaa3368cba880dcc74aac8fb95e22156be21
parent61245ad18545ab09b22e9fcce5e49d5d36bf8176 (diff)
downloadcgit-7c849d94ec1cfecdec5a88d49f5af5c98f96ebca.zip
cgit-7c849d94ec1cfecdec5a88d49f5af5c98f96ebca.tar.gz
cgit-7c849d94ec1cfecdec5a88d49f5af5c98f96ebca.tar.bz2
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>
Diffstat (more/less context) (ignore whitespace changes)
-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()
45{ 45{
46 char *path; 46 char *path;
47 47
48 path = fmt("%s", cgit_cache_root);
49 if (mkdir(path, S_IRWXU) && errno!=EEXIST)
50 return 0;
51
48 if (!cgit_query_repo) 52 if (!cgit_query_repo)
49 return 0; 53 return 0;
50 54
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)
42 42
43static void cgit_fill_cache(struct cacheitem *item) 43static void cgit_fill_cache(struct cacheitem *item)
44{ 44{
45 static char buf[PATH_MAX];
46
47 getcwd(buf, sizeof(buf));
45 htmlfd = item->fd; 48 htmlfd = item->fd;
46 item->st.st_mtime = time(NULL); 49 item->st.st_mtime = time(NULL);
47 if (cgit_query_repo) 50 if (cgit_query_repo)
48 cgit_print_repo_page(item); 51 cgit_print_repo_page(item);
49 else 52 else
50 cgit_print_repolist(item); 53 cgit_print_repolist(item);
54 chdir(buf);
51} 55}
52 56
53static void cgit_check_cache(struct cacheitem *item) 57static void cgit_check_cache(struct cacheitem *item)