Unidiff3 files changed, 16 insertions, 4 deletions
|
diff --git a/cache.c b/cache.c index 2e1ef8c..b947a34 100644 --- a/ cache.c+++ b/ cache.c |
|
@@ -100,4 +100,9 @@ int cache_unlock(struct cacheitem *item) |
100 | } |
100 | } |
101 | |
101 | |
| |
102 | int cache_cancel_lock(struct cacheitem *item) |
| |
103 | { |
| |
104 | return (unlink(fmt("%s.lock", item->name)) == 0); |
| |
105 | } |
| |
106 | |
102 | int cache_expired(struct cacheitem *item) |
107 | int cache_expired(struct cacheitem *item) |
103 | { |
108 | { |
|
|
diff --git a/cgit.c b/cgit.c index d1abaa0..0f72f2d 100644 --- a/ cgit.c+++ b/ cgit.c |
|
@@ -62,11 +62,17 @@ static void cgit_check_cache(struct cacheitem *item) |
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 | } |
|
|
diff --git a/cgit.h b/cgit.h index c1dcc97..c9554a7 100644 --- a/ cgit.h+++ b/ cgit.h |
|
@@ -67,4 +67,5 @@ extern void cache_prepare(struct cacheitem *item); |
67 | extern int cache_lock(struct cacheitem *item); |
67 | extern int cache_lock(struct cacheitem *item); |
68 | extern int cache_unlock(struct cacheitem *item); |
68 | extern int cache_unlock(struct cacheitem *item); |
| |
69 | extern int cache_cancel_lock(struct cacheitem *item); |
69 | extern int cache_exist(struct cacheitem *item); |
70 | extern int cache_exist(struct cacheitem *item); |
70 | extern int cache_expired(struct cacheitem *item); |
71 | extern int cache_expired(struct cacheitem *item); |
|