X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=wrw%2Fdispatch.py;h=e51559e1fbe4b477a847af6bc1ea985a588393f2;hb=3614ca8353a5f2055fdcc086e6bc9dc993b49b42;hp=fe62df33c4f75c3321aaea0cf039e810155ad816;hpb=e8aa9ce29141768796b430fa8c6f95dce6e7a507;p=wrw.git diff --git a/wrw/dispatch.py b/wrw/dispatch.py index fe62df3..e51559e 100644 --- a/wrw/dispatch.py +++ b/wrw/dispatch.py @@ -1,3 +1,6 @@ +import sys, traceback +from . import env + __all__ = ["restart"] class restart(Exception): @@ -20,17 +23,17 @@ class iterproxy(object): self.bk = real self.bki = iter(real) self._next = [None] - self.next() + self.__next__() def __iter__(self): return self - def next(self): + def __next__(self): if self._next is None: raise StopIteration() ret = self._next[0] try: - self._next[:] = [self.bki.next()] + self._next[:] = [self.bki.__next__()] except StopIteration: self._next = None return ret @@ -39,15 +42,33 @@ class iterproxy(object): if hasattr(self.bk, "close"): self.bk.close() +def defaulterror(req, excinfo): + from . import resp + traceback.print_exception(*excinfo) + raise resp.httperror(500) + +def wraphandler(handler, excinfo): + def wrapped(req): + return handler(req, excinfo) + return wrapped + +errorhandler = env.var(defaulterror) + def handle(req, startreq, handler): + eh = errorhandler.val try: resp = [""] while True: try: resp = iterproxy(handler(req)) break - except restart, i: + except restart as i: handler = i.handle + except Exception as i: + if eh is None: + raise + handler = wraphandler(eh, sys.exc_info()) + eh = None req.commit(startreq) return resp finally: