X-Git-Url: http://www.dolda2000.com/gitweb/?a=blobdiff_plain;f=python%2Fashd%2Fwsgidir.py;h=5ce7638f11b3e029839f7ebcb80c6cd081c87c9c;hb=48a91dd9f3bce22911839aa678ebe9a6bafab5fc;hp=e5dee720b22671964534c15a72bd875863967b3b;hpb=adb11d5f566968a0a12fcd225b5748bce09e0014;p=ashd.git diff --git a/python/ashd/wsgidir.py b/python/ashd/wsgidir.py index e5dee72..5ce7638 100644 --- a/python/ashd/wsgidir.py +++ b/python/ashd/wsgidir.py @@ -65,6 +65,13 @@ def chain(path, env, startreq): return wsgiutil.simpleerror(env, startreq, 500, "Internal Error", "Invalid WSGI handler.") exts["wsgi"] = chain +def addext(ext, handler): + p = handler.rindex('.') + mname = handler[:p] + hname = handler[p + 1:] + mod = __import__(mname, fromlist = ["dummy"]) + exts[ext] = getattr(mod, hname) + def application(env, startreq): if not "SCRIPT_FILENAME" in env: return wsgiutil.simpleerror(env, startreq, 500, "Internal Error", "The server is erroneously configured.") @@ -79,4 +86,8 @@ def application(env, startreq): return(exts[ext](path, env, startreq)) def wmain(*argv): + for arg in argv: + if arg[0] == '.': + p = arg.index('=') + addext(arg[1:p], arg[p + 1:]) return application