a gopher interface forked from the popular cgit
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Lars Hjemli 8e495b075d
cgit 0.1
19 years ago
.gitignore
COPYING
Makefile cgit 0.1 19 years ago
README Remove implementation details from README 19 years ago
cache.c Allow relative paths for cgit_cache_root 19 years ago
cgit.c Add basic diff view 19 years ago
cgit.css Add basic diff view 19 years ago
cgit.h Add basic diff view 19 years ago
git.h Show list of modified files in ui-commit.c 19 years ago
html.c Show list of modified files in ui-commit.c 19 years ago
parsing.c Teach commit parser about author/committer email + timestamp 19 years ago
shared.c Add basic diff view 19 years ago
ui-commit.c Don't show new and old filemode for added/removed files 19 years ago
ui-diff.c Add basic diff view 19 years ago
ui-log.c Reformat code to avoid excessive line lengths 19 years ago
ui-repolist.c Move functions for repolist output into ui-repolist.c 19 years ago
ui-shared.c Make repo header a link to summary page 19 years ago
ui-summary.c Reformat code to avoid excessive line lengths 19 years ago
ui-tree.c Use html_filemode in ui-tree.c 19 years ago
ui-view.c Add ui-commit.c + misc ui cleanups 19 years ago
xdiff.h Add basic diff view 19 years ago

README


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