Left: | ||
Right: |
LEFT | RIGHT |
---|---|
1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
2 # coding: utf-8 | 2 # coding: utf-8 |
3 | 3 |
4 # This file is part of Adblock Plus <https://adblockplus.org/>, | 4 # This file is part of Adblock Plus <https://adblockplus.org/>, |
5 # Copyright (C) 2006-2015 Eyeo GmbH | 5 # Copyright (C) 2006-2015 Eyeo GmbH |
6 # | 6 # |
7 # Adblock Plus is free software: you can redistribute it and/or modify | 7 # Adblock Plus is free software: you can redistribute it and/or modify |
8 # it under the terms of the GNU General Public License version 3 as | 8 # it under the terms of the GNU General Public License version 3 as |
9 # published by the Free Software Foundation. | 9 # published by the Free Software Foundation. |
10 # | 10 # |
11 # Adblock Plus is distributed in the hope that it will be useful, | 11 # Adblock Plus is distributed in the hope that it will be useful, |
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 # but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
14 # GNU General Public License for more details. | 14 # GNU General Public License for more details. |
15 # | 15 # |
16 # You should have received a copy of the GNU General Public License | 16 # You should have received a copy of the GNU General Public License |
17 # along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | 17 # along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
18 | 18 |
19 import io | 19 import io |
20 import json | 20 import json |
21 import os | 21 import os |
22 import posixpath | 22 import posixpath |
23 import re | 23 import re |
24 import urlparse | 24 import urlparse |
25 | |
25 import flask | 26 import flask |
Felix Dahlke
2015/02/04 04:02:35
While we're nit picking :)
PEP-8: "You should put
| |
26 | 27 |
27 app = flask.Flask(__name__) | 28 app = flask.Flask(__name__) |
28 | 29 |
29 def get_scripts(root): | 30 def get_scripts(dir, reldir=""): |
30 for dir, _, files in os.walk(root): | 31 for filename in os.listdir(dir): |
31 for file in files: | 32 path = os.path.join(dir, filename) |
32 if os.path.splitext(file)[1] == ".js": | 33 # "Relative path" will be the parameter passed in to require(), meaning |
33 path = os.path.join(dir, file) | 34 # that it always has to use forward slashes. |
Felix Dahlke
2015/02/04 03:58:51
posixpath.join?
Wladimir Palant
2015/02/04 15:37:14
No, we need a proper OS-specific path here, only t
Felix Dahlke
2015/02/04 18:20:25
OK, fair enough. Considering that I didn't fully g
Wladimir Palant
2015/02/04 20:46:14
I don't think variable naming will make it any cle
| |
34 relpath = posixpath.relpath(path, root) | 35 relpath = posixpath.join(reldir, filename) |
35 yield (path, relpath) | 36 if os.path.isdir(path): |
37 for path, relpath in get_scripts(path, relpath): | |
38 yield path, relpath | |
39 elif os.path.splitext(path)[1] == ".js": | |
40 yield path, relpath | |
36 | 41 |
37 def js_encode(str): | 42 def js_encode(str): |
38 return json.dumps(str) | 43 return json.dumps(str) |
39 | 44 |
40 def script_as_string(path, sourceURL, backcompat): | 45 def script_as_string(path, sourceURL, backcompat): |
41 if backcompat: | 46 if backcompat: |
42 from jshydra.abp_rewrite import doRewrite | 47 from jshydra.abp_rewrite import doRewrite |
43 data = doRewrite([os.path.abspath(path)], []).decode("utf-8") | 48 data = doRewrite([os.path.abspath(path)], []).decode("utf-8") |
44 else: | 49 else: |
45 with io.open(path, "r", encoding="utf-8") as handle: | 50 with io.open(path, "r", encoding="utf-8") as handle: |
46 data = handle.read() | 51 data = handle.read() |
47 data += "\n//# sourceURL=%s" % sourceURL | 52 data += "\n//# sourceURL=%s" % sourceURL |
48 return js_encode(data) | 53 return js_encode(data) |
49 | 54 |
50 @app.route("/<path:path>", methods = ["GET"]) | 55 @app.route("/<path:path>", methods = ["GET"]) |
51 @app.route("/", methods = ["GET"]) | 56 @app.route("/", methods = ["GET"]) |
52 def multiplex(path=""): | 57 def multiplex(path=""): |
53 request_url = urlparse.urlparse(flask.request.url) | 58 base_url = flask.request.url |
59 request_url = urlparse.urlparse(base_url) | |
54 request_path = request_url.path | 60 request_path = request_url.path |
55 islib = request_path.startswith("/lib/") | 61 islib = request_path.startswith("/lib/") |
56 backcompat = request_url.query == "backcompat" | 62 backcompat = request_url.query == "backcompat" |
57 | 63 |
58 rootdir = os.path.dirname(__file__) | 64 rootdir = os.path.dirname(__file__) |
59 if request_path == "/lib.js": | 65 if request_path == "/lib.js": |
60 data = "" | 66 def generate_libs(): |
61 for path, relpath in get_scripts(os.path.join(rootdir, "lib")): | 67 for path, relpath in get_scripts(os.path.join(rootdir, "lib")): |
62 url = urlparse.urljoin(flask.request.url, "/lib/" + relpath) | 68 url = urlparse.urljoin(base_url, "/lib/" + relpath) |
63 data += "require.sources[%s] = %s;\n" % ( | 69 yield "require.sources[%s] = %s;\n" % ( |
64 js_encode(os.path.splitext(relpath)[0]), | 70 js_encode(posixpath.splitext(relpath)[0]), |
65 script_as_string(path, url, backcompat) | 71 script_as_string(path, url, backcompat) |
66 ) | 72 ) |
67 return (data, 200, {"Content-Type": "application/javascript; charset=utf-8"} ) | 73 return flask.Response(generate_libs(), mimetype="application/javascript") |
68 elif request_path == "/tests.js": | 74 elif request_path == "/tests.js": |
69 data = "var tests = [" | 75 def generate_tests(): |
70 for path, relpath in get_scripts(os.path.join(rootdir, "test", "tests")): | 76 yield "var tests = [" |
71 url = urlparse.urljoin(flask.request.url, "/tests/" + relpath) | 77 for path, relpath in get_scripts(os.path.join(rootdir, "test", "tests")): |
72 data += " %s,\n" % script_as_string(path, url, backcompat) | 78 url = urlparse.urljoin(base_url, "/tests/" + relpath) |
73 data += "];" | 79 yield " %s,\n" % script_as_string(path, url, backcompat) |
74 return (data, 200, {"Content-Type": "application/javascript; charset=utf-8"} ) | 80 yield "];" |
81 return flask.Response(generate_tests(), mimetype="application/javascript") | |
75 else: | 82 else: |
76 if request_path.startswith("/lib/"): | 83 if request_path.startswith("/lib/"): |
77 rootdir = os.path.join(rootdir, "lib") | 84 rootdir = os.path.join(rootdir, "lib") |
78 else: | 85 else: |
79 rootdir = os.path.join(rootdir, "test") | 86 rootdir = os.path.join(rootdir, "test") |
80 if request_path.endswith("/"): | 87 if request_path.endswith("/"): |
81 request_path += "index.html" | 88 request_path += "index.html" |
82 return flask.send_from_directory(rootdir, request_path.lstrip("/")) | 89 return flask.send_from_directory(rootdir, request_path.lstrip("/")) |
83 | 90 |
84 if __name__ == "__main__": | 91 if __name__ == "__main__": |
85 app.run(debug=True) | 92 app.run(debug=True) |
LEFT | RIGHT |