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

Unified Diff: bindings/scripts/aggregate_generated_bindings.py

Issue 540533002: Roll IDL to Dartium37 (r181268) (Closed) Base URL: https://dart.googlecode.com/svn/third_party/WebCore
Patch Set: Created 6 years, 3 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
« no previous file with comments | « bindings/scripts/__init__.py ('k') | bindings/scripts/blink_idl_lexer.py » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: bindings/scripts/aggregate_generated_bindings.py
diff --git a/bindings/scripts/aggregate_generated_bindings.py b/bindings/scripts/aggregate_generated_bindings.py
new file mode 100755
index 0000000000000000000000000000000000000000..abb2b81d75b447f4eddb540bac42b2678b028f4e
--- /dev/null
+++ b/bindings/scripts/aggregate_generated_bindings.py
@@ -0,0 +1,236 @@
+#!/usr/bin/python
+#
+# Copyright (C) 2009 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.
+#
+# 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.
+
+"""Generate aggregate .cpp files that include multiple V8 binding .cpp files.
+
+This can be a single output file, to preserve symbol space; or multiple output
+files, to reduce maximum compilation unit size and allow parallel compilation.
+
+Usage:
+aggregate_generated_bindings.py COMPONENT_DIR IDL_FILES_LIST -- OUTPUT_FILE1 OUTPUT_FILE2 ...
+
+COMPONENT_DIR is the relative directory of a component, e.g., 'core', 'modules'.
+IDL_FILES_LIST is a text file containing the IDL file paths, so the command
+line doesn't exceed OS length limits.
+OUTPUT_FILE1 etc. are filenames of output files.
+
+Design doc: http://www.chromium.org/developers/design-documents/idl-build
+"""
+
+import errno
+import os
+import re
+import subprocess
+import sys
+
+from utilities import idl_filename_to_interface_name
+
+# A regexp for finding Conditional attributes in interface definitions.
+CONDITIONAL_PATTERN = re.compile(
+ r'\['
+ r'[^\]]*'
+ r'Conditional=([\_0-9a-zA-Z&|]*)'
+ r'[^\]]*'
+ r'\]\s*'
+ r'((callback|partial)\s+)?'
+ r'interface\s+'
+ r'\w+\s*'
+ r'(:\s*\w+\s*)?'
+ r'{',
+ re.MULTILINE)
+
+COPYRIGHT_TEMPLATE = """/*
+ * THIS FILE WAS AUTOMATICALLY GENERATED, DO NOT EDIT.
+ *
+ * This file was generated by the action_derivedsourcesallinone.py script.
+ *
+ * Copyright (C) 2009 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:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. 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.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``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 APPLE COMPUTER, INC. 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.
+ */
+"""
+
+
+def format_conditional(conditional):
+ """Wraps conditional with ENABLE() and replace '&','|' with '&&','||' if
+ more than one conditional is specified."""
+ def wrap_with_enable(s):
+ if s in ['|', '&']:
+ return s * 2
+ return 'ENABLE(' + s + ')'
+ return ' '.join(map(wrap_with_enable, conditional))
+
+
+def extract_conditional(idl_file_path):
+ """Find [Conditional] interface extended attribute."""
+ with open(idl_file_path) as idl_file:
+ idl_contents = idl_file.read()
+
+ match = CONDITIONAL_PATTERN.search(idl_contents)
+ if not match:
+ return None
+ conditional = match.group(1)
+ return re.split('([|&])', conditional)
+
+
+def extract_meta_data(file_paths):
+ """Extracts conditional and interface name from each IDL file."""
+ meta_data_list = []
+
+ for file_path in file_paths:
+ if not file_path.endswith('.idl'):
+ print 'WARNING: non-IDL file passed: "%s"' % file_path
+ continue
+ if not os.path.exists(file_path):
+ print 'WARNING: file not found: "%s"' % file_path
+ continue
+
+ # Extract interface name from file name
+ interface_name = idl_filename_to_interface_name(file_path)
+
+ meta_data = {
+ 'conditional': extract_conditional(file_path),
+ 'name': interface_name,
+ }
+ meta_data_list.append(meta_data)
+
+ return meta_data_list
+
+
+def generate_content(component_dir, files_meta_data_this_partition, prefix):
+ # Add fixed content.
+ output = [COPYRIGHT_TEMPLATE,
+ '#define NO_IMPLICIT_ATOMICSTRING\n\n']
+
+ # List all includes segmented by if and endif.
+ prev_conditional = None
+ files_meta_data_this_partition.sort(key=lambda e: e['conditional'])
+ for meta_data in files_meta_data_this_partition:
+ conditional = meta_data['conditional']
+ if prev_conditional != conditional:
+ if prev_conditional:
+ output.append('#endif\n')
+ if conditional:
+ output.append('\n#if %s\n' % format_conditional(conditional))
+ prev_conditional = conditional
+
+ output.append('#include "bindings/%s/%s/%s%s.cpp"\n' %
+ (component_dir, prefix.lower(), prefix, meta_data['name']))
+
+ if prev_conditional:
+ output.append('#endif\n')
+
+ return ''.join(output)
+
+
+def write_content(content, output_file_name):
+ parent_path, file_name = os.path.split(output_file_name)
+ if not os.path.exists(parent_path):
+ print 'Creating directory: %s' % parent_path
+ os.makedirs(parent_path)
+ with open(output_file_name, 'w') as f:
+ f.write(content)
+
+
+def resolve_cygpath(cygdrive_names):
+ if not cygdrive_names:
+ return []
+ cmd = ['cygpath', '-f', '-', '-wa']
+ process = subprocess.Popen(cmd, stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
+ idl_file_names = []
+ for file_name in cygdrive_names:
+ process.stdin.write('%s\n' % file_name)
+ process.stdin.flush()
+ idl_file_names.append(process.stdout.readline().rstrip())
+ process.stdin.close()
+ process.wait()
+ return idl_file_names
+
+
+def main(args):
+ if len(args) <= 4:
+ raise Exception('Expected at least 5 arguments.')
+ if (args[1] == '--dart'):
+ component_dir = args[2]
+ input_file_name = args[3]
+ prefix = 'Dart'
+ else:
+ component_dir = args[1]
+ input_file_name = args[2]
+ prefix = 'V8'
+ in_out_break_index = args.index('--')
+ output_file_names = args[in_out_break_index + 1:]
+
+ with open(input_file_name) as input_file:
+ file_names = sorted([os.path.realpath(line.rstrip('\n'))
+ for line in input_file])
+ idl_file_names = [file_name for file_name in file_names
+ if not file_name.startswith('/cygdrive')]
+ cygdrive_names = [file_name for file_name in file_names
+ if file_name.startswith('/cygdrive')]
+ idl_file_names.extend(resolve_cygpath(cygdrive_names))
+
+ files_meta_data = extract_meta_data(idl_file_names)
+ total_partitions = len(output_file_names)
+ for partition, file_name in enumerate(output_file_names):
+ files_meta_data_this_partition = [
+ meta_data for meta_data in files_meta_data
+ if hash(meta_data['name']) % total_partitions == partition]
+ file_contents = generate_content(component_dir,
+ files_meta_data_this_partition,
+ prefix)
+ write_content(file_contents, file_name)
+
+
+if __name__ == '__main__':
+ sys.exit(main(sys.argv))
« no previous file with comments | « bindings/scripts/__init__.py ('k') | bindings/scripts/blink_idl_lexer.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698