blob: b6d7efcf563255dc65bf0e14856457a1fc51d1b6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
#!/usr/bin/env python
# Copyright (c) 2009 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
# This script concatenates in place JS files in the order specified
# using <script> tags in a given 'order.html' file.
from HTMLParser import HTMLParser
from cStringIO import StringIO
import os.path
import sys
class OrderedJSFilesExtractor(HTMLParser):
def __init__(self, order_html_name):
HTMLParser.__init__(self)
self.ordered_js_files = []
order_html = open(order_html_name, 'r')
self.feed(order_html.read())
def handle_starttag(self, tag, attrs):
if tag == 'script':
attrs_dict = dict(attrs)
if ('type' in attrs_dict and attrs_dict['type'] == 'text/javascript' and
'src' in attrs_dict):
self.ordered_js_files.append(attrs_dict['src'])
def main(argv):
if len(argv) < 3:
print('usage: %s order.html input_file_1 input_file_2 ... '
'output_file' % argv[0])
return 1
output_file_name = argv.pop()
full_paths = {}
for full_path in argv[2:]:
(dir_name, file_name) = os.path.split(full_path)
if file_name.endswith('.js'):
full_paths[file_name] = full_path
extractor = OrderedJSFilesExtractor(argv[1])
output = StringIO()
for input_file_name in extractor.ordered_js_files:
if not input_file_name in full_paths:
print('A full path to %s isn\'t specified in command line. '
'Probably, you have an obsolete script entry in %s' %
(input_file_name, argv[1]))
output.write('/* %s */\n\n' % input_file_name)
input_file = open(full_paths[input_file_name], 'r')
output.write(input_file.read())
output.write('\n')
input_file.close()
output_file = open(output_file_name, 'w')
output_file.write(output.getvalue())
output_file.close()
output.close()
if __name__ == '__main__':
sys.exit(main(sys.argv))
|