aboutsummaryrefslogtreecommitdiff
path: root/tools/scan-view/ScanView.py
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2008-09-21 20:34:58 +0000
committerDaniel Dunbar <daniel@zuster.org>2008-09-21 20:34:58 +0000
commitcb028b0180b38c7d0404acb936d276ff050061c6 (patch)
treebabd85d3c7fe3d90ec287e2637fe1a6f5da89563 /tools/scan-view/ScanView.py
parent12a467ff0bc216240c2fcb5a325ef2326b41a0ed (diff)
scan-view tweaks:
- Update for scan-build table change. - Add --auto-reload option (for development, avoids need to restart server). - Always send Last-Modified, with a reasonable value for dynamic content. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56409 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/scan-view/ScanView.py')
-rw-r--r--tools/scan-view/ScanView.py22
1 files changed, 18 insertions, 4 deletions
diff --git a/tools/scan-view/ScanView.py b/tools/scan-view/ScanView.py
index 41e5a51392..b9839eab45 100644
--- a/tools/scan-view/ScanView.py
+++ b/tools/scan-view/ScanView.py
@@ -15,10 +15,15 @@ import Reporter
# Keys replaced by server.
+kReportColRE = re.compile('<!-- REPORTBUGCOL -->')
+kReportColRepl = '<td></td>'
kReportBugRE = re.compile('<!-- REPORTBUG id="report-(.*)\\.html" -->')
kReportBugRepl = '<td class="ReportBug"><a href="report/\\1">Report Bug</a></td>'
kBugKeyValueRE = re.compile('<!-- BUG([^ ]*) (.*) -->')
+kReportReplacements = [(kReportColRE, kReportColRepl),
+ (kReportBugRE, kReportBugRepl)]
+
###
__version__ = "0.1"
@@ -88,6 +93,12 @@ class ScanViewServer(BaseHTTPServer.HTTPServer):
except OSError,e:
print 'OSError',e.errno
+ def finish_request(self, request, client_address):
+ if self.options.autoReload:
+ import ScanView
+ self.RequestHandlerClass = reload(ScanView).ScanViewRequestHandler
+ BaseHTTPServer.HTTPServer.finish_request(self, request, client_address)
+
def handle_error(self, request, client_address):
# Ignore socket errors
info = sys.exc_info()
@@ -95,7 +106,7 @@ class ScanViewServer(BaseHTTPServer.HTTPServer):
if self.options.debug > 1:
print >>sys.stderr, "%s: SERVER: ignored socket error." % (sys.argv[0],)
return
- BaseHTTPServer.HTTPServer.handle_error(request, client_address)
+ BaseHTTPServer.HTTPServer.handle_error(self, request, client_address)
# Borrowed from Quixote, with simplifications.
def parse_query(qs, fields=None):
@@ -114,6 +125,7 @@ def parse_query(qs, fields=None):
class ScanViewRequestHandler(SimpleHTTPServer.SimpleHTTPRequestHandler):
server_version = "ScanViewServer/" + __version__
+ dynamic_mtime = time.time()
def do_HEAD(self):
try:
@@ -382,8 +394,9 @@ Method: <select id="reporter" name="reporter" onChange="updateReporterOptions()"
self.send_response(200)
self.send_header("Content-type", ctype)
self.send_header("Content-Length", str(len(s)))
- if mtime:
- self.send_header("Last-Modified", self.date_time_string(mtime))
+ if mtime is None:
+ mtime = self.dynamic_mtime
+ self.send_header("Last-Modified", self.date_time_string(mtime))
self.end_headers()
return StringIO.StringIO(s)
@@ -391,7 +404,8 @@ Method: <select id="reporter" name="reporter" onChange="updateReporterOptions()"
f = open(path,'r')
fs = os.fstat(f.fileno())
data = f.read()
- data = kReportBugRE.sub(kReportBugRepl, data)
+ for a,b in kReportReplacements:
+ data = a.sub(b, data)
return self.send_string(data, ctype, mtime=fs.st_mtime)