WebHTTPBody: Keep track of whether the data includes passwords.
[WebKit-https.git] / Source / WebKit / chromium / scripts / generate_devtools_zip.py
1 #!/usr/bin/env python
2 #
3 # Copyright (C) 2011 Google Inc. All rights reserved.
4 #
5 # Redistribution and use in source and binary forms, with or without
6 # modification, are permitted provided that the following conditions are
7 # met:
8 #
9 #         * Redistributions of source code must retain the above copyright
10 # notice, this list of conditions and the following disclaimer.
11 #         * Redistributions in binary form must reproduce the above
12 # copyright notice, this list of conditions and the following disclaimer
13 # in the documentation and/or other materials provided with the
14 # distribution.
15 #         * Neither the name of Google Inc. nor the names of its
16 # contributors may be used to endorse or promote products derived from
17 # this software without specific prior written permission.
18 #
19 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
31 """Creates a zip file containing the web inspector files for debugging.
32
33 The zip file contains all the .html, .js, .css and image files used by the
34 web inspector.  The js files and css files are not concatenated and are not
35 minified."""
36
37 from __future__ import with_statement
38
39 import os
40 import StringIO
41 import sys
42 import zipfile
43
44 import concatenate_js_files
45 import generate_devtools_html
46 import generate_devtools_extension_api
47
48
49 class ParsedArgs:
50     def __init__(self, inspector_html, devtools_files, workers_files, extension_api_files,
51                  search_dirs, js_search_dirs, output_filename):
52         self.inspector_html = inspector_html
53         self.devtools_files = devtools_files
54         self.workers_files = workers_files
55         self.extension_api_files = extension_api_files
56         self.search_dirs = search_dirs
57         self.js_search_dirs = js_search_dirs
58         self.output_filename = output_filename
59
60
61 def parse_args(argv):
62     inspector_html = argv[0]
63
64     devtools_files_position = argv.index('--devtools-files')
65     workers_files_position = argv.index('--workers-files')
66     extension_api_files_position = argv.index('--extension-api-files')
67     search_path_position = argv.index('--search-path')
68     js_search_path_position = argv.index('--js-search-path')
69     output_position = argv.index('--output')
70
71     devtools_files = argv[devtools_files_position + 1:workers_files_position]
72     workers_files = argv[workers_files_position + 1:extension_api_files_position]
73     extension_api_files = argv[extension_api_files_position + 1:search_path_position]
74     search_dirs = argv[search_path_position + 1:js_search_path_position]
75     js_search_dirs = argv[js_search_path_position + 1:output_position]
76
77     return ParsedArgs(inspector_html, devtools_files, workers_files, extension_api_files,
78                       search_dirs, js_search_dirs, argv[output_position + 1])
79
80
81 def main(argv):
82     parsed_args = parse_args(argv[1:])
83
84     devtools_html = StringIO.StringIO()
85     with open(parsed_args.inspector_html, 'r') as inspector_file:
86         generate_devtools_html.write_devtools_html(
87             inspector_file, devtools_html, True, parsed_args.devtools_files)
88
89     zip = zipfile.ZipFile(parsed_args.output_filename, 'w', zipfile.ZIP_DEFLATED)
90     zip.writestr("devtools.html", devtools_html.getvalue())
91
92     devtools_extension_api = StringIO.StringIO()
93     generate_devtools_extension_api.write_devtools_extension_api(
94         devtools_extension_api, parsed_args.extension_api_files)
95     zip.writestr("devtools_extension_api.js", devtools_extension_api.getvalue())
96
97     js_extractor = concatenate_js_files.OrderedJSFilesExtractor(
98         devtools_html.getvalue())
99
100     js_dirs = parsed_args.search_dirs + parsed_args.js_search_dirs
101     expander = concatenate_js_files.PathExpander(js_dirs)
102     files = js_extractor.ordered_js_files
103     for input_file_name in set(files):
104         full_path = expander.expand(input_file_name)
105         if full_path is None:
106             raise Exception('File %s referenced in %s not found on any source paths, '
107                             'check source tree for consistency' %
108                             (input_file_name, 'devtools.html'))
109         zip.write(full_path, os.path.basename(full_path))
110
111     front_end_path = os.path.dirname(os.path.abspath(parsed_args.inspector_html))
112
113     for input_file_name in set(parsed_args.workers_files):
114         script_path = os.path.dirname(os.path.abspath(input_file_name))
115         if script_path.startswith(front_end_path):
116             script_path = script_path.replace(front_end_path, "")
117             if len(script_path) > 0:
118                 script_path += '/'
119             zip.write(input_file_name,
120                       script_path + os.path.basename(input_file_name))
121         else:
122             raise Exception('Worker script %s is not from Inspector front-end dir' % (input_file_name))
123
124     for dirname in parsed_args.search_dirs:
125         for filename in os.listdir(dirname):
126             if filename.endswith('.css'):
127                 zip.write(os.path.join(dirname, filename), filename)
128         dirname = os.path.join(dirname, 'Images')
129         for filename in os.listdir(dirname):
130             if filename.endswith('.png') or filename.endswith('.gif'):
131                 zip.write(os.path.join(dirname, filename),
132                           os.path.join('Images', filename))
133
134     # It would be nice to use the with statement to scope closing the archive,
135     # but that wasn't added until python 2.7.
136     zip.close()
137
138
139 if '__main__' == __name__:
140     sys.exit(main(sys.argv))