| OLD | NEW | 
|---|
|  | (Empty) | 
| 1 #!/usr/bin/python |  | 
| 2 # Copyright (C) 2013 Google Inc. All rights reserved. |  | 
| 3 # |  | 
| 4 # Redistribution and use in source and binary forms, with or without |  | 
| 5 # modification, are permitted provided that the following conditions are |  | 
| 6 # met: |  | 
| 7 # |  | 
| 8 #     * Redistributions of source code must retain the above copyright |  | 
| 9 # notice, this list of conditions and the following disclaimer. |  | 
| 10 #     * Redistributions in binary form must reproduce the above |  | 
| 11 # copyright notice, this list of conditions and the following disclaimer |  | 
| 12 # in the documentation and/or other materials provided with the |  | 
| 13 # distribution. |  | 
| 14 #     * Neither the name of Google Inc. nor the names of its |  | 
| 15 # contributors may be used to endorse or promote products derived from |  | 
| 16 # this software without specific prior written permission. |  | 
| 17 # |  | 
| 18 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |  | 
| 19 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |  | 
| 20 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |  | 
| 21 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |  | 
| 22 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |  | 
| 23 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |  | 
| 24 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |  | 
| 25 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |  | 
| 26 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |  | 
| 27 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |  | 
| 28 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | 
| 29 |  | 
| 30 """Compile an .idl file to Blink V8 bindings (.h and .cpp files). |  | 
| 31 |  | 
| 32 We are porting the IDL compiler from Perl to Python. The plan is as follows. |  | 
| 33 We will temporarily have two build flows (see ../derived_sources.gyp): |  | 
| 34 [1] Perl: deprecated_generate_bindings.pl, which calls: |  | 
| 35     deprecated_idl_parser.pm => deprecated_code_generator_v8.pm |  | 
| 36 [2] Python: idl_compiler.py, which calls: |  | 
| 37     IDL lexer => IDL parser => Python object builder => |  | 
| 38     interface dependency resolver => IDL semantic validator => |  | 
| 39     C++ code generator |  | 
| 40 |  | 
| 41 We will move IDL files from the Perl build flow [1] to the Python build flow [2] |  | 
| 42 incrementally. See http://crbug.com/239771 |  | 
| 43 """ |  | 
| 44 import optparse |  | 
| 45 import os |  | 
| 46 import pickle |  | 
| 47 import posixpath |  | 
| 48 import shlex |  | 
| 49 import sys |  | 
| 50 |  | 
| 51 import code_generator_v8 |  | 
| 52 import idl_reader |  | 
| 53 |  | 
| 54 module_path, _ = os.path.split(__file__) |  | 
| 55 source_path = os.path.normpath(os.path.join(module_path, os.pardir, os.pardir)) |  | 
| 56 |  | 
| 57 def parse_options(): |  | 
| 58     parser = optparse.OptionParser() |  | 
| 59     parser.add_option('--additional-idl-files') |  | 
| 60     # FIXME: The --dump-json-and-pickle option is only for debugging and will |  | 
| 61     # be removed once we complete migrating all IDL files from the Perl flow to |  | 
| 62     # the Python flow. |  | 
| 63     parser.add_option('--dump-json-and-pickle', action='store_true', default=Fal
     se) |  | 
| 64     parser.add_option('--idl-attributes-file') |  | 
| 65     parser.add_option('--include', dest='idl_directories', action='append') |  | 
| 66     parser.add_option('--output-directory') |  | 
| 67     parser.add_option('--interface-dependencies-file') |  | 
| 68     parser.add_option('--verbose', action='store_true', default=False) |  | 
| 69     parser.add_option('--write-file-only-if-changed', type='int') |  | 
| 70     # ensure output comes last, so command line easy to parse via regexes |  | 
| 71     parser.disable_interspersed_args() |  | 
| 72 |  | 
| 73     options, args = parser.parse_args() |  | 
| 74     if options.output_directory is None: |  | 
| 75         parser.error('Must specify output directory using --output-directory.') |  | 
| 76     if options.additional_idl_files is None: |  | 
| 77         options.additional_idl_files = [] |  | 
| 78     else: |  | 
| 79         # additional_idl_files is passed as a string with varied (shell-style) |  | 
| 80         # quoting, hence needs parsing. |  | 
| 81         options.additional_idl_files = shlex.split(options.additional_idl_files) |  | 
| 82     if len(args) != 1: |  | 
| 83         parser.error('Must specify exactly 1 input file as argument, but %d give
     n.' % len(args)) |  | 
| 84     options.idl_filename = os.path.realpath(args[0]) |  | 
| 85     return options |  | 
| 86 |  | 
| 87 |  | 
| 88 def get_relative_dir_posix(filename): |  | 
| 89     """Returns directory of a local file relative to Source, in POSIX format.""" |  | 
| 90     relative_path_local = os.path.relpath(filename, source_path) |  | 
| 91     relative_dir_local = os.path.dirname(relative_path_local) |  | 
| 92     return relative_dir_local.replace(os.path.sep, posixpath.sep) |  | 
| 93 |  | 
| 94 |  | 
| 95 def write_json_and_pickle(definitions, interface_name, output_directory): |  | 
| 96     json_string = definitions.to_json() |  | 
| 97     json_basename = interface_name + '.json' |  | 
| 98     json_filename = os.path.join(output_directory, json_basename) |  | 
| 99     with open(json_filename, 'w') as json_file: |  | 
| 100         json_file.write(json_string) |  | 
| 101     pickle_basename = interface_name + '.pkl' |  | 
| 102     pickle_filename = os.path.join(output_directory, pickle_basename) |  | 
| 103     with open(pickle_filename, 'wb') as pickle_file: |  | 
| 104         pickle.dump(definitions, pickle_file) |  | 
| 105 |  | 
| 106 |  | 
| 107 def main(): |  | 
| 108     options = parse_options() |  | 
| 109     idl_filename = options.idl_filename |  | 
| 110     basename = os.path.basename(idl_filename) |  | 
| 111     interface_name, _ = os.path.splitext(basename) |  | 
| 112     output_directory = options.output_directory |  | 
| 113     verbose = options.verbose |  | 
| 114     if verbose: |  | 
| 115         print idl_filename |  | 
| 116     relative_dir_posix = get_relative_dir_posix(idl_filename) |  | 
| 117 |  | 
| 118     reader = idl_reader.IdlReader(options.interface_dependencies_file, options.a
     dditional_idl_files, options.idl_attributes_file, output_directory, verbose) |  | 
| 119     definitions = reader.read_idl_definitions(idl_filename) |  | 
| 120     code_generator = code_generator_v8.CodeGeneratorV8(definitions, interface_na
     me, options.output_directory, relative_dir_posix, options.idl_directories, verbo
     se) |  | 
| 121     if not definitions: |  | 
| 122         # We generate dummy .h and .cpp files just to tell build scripts |  | 
| 123         # that outputs have been created. |  | 
| 124         code_generator.write_dummy_header_and_cpp() |  | 
| 125         return |  | 
| 126     if options.dump_json_and_pickle: |  | 
| 127         write_json_and_pickle(definitions, interface_name, output_directory) |  | 
| 128         return |  | 
| 129     code_generator.write_header_and_cpp() |  | 
| 130 |  | 
| 131 |  | 
| 132 if __name__ == '__main__': |  | 
| 133     sys.exit(main()) |  | 
| OLD | NEW | 
|---|