mirror of
https://github.com/facebook/sapling.git
synced 2024-10-09 00:14:35 +03:00
4498f60ff4
First, it changes the server to be almost a generic WSGI server. Second, it changes request.py to have wsgiapplication and _wsgirequest. wsgiapplication is a class that creates _wsgirequests when called by a WSGI compliant server. It needs to know whether or not it should create hgwebdir or hgweb requests. Lastly, wsgicgi.py is added, and the CGI scripts are altered to use it to launch wsgiapplications in a WSGI compliant way. As a side effect, all the keepalive code has been removed from request.py. This code needs to be moved so that it is exclusively in server.py
36 lines
1.0 KiB
Python
36 lines
1.0 KiB
Python
#!/usr/bin/env python
|
|
#
|
|
# An example CGI script to export multiple hgweb repos, edit as necessary
|
|
|
|
import cgitb, sys
|
|
cgitb.enable()
|
|
|
|
# sys.path.insert(0, "/path/to/python/lib") # if not a system-wide install
|
|
from mercurial.hgweb.hgwebdir_mod import hgwebdir
|
|
from mercurial.hgweb.request import wsgiapplication
|
|
import mercurial.hgweb.wsgicgi as wsgicgi
|
|
|
|
# The config file looks like this. You can have paths to individual
|
|
# repos, collections of repos in a directory tree, or both.
|
|
#
|
|
# [paths]
|
|
# virtual/path = /real/path
|
|
# virtual/path = /real/path
|
|
#
|
|
# [collections]
|
|
# /prefix/to/strip/off = /root/of/tree/full/of/repos
|
|
#
|
|
# 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'
|
|
|
|
def make_web_app():
|
|
return hgwebdir("hgweb.config")
|
|
|
|
wsgicgi.launch(wsgiapplication(make_web_app))
|