##// END OF EJS Templates
help: better explanation for some of the environment variables...
help: better explanation for some of the environment variables In particular, the precedence for usernames is explained in more detail. Thanks to timeless for pointing out the deficiencies here.

File last commit:

r7799:43edbd8c default
r7805:cf6ec23a default
Show More
hgwebdir.fcgi
62 lines | 2.0 KiB | text/plain | TextLexer
Michael Gebetsroither
Add hgwebdir.fcgi to contrib
r4391 #!/usr/bin/env python
#
# An example CGI script to export multiple hgweb repos, edit as necessary
Benoit Boissinot
cgi: sys.path.insert should be before importing mercurial...
r5244 # adjust python path if not a system-wide install:
#import sys
#sys.path.insert(0, "/path/to/python/lib")
Thomas Arendsen Hein
Enable demandimport only in scripts, not in importable modules (issue605)...
r5197 # enable demandloading to reduce startup time
from mercurial import demandimport; demandimport.enable()
Maxim Dounin
hgweb: disable cgitb by default in hgwebdir.fcgi too
r6085 # Uncomment to send python tracebacks to the browser if an error occurs:
#import cgitb
#cgitb.enable()
Michael Gebetsroither
Add hgwebdir.fcgi to contrib
r4391
# If you'd like to serve pages with UTF-8 instead of your default
# locale charset, you can do so by uncommenting the following lines.
# Note that this will cause your .hgrc files to be interpreted in
# UTF-8 and all your repo files to be displayed using UTF-8.
#
#import os
#os.environ["HGENCODING"] = "UTF-8"
from mercurial.hgweb.hgwebdir_mod import hgwebdir
from flup.server.fcgi import WSGIServer
# The config file looks like this. You can have paths to individual
# repos, collections of repos in a directory tree, or both.
#
# [paths]
Patrick Mezard
hgweb: extend [paths] syntax to match repositories recursively (issue852)...
r7450 # virtual/path1 = /real/path1
# virtual/path2 = /real/path2
# virtual/root = /real/root/*
# / = /real/root2/*
Michael Gebetsroither
Add hgwebdir.fcgi to contrib
r4391 #
# [collections]
# /prefix/to/strip/off = /root/of/tree/full/of/repos
#
Patrick Mezard
hgweb: extend [paths] syntax to match repositories recursively (issue852)...
r7450 # paths example:
#
# * First two lines mount one repository into one virtual path, like
# '/real/path1' into 'virtual/path1'.
#
# * The third entry tells every mercurial repository found in
# '/real/root', recursively, should be mounted in 'virtual/root'. This
# format is preferred over the [collections] one, using absolute paths
# as configuration keys is not supported on every platform (including
# Windows).
#
# * The last entry is a special case mounting all repositories in
# '/real/root2' in the root of the virtual directory.
#
Michael Gebetsroither
Add hgwebdir.fcgi to contrib
r4391 # collections example: say directory tree /foo contains repos /foo/bar,
# /foo/quux/baz. Give this config section:
# [collections]
# /foo = /foo
# Then repos will list as bar and quux/baz.
#
# Alternatively you can pass a list of ('virtual/path', '/real/path') tuples
# or use a dictionary with entries like 'virtual/path': '/real/path'
Dirkjan Ochtman
contrib: bring hgwebdir.fcgi up-to-date with current WSGI practices
r7799 WSGIServer(hgwebdir('hgweb.config')).run()