Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(159)

Unified Diff: tools/skpdiff/skpdiff_server.py

Issue 19929007: add basic HTTP server for viewing skpdiff results (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/skpdiff/skpdiff_server.py
diff --git a/tools/skpdiff/skpdiff_server.py b/tools/skpdiff/skpdiff_server.py
new file mode 100644
index 0000000000000000000000000000000000000000..cfaac5ce2dffd73255fe04caca0de6ca922677b4
--- /dev/null
+++ b/tools/skpdiff/skpdiff_server.py
@@ -0,0 +1,79 @@
+#!/usr/bin/python
epoger 2013/07/24 17:46:53 I don't remember where this is documented, but for
Zach Reizner 2013/07/24 20:16:36 According to http://www.python.org/dev/peps/pep-00
+# -*- coding: utf-8 -*-
+
+from __future__ import print_function
+import BaseHTTPServer
+import os
+import os.path
+
+# A simple dictionary of file name extensions to MIME types. The empty string entry is used as the
+# default when no extension was given or if the extension has no entry in this dictionary.
+MIME_TYPE_MAP = {'': 'application/octet-stream',
+ 'html': 'text/html',
+ 'css': 'text/css',
+ 'png': 'image/png',
+ 'js': 'application/javascript'
+ }
+
+
+class SkPDiffHandler(BaseHTTPServer.BaseHTTPRequestHandler):
+ def send_file(self, file_path):
+ # Grab the extension if there is one
+ extension = os.path.splitext(file_path)[1]
+ if len(extension) >= 1:
epoger 2013/07/24 17:46:53 FYI: I don't care one way or the other, but I thin
+ extension = extension[1:]
+
+ # Determine the MIME type of the file from its extension
+ mime_type = MIME_TYPE_MAP.get(extension, MIME_TYPE_MAP[''])
+
+ # Open the file and send it over HTTP
+ sending_file = open(file_path, 'rb')
+ self.send_response(200)
+ self.send_header('Content-type', mime_type)
+ self.end_headers()
+ self.wfile.write(sending_file.read())
+ sending_file.close()
+
+ def serve_if_in_dir(self, dir_path, file_path):
+ # Determine if the file exists relative to the given dir_path AND exists under the dir_path
epoger 2013/07/24 17:46:53 Please add a note indicating the security reasons
+ real_path = os.path.normpath(os.path.join(dir_path, file_path))
+ print(repr(real_path))
+ if os.path.commonprefix([real_path, dir_path]) == dir_path:
+ if os.path.isfile(real_path):
+ self.send_file(real_path)
+ return True
+ return False
+
+ def do_GET(self):
+ # Grab the script path because that is where all the static assets are
+ script_dir = os.path.dirname(os.path.abspath(__file__))
+
+ # Simple rewrite rule of the root path to 'viewer.html'
+ if self.path == '' or self.path == '/':
+ self.path = '/viewer.html'
+
+ # The [1:] chops of the leading '/'
epoger 2013/07/24 17:46:53 of -> off
+ file_path = self.path[1:]
+
+ # Attempt to send static asset files first
+ if self.serve_if_in_dir(script_dir, file_path):
+ return
+
+ # WARNING: Using the root is a big ol' hack. Incredibly insecure. Only allow serving to
epoger 2013/07/24 17:46:53 Indeed it is. Is there some other way we can hand
+ # localhost unless you want the network to be able to see ALL of the files you can.
+ # Attempt to send gm image files
+ if self.serve_if_in_dir('/', file_path):
+ return
+
+ # If no file to send was found, just give the standard 404
+ self.send_error(404)
+
+
+def main():
+ server_address = ('127.0.0.1', 8080)
+ http_server = BaseHTTPServer.HTTPServer(server_address, SkPDiffHandler)
+ print('Navigate thine browser to: {}:{}'.format(*server_address))
+ http_server.serve_forever()
+
+if __name__ == '__main__':
+ main()
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698