X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=wrw%2Fresp.py;h=9ad22d1126e2fb4af2852fb50b985c0533d07f4a;hb=ef04ec8791734c918a5b8940976bf3fde3618710;hp=8216d23502d9386b674bb304e36729442b6cf99a;hpb=a4811d704ac8b4d97ae9af3841823ad2b56c4380;p=wrw.git diff --git a/wrw/resp.py b/wrw/resp.py index 8216d23..9ad22d1 100644 --- a/wrw/resp.py +++ b/wrw/resp.py @@ -1,66 +1,56 @@ -import dispatch, proto +import dispatch, proto, env +from sp import xhtml +h = xhtml.cons() __all__ = ["skeleton", "skelfor", "setskel", "usererror"] class skeleton(object): - def page(self, title, content): - return """ - - - -%s - - -%s - -""" % (self.head(title), content) + def page(self, title, *content): + return h.html(self.head(title), h.body(*content)) def head(self, title): - return """%s\n%s""" % (title, self.style()) + return xhtml.head(title=title) - def style(self): - return "" + def error(self, message, *detail): + return self.page(message, h.h1(message), h.p(*detail)) - def error(self, message, detail): - return self.page(message, """

%s

\n

%s

\n""" % (message, detail)) + def message(self, message, *detail): + return self.page(message, h.h1(message), h.p(*detail)) - def message(self, message, detail): - return self.page(message, """

%s

\n

%s

\n""" % (message, detail)) - -defskel = skeleton() +defskel = env.var(skeleton()) def getskel(req): - return [defskel] + return [defskel.val] def skelfor(req): return req.item(getskel)[0] def setskel(req, skel): req.item(getskel)[0] = skel class usererror(dispatch.restart): - def __init__(self, message, detail): + def __init__(self, message, *detail): super(usererror, self).__init__() self.message = message self.detail = detail def handle(self, req): - return [skelfor(req).error(self.message, self.detail)] + return xhtml.forreq(req, skelfor(req).error(self.message, *self.detail)) class message(dispatch.restart): - def __init__(self, message, detail): + def __init__(self, msg, *detail): super(message, self).__init__() - self.message = message + self.message = msg self.detail = detail def handle(self, req): - return [skelfor(req).message(self.message, self.detail)] + return xhtml.forreq(req, skelfor(req).error(self.message, *self.detail)) class httperror(usererror): def __init__(self, status, message = None, detail = None): if message is None: message = proto.statusinfo[status][0] if detail is None: - detail = proto.statusinfo[status][1] - super(httperror, self).__init__(message, detail) + detail = (proto.statusinfo[status][1],) + super(httperror, self).__init__(message, *detail) self.status = status def handle(self, req):