Unidiff1 files changed, 8 insertions, 1 deletions
|
diff --git a/cgit.c b/cgit.c index 7f14016..dc91125 100644 --- a/ cgit.c+++ b/ cgit.c |
|
@@ -31,6 +31,7 @@ char *cgit_virtual_root = NULL; |
31 | |
31 | |
32 | char *cgit_cache_root = "/var/cache/cgit"; |
32 | char *cgit_cache_root = "/var/cache/cgit"; |
33 | |
33 | |
| |
34 | int cgit_max_lock_attempts = 5; |
34 | int cgit_cache_root_ttl = 5; |
35 | int cgit_cache_root_ttl = 5; |
35 | int cgit_cache_repo_ttl = 5; |
36 | int cgit_cache_repo_ttl = 5; |
36 | int cgit_cache_dynamic_ttl = 5; |
37 | int cgit_cache_dynamic_ttl = 5; |
@@ -465,11 +466,17 @@ static void cgit_fill_cache(struct cacheitem *item) |
465 | |
466 | |
466 | static void cgit_refresh_cache(struct cacheitem *item) |
467 | static void cgit_refresh_cache(struct cacheitem *item) |
467 | { |
468 | { |
| |
469 | int i = 0; |
| |
470 | |
468 | cache_prepare(item); |
471 | cache_prepare(item); |
469 | top: |
472 | top: |
| |
473 | if (++i > cgit_max_lock_attempts) { |
| |
474 | die("cgit_refresh_cache: unable to lock %s: %s", |
| |
475 | item->name, strerror(errno)); |
| |
476 | } |
470 | if (!cache_exist(item)) { |
477 | if (!cache_exist(item)) { |
471 | if (!cache_lock(item)) { |
478 | if (!cache_lock(item)) { |
472 | sched_yield(); |
479 | sleep(1); |
473 | goto top; |
480 | goto top; |
474 | } |
481 | } |
475 | if (!cache_exist(item)) |
482 | if (!cache_exist(item)) |
|