Unidiff1 files changed, 10 insertions, 4 deletions
|
diff --git a/cgit.c b/cgit.c index d1abaa0..0f72f2d 100644 --- a/ cgit.c+++ b/ cgit.c |
|
@@ -56,23 +56,29 @@ static void cgit_check_cache(struct cacheitem *item) |
56 | die("cgit_refresh_cache: unable to lock %s: %s", |
56 | die("cgit_refresh_cache: unable to lock %s: %s", |
57 | item->name, strerror(errno)); |
57 | item->name, strerror(errno)); |
58 | } |
58 | } |
59 | if (!cache_exist(item)) { |
59 | if (!cache_exist(item)) { |
60 | if (!cache_lock(item)) { |
60 | if (!cache_lock(item)) { |
61 | sleep(1); |
61 | sleep(1); |
62 | goto top; |
62 | goto top; |
63 | } |
63 | } |
64 | if (!cache_exist(item)) |
64 | if (!cache_exist(item)) { |
65 | cgit_fill_cache(item); |
65 | cgit_fill_cache(item); |
66 | cache_unlock(item); |
66 | cache_unlock(item); |
| |
67 | } else { |
| |
68 | cache_cancel_lock(item); |
| |
69 | } |
67 | } else if (cache_expired(item) && cache_lock(item)) { |
70 | } else if (cache_expired(item) && cache_lock(item)) { |
68 | if (cache_expired(item)) |
71 | if (cache_expired(item)) { |
69 | cgit_fill_cache(item); |
72 | cgit_fill_cache(item); |
70 | cache_unlock(item); |
73 | cache_unlock(item); |
| |
74 | } else { |
| |
75 | cache_cancel_lock(item); |
| |
76 | } |
71 | } |
77 | } |
72 | } |
78 | } |
73 | |
79 | |
74 | static void cgit_print_cache(struct cacheitem *item) |
80 | static void cgit_print_cache(struct cacheitem *item) |
75 | { |
81 | { |
76 | static char buf[4096]; |
82 | static char buf[4096]; |
77 | ssize_t i; |
83 | ssize_t i; |
78 | |
84 | |
|