X-Git-Url: http://www.dolda2000.com/gitweb/?p=ashd.git;a=blobdiff_plain;f=python%2Fashd%2Fscgi.py;h=95325f215417e83c064cf94fa6be15589ceebb76;hp=4583fa73769e0ec6f94f5f71bf511e878d9d32d8;hb=8bb0e3c1a8831f79c263850d87c06195d85b9a0f;hpb=1b16086880096c31abd31fa2dae40e5b36789162 diff --git a/python/ashd/scgi.py b/python/ashd/scgi.py index 4583fa7..95325f2 100644 --- a/python/ashd/scgi.py +++ b/python/ashd/scgi.py @@ -84,16 +84,19 @@ def wrapwsgi(handler): raise Exception, "Trying to write data before starting response." status, headers = resp respsent[:] = [True] - sk.write("Status: %s\n" % status) - for nm, val in headers: - sk.write("%s: %s\n" % (nm, val)) - sk.write("\n") + try: + sk.write("Status: %s\n" % status) + for nm, val in headers: + sk.write("%s: %s\n" % (nm, val)) + sk.write("\n") + except IOError: + raise closed() def write(data): if not data: return + flushreq() try: - flushreq() sk.write(data) sk.flush() except IOError: @@ -114,10 +117,13 @@ def wrapwsgi(handler): respiter = handler(env, startreq) try: - for data in respiter: - write(data) - if resp: - flushreq() + try: + for data in respiter: + write(data) + if resp: + flushreq() + except closed: + pass finally: if hasattr(respiter, "close"): respiter.close()