author | Lars Hjemli <hjemli@gmail.com> | 2006-12-11 21:53:50 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2006-12-11 21:53:50 (UTC) |
commit | fbaf1171b4e343929dd43ecac7cd9d1c692b84ec (patch) (unidiff) | |
tree | 40b7007b2e1e85f2e91e052b33555df2e9fb5e14 /cgit.h | |
parent | 44923f8953c66dc9b852316b655ab3b5aec9478e (diff) | |
download | cgit-fbaf1171b4e343929dd43ecac7cd9d1c692b84ec.zip cgit-fbaf1171b4e343929dd43ecac7cd9d1c692b84ec.tar.gz cgit-fbaf1171b4e343929dd43ecac7cd9d1c692b84ec.tar.bz2 |
Don't truncate valid cachefiles
An embarrassing thinko in cgit_check_cache() would truncate valid cachefiles
in the following situation:
1) process A notices a missing/expired cachefile
2) process B gets scheduled, locks, fills and unlocks the cachefile
3) process A gets scheduled, locks the cachefile, notices that the cachefile
now exist/is not expired anymore, and continues to overwrite it with an
empty lockfile.
Thanks to Linus for noticing (again).
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | cgit.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -21,66 +21,67 @@ extern char *cgit_root; | |||
21 | extern char *cgit_root_title; | 21 | extern char *cgit_root_title; |
22 | extern char *cgit_css; | 22 | extern char *cgit_css; |
23 | extern char *cgit_logo; | 23 | extern char *cgit_logo; |
24 | extern char *cgit_logo_link; | 24 | extern char *cgit_logo_link; |
25 | extern char *cgit_virtual_root; | 25 | extern char *cgit_virtual_root; |
26 | extern char *cgit_cache_root; | 26 | extern char *cgit_cache_root; |
27 | 27 | ||
28 | extern int cgit_max_lock_attempts; | 28 | extern int cgit_max_lock_attempts; |
29 | extern int cgit_cache_root_ttl; | 29 | extern int cgit_cache_root_ttl; |
30 | extern int cgit_cache_repo_ttl; | 30 | extern int cgit_cache_repo_ttl; |
31 | extern int cgit_cache_dynamic_ttl; | 31 | extern int cgit_cache_dynamic_ttl; |
32 | extern int cgit_cache_static_ttl; | 32 | extern int cgit_cache_static_ttl; |
33 | extern int cgit_cache_max_create_time; | 33 | extern int cgit_cache_max_create_time; |
34 | 34 | ||
35 | extern char *cgit_repo_name; | 35 | extern char *cgit_repo_name; |
36 | extern char *cgit_repo_desc; | 36 | extern char *cgit_repo_desc; |
37 | extern char *cgit_repo_owner; | 37 | extern char *cgit_repo_owner; |
38 | 38 | ||
39 | extern int cgit_query_has_symref; | 39 | extern int cgit_query_has_symref; |
40 | extern int cgit_query_has_sha1; | 40 | extern int cgit_query_has_sha1; |
41 | 41 | ||
42 | extern char *cgit_querystring; | 42 | extern char *cgit_querystring; |
43 | extern char *cgit_query_repo; | 43 | extern char *cgit_query_repo; |
44 | extern char *cgit_query_page; | 44 | extern char *cgit_query_page; |
45 | extern char *cgit_query_head; | 45 | extern char *cgit_query_head; |
46 | extern char *cgit_query_sha1; | 46 | extern char *cgit_query_sha1; |
47 | 47 | ||
48 | extern int htmlfd; | 48 | extern int htmlfd; |
49 | 49 | ||
50 | extern void cgit_global_config_cb(const char *name, const char *value); | 50 | extern void cgit_global_config_cb(const char *name, const char *value); |
51 | extern void cgit_repo_config_cb(const char *name, const char *value); | 51 | extern void cgit_repo_config_cb(const char *name, const char *value); |
52 | extern void cgit_querystring_cb(const char *name, const char *value); | 52 | extern void cgit_querystring_cb(const char *name, const char *value); |
53 | 53 | ||
54 | extern char *fmt(const char *format,...); | 54 | extern char *fmt(const char *format,...); |
55 | 55 | ||
56 | extern void html(const char *txt); | 56 | extern void html(const char *txt); |
57 | extern void htmlf(const char *format,...); | 57 | extern void htmlf(const char *format,...); |
58 | extern void html_txt(char *txt); | 58 | extern void html_txt(char *txt); |
59 | extern void html_attr(char *txt); | 59 | extern void html_attr(char *txt); |
60 | extern void html_link_open(char *url, char *title, char *class); | 60 | extern void html_link_open(char *url, char *title, char *class); |
61 | extern void html_link_close(void); | 61 | extern void html_link_close(void); |
62 | 62 | ||
63 | extern int cgit_read_config(const char *filename, configfn fn); | 63 | extern int cgit_read_config(const char *filename, configfn fn); |
64 | extern int cgit_parse_query(char *txt, configfn fn); | 64 | extern int cgit_parse_query(char *txt, configfn fn); |
65 | 65 | ||
66 | extern void cache_prepare(struct cacheitem *item); | 66 | 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); |
71 | 72 | ||
72 | extern char *cgit_repourl(const char *reponame); | 73 | extern char *cgit_repourl(const char *reponame); |
73 | extern char *cgit_pageurl(const char *reponame, const char *pagename, | 74 | extern char *cgit_pageurl(const char *reponame, const char *pagename, |
74 | const char *query); | 75 | const char *query); |
75 | 76 | ||
76 | extern void cgit_print_error(char *msg); | 77 | extern void cgit_print_error(char *msg); |
77 | extern void cgit_print_docstart(char *title, struct cacheitem *item); | 78 | extern void cgit_print_docstart(char *title, struct cacheitem *item); |
78 | extern void cgit_print_docend(); | 79 | extern void cgit_print_docend(); |
79 | extern void cgit_print_pageheader(char *title); | 80 | extern void cgit_print_pageheader(char *title); |
80 | 81 | ||
81 | extern void cgit_print_repolist(struct cacheitem *item); | 82 | extern void cgit_print_repolist(struct cacheitem *item); |
82 | extern void cgit_print_summary(); | 83 | extern void cgit_print_summary(); |
83 | extern void cgit_print_log(const char *tip, int ofs, int cnt); | 84 | extern void cgit_print_log(const char *tip, int ofs, int cnt); |
84 | extern void cgit_print_view(char *hex); | 85 | extern void cgit_print_view(char *hex); |
85 | 86 | ||
86 | #endif /* CGIT_H */ | 87 | #endif /* CGIT_H */ |