def run(self): timestamp = time.time() # start time # to capture the console output of the application stdout, sys.stdout = sys.stdout, StringIO() try: # MS Windows: no special translation of end-of-lines if os.name == 'nt': import msvcrt msvcrt.setmode(sys.stdin.fileno(), os.O_BINARY) requestDict = dict( format='CGI', time=timestamp, # ce: a little tricky. We use marshal which only works # on built-in types, so we need environ's dictionary: environ=os.environ.data, input=sys.stdin) from WebKit import Profiler Profiler.startTime = time.time() print 'ONE SHOT MODE\n' from WebKit.OneShotAppServer import OneShotAppServer appSvr = OneShotAppServer(self._webKitDir) # It is important to call transaction.die() after using it, rather than # just letting it fall out of scope, to avoid circular references from WebKit.ASStreamOut import ASStreamOut rs = ASStreamOut() transaction = appSvr.dispatchRawRequest(requestDict, rs) rs.close() if transaction: transaction.die() del transaction appSvr.shutDown() appSvr = None print "AppServer run time %.2f seconds" % (time.time() - Profiler.startTime) sys.stdout = stdout # MS Windows: no special translation of end-of-lines if os.name == 'nt': import msvcrt msvcrt.setmode(sys.stdout.fileno(), os.O_BINARY) response = rs._buffer if response: sys.stdout.write(response) else: sys.stdout.write('''Content-Type: text/html\n <html><head><title>WebKit CGI Error</title><body> <h3>WebKit CGI Error</h3> <h4>No response from application server</h4> </body></html>\n''') if self.setting('ShowConsole'): # show the contents of the console, # but only if we are serving up an HTML file endheaders = response.find("\r\n\r\n") if endheaders < 0: endheaders = response.find("\n\n") if not endheaders: print "No Headers Found" return headers = response[:endheaders].split("\n") entries = [] for header in headers: if header: entries.append(header.split(":", 1)) found = False for name, value in entries: if name.lower() == 'content-type': found = True break if found and value.strip().lower() == 'text/html': self.showConsole(_console.getvalue()) except: import traceback sys.stderr.write('[%s] [error] WebKit.OneShotAdapter:' ' Error while responding to request (unknown)\n' % (time.asctime(time.localtime(time.time())))) sys.stderr.write('Python exception:\n') traceback.print_exc(file=sys.stderr) sys.stdout = stdout output = ''.join(traceback.format_exception(*sys.exc_info())) output = htmlEncode(output) sys.stdout.write('''Content-Type: text/html\n <html><head><title>WebKit CGI Error</title><body> <h3>WebKit CGI Error</h3> <pre>%s</pre> </body></html>\n''' % output)