Skip to content
Snippets Groups Projects
Commit 6d43b55a authored by Mike Bayer's avatar Mike Bayer
Browse files

Merged in CodeMan99/mako (pull request #11)

Make run_wsgi.py python3 compliant & correct encoding problems
parents 756e7da0 b9072319
No related branches found
No related tags found
No related merge requests found
#!/usr/bin/python
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
import cgi, re, os, posixpath, mimetypes
from mako.lookup import TemplateLookup
from mako import exceptions
root = './'
port = 8000
error_style = 'html' # select 'text' for plaintext error reporting
lookup = TemplateLookup(directories=[root + 'templates', root + 'htdocs'], filesystem_checks=True, module_directory='./modules')
lookup = TemplateLookup(
directories=[root + 'templates', root + 'htdocs'],
filesystem_checks=True,
module_directory='./modules',
# even better would be to use 'charset' in start_response
output_encoding='ascii',
ending_errors='replace'
)
def serve(environ, start_response):
"""serves requests using the WSGI callable interface."""
......@@ -28,23 +39,25 @@ def serve(environ, start_response):
if re.match(r'.*\.html$', uri):
try:
template = lookup.get_template(uri)
start_response("200 OK", [('Content-type','text/html')])
return [template.render(**d)]
except exceptions.TopLevelLookupException:
start_response("404 Not Found", [])
return ["Cant find template '%s'" % uri]
return [str.encode("Cant find template '%s'" % uri)]
start_response("200 OK", [('Content-type','text/html')])
try:
return [template.render(**d)]
except:
if error_style == 'text':
start_response("200 OK", [('Content-type','text/plain')])
return [exceptions.text_error_template().render()]
else:
start_response("200 OK", [('Content-type','text/html')])
return [exceptions.html_error_template().render()]
return [exceptions.html_error_template().render()]
else:
u = re.sub(r'^\/+', '', uri)
filename = os.path.join(root, u)
start_response("200 OK", [('Content-type',guess_type(uri))])
return [file(filename).read()]
if os.path.isfile(filename):
start_response("200 OK", [('Content-type',guess_type(uri))])
return [open(filename, 'rb').read()]
else:
start_response("404 Not Found", [])
return [str.encode("File not found: '%s'" % filename)]
def getfield(f):
"""convert values from cgi.Field objects to plain values."""
......@@ -54,9 +67,6 @@ def getfield(f):
return f.value
extensions_map = mimetypes.types_map.copy()
extensions_map.update({
'': 'text/html', # Default
})
def guess_type(path):
"""return a mimetype for the given path based on file extension."""
......@@ -67,12 +77,10 @@ def guess_type(path):
if ext in extensions_map:
return extensions_map[ext]
else:
return extensions_map['']
return 'text/html'
if __name__ == '__main__':
import wsgiref.simple_server
server = wsgiref.simple_server.make_server('', port, serve)
print "Server listening on port %d" % port
print("Server listening on port %d" % port)
server.serve_forever()
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment