Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Delta Between Two Patch Sets: sitescripts/web/bin/generate_static_pages.py

Issue 17817001: Simple CMS as Anwiki replacement (Closed)
Left Patch Set: Created Oct. 23, 2013, 1:52 p.m.
Right Patch Set: Fixed MIME type Created Nov. 4, 2013, 4:11 p.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
Left: Side by side diff | Download
Right: Side by side diff | Download
« no previous file with change/comment | « sitescripts/web/bin/__init__.py ('k') | sitescripts/web/bin/test_server.py » ('j') | no next file with change/comment »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
LEFTRIGHT
1 # coding: utf-8 1 # coding: utf-8
2 2
3 # This file is part of the Adblock Plus web scripts, 3 # This file is part of the Adblock Plus web scripts,
4 # Copyright (C) 2006-2013 Eyeo GmbH 4 # Copyright (C) 2006-2013 Eyeo GmbH
5 # 5 #
6 # Adblock Plus is free software: you can redistribute it and/or modify 6 # Adblock Plus is free software: you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License version 3 as 7 # it under the terms of the GNU General Public License version 3 as
8 # published by the Free Software Foundation. 8 # published by the Free Software Foundation.
9 # 9 #
10 # Adblock Plus is distributed in the hope that it will be useful, 10 # Adblock Plus is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of 11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details. 13 # GNU General Public License for more details.
14 # 14 #
15 # You should have received a copy of the GNU General Public License 15 # You should have received a copy of the GNU General Public License
16 # along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. 16 # along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
17 17
18 import sys, os 18 import sys, os, re, errno, codecs
19 from sitescripts.utils import setupStderr 19 from ...utils import setupStderr, cached
20 from sitescripts.web.utils import process_page 20 from ..utils import process_page
21 from sitescripts.web.sources import MercurialSource 21 from ..sources import MercurialSource
22 22
23 def generate_pages(repo, output_dir): 23 def generate_pages(repo, output_dir):
24 known_files = set() 24 known_files = set()
25 25
26 def write_file(path_parts, contents): 26 def write_file(path_parts, contents, binary=False):
27 encoding = None if binary else "utf-8"
27 outfile = os.path.join(output_dir, *path_parts) 28 outfile = os.path.join(output_dir, *path_parts)
28 if outfile in known_files: 29 if outfile in known_files:
29 print >>sys.stderr, "Warning: File %s has multiple sources" % outfile 30 print >>sys.stderr, "Warning: File %s has multiple sources" % outfile
30 return 31 return
31 known_files.add(outfile) 32 known_files.add(outfile)
32 33
33 if os.path.exists(outfile): 34 if os.path.exists(outfile):
34 with open(outfile, "rb") as handle: 35 with codecs.open(outfile, "rb", encoding=encoding) as handle:
35 if handle.read() == contents: 36 if handle.read() == contents:
36 return 37 return
37 38
38 try: 39 try:
39 os.makedirs(os.path.dirname(outfile)) 40 os.makedirs(os.path.dirname(outfile))
40 except OSError: 41 except OSError, e:
41 pass 42 if e.errno != errno.EEXIST:
43 raise
42 44
43 with open(outfile, "wb") as handle: 45 with codecs.open(outfile, "wb", encoding=encoding) as handle:
44 handle.write(contents) 46 handle.write(contents)
45 47
46 with MercurialSource(repo) as source: 48 with MercurialSource(repo) as source:
49 # Cache the result for some functions - we can assume here that the data
50 # never changes
51 source.resolve_link = cached(float("Infinity"))(source.resolve_link)
52 source.read_config = cached(float("Infinity"))(source.read_config)
53 source.read_template = cached(float("Infinity"))(source.read_template)
54 source.read_locale = cached(float("Infinity"))(source.read_locale)
55 source.read_include = cached(float("Infinity"))(source.read_include)
56
47 locales = list(source.list_locales()) 57 locales = list(source.list_locales())
48 for page, format in source.list_pages(): 58 for page, format in source.list_pages():
49 for locale in locales: 59 for locale in locales:
50 if source.has_locale(locale, page): 60 if source.has_locale(locale, page):
51 pagedata = process_page(source, locale, page, format) 61 pagedata = process_page(source, locale, page, format)
62
63 # Make sure links to static files are versioned
64 pagedata = re.sub(r'(<script\s[^<>]*\bsrc="/[^"<>]+)', r"\1?%s" % sour ce.version, pagedata)
65 pagedata = re.sub(r'(<link\s[^<>]*\bhref="/[^"<>]+)', r"\1?%s" % sourc e.version, pagedata)
66 pagedata = re.sub(r'(<img\s[^<>]*\bsrc="/[^"<>]+)', r"\1?%s" % source. version, pagedata)
67
52 write_file([locale] + page.split("/"), pagedata) 68 write_file([locale] + page.split("/"), pagedata)
53 69
54 for filename in source.list_localizable_files(): 70 for filename in source.list_localizable_files():
55 for locale in locales: 71 for locale in locales:
56 if source.has_localizable_file(locale, filename): 72 if source.has_localizable_file(locale, filename):
57 filedata = source.read_localizable_file(locale, filename) 73 filedata = source.read_localizable_file(locale, filename)
58 write_file([locale] + filename.split("/"), filedata) 74 write_file([locale] + filename.split("/"), filedata, binary=True)
59 75
60 for filename in source.list_static(): 76 for filename in source.list_static():
61 write_file(filename.split("/"), source.read_static(filename)) 77 write_file(filename.split("/"), source.read_static(filename), binary=True)
62 78
63 def remove_unknown(dir): 79 def remove_unknown(dir):
64 files = os.listdir(dir) 80 files = os.listdir(dir)
65 for filename in files: 81 for filename in files:
66 path = os.path.join(dir, filename) 82 path = os.path.join(dir, filename)
67 if os.path.isfile(path) and path not in known_files: 83 if os.path.isfile(path) and path not in known_files:
68 os.remove(path) 84 os.remove(path)
69 elif os.path.isdir(path): 85 elif os.path.isdir(path):
70 remove_unknown(path) 86 remove_unknown(path)
71 if not os.listdir(path): 87 if not os.listdir(path):
72 os.rmdir(path) 88 os.rmdir(path)
73 remove_unknown(output_dir) 89 remove_unknown(output_dir)
74 90
75 if __name__ == "__main__": 91 if __name__ == "__main__":
76 setupStderr() 92 setupStderr()
77 if len(sys.argv) < 3: 93 if len(sys.argv) < 3:
78 print >>sys.stderr, "Usage: %s source_repository output_dir" % sys.argv[0] 94 print >>sys.stderr, "Usage: %s source_repository output_dir" % sys.argv[0]
79 sys.exit(1) 95 sys.exit(1)
80 96
81 repo, output_dir = sys.argv[1:3] 97 repo, output_dir = sys.argv[1:3]
82 generate_pages(repo, output_dir) 98 generate_pages(repo, output_dir)
LEFTRIGHT

Powered by Google App Engine
This is Rietveld