X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/25105d7ecaba474d4b7c364ebb586aac3dfc5abb..318d106300102c19d114a4ea89265b0a4060d9cb:/cgit.c?ds=sidebyside diff --git a/cgit.c b/cgit.c index 09c857c..dc91125 100644 --- a/cgit.c +++ b/cgit.c @@ -1,13 +1,23 @@ +/* cgit.c: cgi for the git scm + * + * Copyright (C) 2006 Lars Hjemli + * + * Licensed under GNU General Public License v2 + * (see COPYING for full license text) + */ + #include "cgit.h" -static const char cgit_doctype[] = +const char cgit_version[] = CGIT_VERSION; + +const char cgit_doctype[] = "\n"; -static const char cgit_error[] = +const char cgit_error[] = "
%s
"; -static const char cgit_lib_error[] = +const char cgit_lib_error[] = "
%s: %s
"; int htmlfd = 0; @@ -21,6 +31,7 @@ char *cgit_virtual_root = NULL; char *cgit_cache_root = "/var/cache/cgit"; +int cgit_max_lock_attempts = 5; int cgit_cache_root_ttl = 5; int cgit_cache_repo_ttl = 5; int cgit_cache_dynamic_ttl = 5; @@ -192,6 +203,7 @@ static void cgit_print_docstart(char *title) html(""); html_txt(title); html("\n"); + htmlf("\n", cgit_version); html("\n"); @@ -454,20 +466,26 @@ static void cgit_fill_cache(struct cacheitem *item) static void cgit_refresh_cache(struct cacheitem *item) { + int i = 0; + + cache_prepare(item); top: - if (!cache_lookup(item)) { - if (cache_lock(item)) { - cgit_fill_cache(item); - cache_unlock(item); - } else { - sched_yield(); + if (++i > cgit_max_lock_attempts) { + die("cgit_refresh_cache: unable to lock %s: %s", + item->name, strerror(errno)); + } + if (!cache_exist(item)) { + if (!cache_lock(item)) { + sleep(1); goto top; } - } else if (cache_expired(item)) { - if (cache_lock(item)) { + if (!cache_exist(item)) cgit_fill_cache(item); - cache_unlock(item); - } + cache_unlock(item); + } else if (cache_expired(item) && cache_lock(item)) { + if (cache_expired(item)) + cgit_fill_cache(item); + cache_unlock(item); } }