Fork of stagit that updates some of the html to a more modern, accessible, and editable style and includes a default stylesheet.
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
sloum 0069d98672 Adds in missing semicolons 3 years ago
LICENSE Sloum's templating edits 3 years ago
Makefile Makefile improvements 4 years ago
README Sloum's templating edits 3 years ago
compat.h Always use the compat functions 8 years ago fix issues in example scripts 4 years ago fix issues in example scripts 4 years ago
favicon.png add favicon 8 years ago
logo.png initial insertion 8 years ago
reallocarray.c Bring in reallocarray() from OpenBSD 8 years ago
stagit-index.1 improve documentation 6 years ago
stagit-index.c Further updates to styles 3 years ago
stagit.1 change order of commits in log from most recent to old to applied order 4 years ago
stagit.c Adds in missing semicolons 3 years ago
strlcat.c Bring in reallocarray() from OpenBSD 8 years ago
strlcpy.c Bring in reallocarray() from OpenBSD 8 years ago
style.css Fixes style issue with wrapping 3 years ago


Notes from Sloum for this version:

This is my fork of stagit. It is pretty similar to the 
original but features changes to the html templating and
adds a default css stylesheet. These changes should 
result in a more modern, accessible, and styleable repo.
What follows is the origin stagit readme, as none of my
changes should affect opperation.

- sloum



static git page generator.

It generates static HTML pages for a git repository.


Make files per repository:

	$ mkdir -p htmldir && cd htmldir
	$ stagit path-to-repo

Make index file for repositories:

	$ stagit-index repodir1 repodir2 repodir3 > index.html

Build and install

$ make
# make install


- C compiler (C99).
- libc (tested with OpenBSD, FreeBSD, NetBSD, Linux: glibc and musl).
- libgit2 (v0.22+).
- POSIX make (optional).


See man pages: stagit(1) and stagit-index(1).

Building a static binary

It may be useful to build static binaries, for example to run in a chroot.

It can be done like this at the time of writing (v0.24):

cd libgit2-src

# change the options in the CMake file: CMakeLists.txt
CURL to OFF              (not needed)
USE_SSH OFF              (not needed)
THREADSAFE OFF           (not needed)
USE_OPENSSL OFF          (not needed, use builtin)

mkdir -p build && cd build
cmake ../
make install

Extract owner field from git config

A way to extract the gitweb owner for example in the format:

		owner = Name here


	awk '/^[ 	]*owner[ 	]=/ {
		sub(/^[^=]*=[ 	]*/, "");
		print $0;

Set clone url for a directory of repos
	cd "$dir"
	for i in *; do
		test -d "$i" && echo "git://$i" > "$i/url"

Update files on git push

Using a post-receive hook the static files can be automatically updated.
Keep in mind git push -f can change the history and the commits may need
to be recreated. This is because stagit checks if a commit file already
exists. It also has a cache (-c) option which can conflict with the new
history. See stagit(1).

git post-receive hook (repo/.git/hooks/post-receive):

	# detect git push -f
	while read -r old new ref; do
		hasrevs=$(git rev-list "$old" "^$new" | sed 1q)
		if test -n "$hasrevs"; then

	# remove commits and .cache on git push -f
	#if test "$force" = "1"; then
	# ...

	# see for normal creation of the files.

Create .tar.gz archives by tag
	mkdir -p archives
	git tag -l | while read -r t; do
		f="archives/${name}-$(echo "${t}" | tr '/' '_').tar.gz"
		test -f "${f}" && continue
		git archive \
			--format tar.gz \
			--prefix "${t}/" \
			-o "${f}" \
			-- \


- Log of all commits from HEAD.
- Log and diffstat per commit.
- Show file tree with linkable line numbers.
- Show references: local branches and tags.
- Detect README and LICENSE file from HEAD and link it as a webpage.
- Detect submodules (.gitmodules file) from HEAD and link it as a webpage.
- Atom feed log (atom.xml).
- Make index page for multiple repositories with stagit-index.
- After generating the pages (relatively slow) serving the files is very fast,
  simple and requires little resources (because the content is static), only
  a HTTP file server is required.
- Usable with text-browsers such as dillo, links, lynx and w3m.


- Not suitable for large repositories (2000+ commits), because diffstats are
  an expensive operation, the cache (-c flag) is a workaround for this in
  some cases.
- Not suitable for large repositories with many files, because all files are
  written for each execution of stagit. This is because stagit shows the lines
  of textfiles and there is no "cache" for file metadata (this would add more
  complexity to the code).
- Not suitable for repositories with many branches, a quite linear history is
  assumed (from HEAD).

  In these cases it is better to just use cgit or possibly change stagit to
  run as a CGI program.

- Relatively slow to run the first time (about 3 seconds for sbase,
  1500+ commits), incremental updates are faster.
- Does not support some of the dynamic features cgit has, like:
  - Snapshot tarballs per commit.
  - File tree per commit.
  - History log of branches diverged from HEAD.
  - Stats (git shortlog -s).

  This is by design, just use git locally.