summaryrefslogtreecommitdiff
path: root/git
diff options
context:
space:
mode:
authorLars Hjemli <hjemli@gmail.com>2010-08-03 22:50:02 +0200
committerLars Hjemli <hjemli@gmail.com>2010-08-03 22:50:02 +0200
commit15c64c5e474bfaa7fd68c588a13d20deefe1c59d (patch)
treeba0f1ec3bf955ecabbd757da7c5134eb1337b442 /git
parent3687be20bc4abf0c0c197d617afaa3a717b1ab9c (diff)
downloadcgit-15c64c5e474bfaa7fd68c588a13d20deefe1c59d.tar.gz
cgit-15c64c5e474bfaa7fd68c588a13d20deefe1c59d.tar.bz2
cgit-15c64c5e474bfaa7fd68c588a13d20deefe1c59d.zip
CGIT 0.8.3.3v0.8.3.3
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (limited to '')
0 files changed, 0 insertions, 0 deletions
span title='2006-12-10 22:41:14 +0100'>2006-12-10Add license file and copyright noticesLars Hjemli5-0/+372 Signed-off-by: Lars Hjemli <hjemli@gmail.com> 2006-12-10Add caching infrastructureLars Hjemli9-28/+353 This enables internal caching of page output. Page requests are split into four groups: 1) repo listing (front page) 2) repo summary 3) repo pages w/symbolic references in query string 4) repo pages w/constant sha1's in query string Each group has a TTL specified in minutes. When a page is requested, a cached filename is stat(2)'ed and st_mtime is compared to time(2). If TTL has expired (or the file didn't exist), the cached file is regenerated. When generating a cached file, locking is used to avoid parallell processing of the request. If multiple processes tries to aquire the same lock, the ones who fail to get the lock serves the (expired) cached file. If the cached file don't exist, the process instead calls sched_yield(2) before restarting the request processing. Signed-off-by: Lars Hjemli <hjemli@gmail.com>