diff options
| author | 2006-12-16 21:55:58 (JST) | |
|---|---|---|
| committer | 2006-12-16 21:55:58 (JST) | |
| commit | 7c849d94ec1cfecdec5a88d49f5af5c98f96ebca (patch) | |
| tree | 294acaa3368cba880dcc74aac8fb95e22156be21 | |
| parent | 61245ad18545ab09b22e9fcce5e49d5d36bf8176 (diff) | |
| download | cgit-7c849d94ec1cfecdec5a88d49f5af5c98f96ebca.zip cgit-7c849d94ec1cfecdec5a88d49f5af5c98f96ebca.tar.gz | |
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.c | 4 | ||||
| -rw-r--r-- | cgit.c | 4 |
2 files changed, 8 insertions, 0 deletions
| @@ -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 | ||
| @@ -42,12 +42,16 @@ static void cgit_print_repo_page(struct cacheitem *item) | |||
| 42 | 42 | ||
| 43 | static void cgit_fill_cache(struct cacheitem *item) | 43 | static 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 | ||
| 53 | static void cgit_check_cache(struct cacheitem *item) | 57 | static void cgit_check_cache(struct cacheitem *item) |
