mirror of
https://git.zx2c4.com/cgit
synced 2024-12-22 23:21:52 +00:00
A hyperfast web frontend for git repositories written in C.
521dc7a4bf
This adds support for the following options to cgit: --root=<path> --cache=<path> --nocache --query=<querystring> --repo=<reponame> --page=<pagename> --head=<branchname> --sha1=<sha1> --ofs=<number> On startup, /etc/cgitrc is parsed, followed by argument parsing and finally querystring parsing. If --nocache is specified (or set in /etc/gitrc), caching is disabled and cgit instead generates pages to stdout. The combined effect of these two changes makes testing/debugging a lot less painfull. Signed-off-by: Lars Hjemli <hjemli@gmail.com> |
||
---|---|---|
.gitignore | ||
cache.c | ||
cgit.c | ||
cgit.css | ||
cgit.h | ||
COPYING | ||
git.h | ||
html.c | ||
Makefile | ||
parsing.c | ||
README | ||
shared.c | ||
ui-commit.c | ||
ui-log.c | ||
ui-repolist.c | ||
ui-shared.c | ||
ui-summary.c | ||
ui-tree.c | ||
ui-view.c |
cgit - cgi for git This is an attempt to create a fast web interface for the git scm, using a frontside cache to decrease server io-pressure. When cgit is invoked, it looks for a cached page matching the request. If no such cachefile exist (or it has expired), it is (re)generated. Finally, the cachefile is returned to the client. If the cachefile has expired, but cgit is unable to lock the cachefile, the client will get the stale cachefile after all. This is done to favour page throughput over page freshness. Also, when a cachefile is generated, a few cache-related http-headers are created: "Modified" is set to current time(2), while "Expires" is set to time(2) + <cachefile TTL> * 60 (unless the TTL is negative, in which case it is read as "60 * 60 * 24 * 365"). This is done to avoid repeated requests for already visited pages. The following cache-related options can be set in /etc/cgitrc: cache-root=<path> root directory for cache files cache-root-ttl=<min> TTL for the repo listing page cache-repo-ttl=<min> TTL for repo summary pages cache-dynamic-ttl=<min> TTL for pages with symbolic references cache-static-ttl=<min> TTL for pages with sha1 references The cachefiles are split into different directories, based on the requested repository and page: Repo listing: <cachedir>/index.html Repo summary: <cachedir>/<repo>/index.html Repo subpage: <cachedir>/<repo>/<page>/<querystring>.html