Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(325)

Unified Diff: Source/bindings/scripts/generate_bindings.py

Issue 18190004: Add Python flow to bindings generation, move dummy-generating IDL files over (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Tweak similarity Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/bindings/scripts/generate_bindings.py
diff --git a/Source/bindings/scripts/generate_bindings.py b/Source/bindings/scripts/generate_bindings.py
new file mode 100755
index 0000000000000000000000000000000000000000..b8125ec5bc5386eaf90334666739347cc7f4f6ce
--- /dev/null
+++ b/Source/bindings/scripts/generate_bindings.py
@@ -0,0 +1,89 @@
+#!/usr/bin/python
+# Copyright (C) 2013 Google Inc. All rights reserved.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are
+# met:
+#
+# * Redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+# * Redistributions in binary form must reproduce the above
+# copyright notice, this list of conditions and the following disclaimer
+# in the documentation and/or other materials provided with the
+# distribution.
+# * Neither the name of Google Inc. nor the names of its
+# contributors may be used to endorse or promote products derived from
+# this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+import optparse
+import os
+import shlex
+import sys
+
+import build_ir
+import code_generator_v8
+
+
+def parse_options():
+ parser = optparse.OptionParser()
+ parser.add_option('--additional-idl-files')
+ parser.add_option('--defines')
haraken 2013/07/08 06:06:29 Is this still needed? Now we no longer need prepro
Nils Barth (inactive) 2013/07/09 08:48:16 Nope, we can remove it – done! (Just checked with
+ parser.add_option('--idl-attributes-file')
+ parser.add_option('--include', dest='idl_directories', action='append')
+ parser.add_option('--output-directory')
+ parser.add_option('--supplemental-dependency-file')
+ parser.add_option('--verbose', action='store_true', default=False)
+ parser.add_option('--write-file-only-if-changed', type='int')
+ # ensure output comes last, so command line easy to parse via regexes
+ parser.disable_interspersed_args()
+
+ options, args = parser.parse_args()
+ if options.output_directory is None:
+ parser.error('Must specify output directory using --output-directory.')
+ if options.additional_idl_files is not None:
+ # additional_idl_files is passed as a string with varied (shell-style)
+ # quoting, hence needs parsing.
+ options.additional_idl_files = shlex.split(options.additional_idl_files)
+ if len(args) != 1:
+ parser.error('Must specify exactly 1 input file as argument, but %d given.' % len(args))
+ options.target_idl_filename = os.path.realpath(args[0])
+ return options
+
+
+def main():
+ options = parse_options()
+ target_idl_filename = options.target_idl_filename
+ target_basename = os.path.basename(target_idl_filename)
+ target_interface_name, _ = os.path.splitext(target_basename)
+ if options.verbose:
+ print target_idl_filename
+
+ try:
+ # FIXME: Currently read_merged_idl does not return, since just a stub
+ # Ignore E1111: Assigning to function call which doesn't return
+ # pylint: disable=E1111
+ blink_ir = build_ir.read_merged_idl(target_idl_filename, supplemental_dependency_file=options.supplemental_dependency_file, additional_idl_files=options.additional_idl_files)
+ except build_ir.IdlNotFoundError:
+ # We generate dummy .h and .cpp files just to tell build scripts
+ # that outputs have been created.
+ code_generator_v8.generate_dummy_header_and_cpp(target_interface_name, options.output_directory)
+ return
+ # FIXME: currently IdlNotFoundError *must* be raised, and dummy .cpp and
+ # .h files generated, as actual code generator not present yet.
+ raise RuntimeError('Stub: real code generator not implemented yet')
+
+
+if __name__ == '__main__':
+ sys.exit(main())

Powered by Google App Engine
This is Rietveld 408576698