| OLD | NEW |
| 1 # Copyright (C) 2013 Google Inc. All rights reserved. | 1 # Copyright (C) 2013 Google Inc. All rights reserved. |
| 2 # | 2 # |
| 3 # Redistribution and use in source and binary forms, with or without | 3 # Redistribution and use in source and binary forms, with or without |
| 4 # modification, are permitted provided that the following conditions are | 4 # modification, are permitted provided that the following conditions are |
| 5 # met: | 5 # met: |
| 6 # | 6 # |
| 7 # * Redistributions of source code must retain the above copyright | 7 # * Redistributions of source code must retain the above copyright |
| 8 # notice, this list of conditions and the following disclaimer. | 8 # notice, this list of conditions and the following disclaimer. |
| 9 # * Redistributions in binary form must reproduce the above | 9 # * Redistributions in binary form must reproduce the above |
| 10 # copyright notice, this list of conditions and the following disclaimer | 10 # copyright notice, this list of conditions and the following disclaimer |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 96 assert is_valid_component_dependency(component, dependency) | 96 assert is_valid_component_dependency(component, dependency) |
| 97 includes.add(include_path) | 97 includes.add(include_path) |
| 98 | 98 |
| 99 template_context['cpp_includes'] = sorted(includes) | 99 template_context['cpp_includes'] = sorted(includes) |
| 100 | 100 |
| 101 header_text = header_template.render(template_context) | 101 header_text = header_template.render(template_context) |
| 102 cpp_text = cpp_template.render(template_context) | 102 cpp_text = cpp_template.render(template_context) |
| 103 return header_text, cpp_text | 103 return header_text, cpp_text |
| 104 | 104 |
| 105 | 105 |
| 106 def set_global_type_info(interfaces_info): |
| 107 idl_types.set_ancestors(interfaces_info['ancestors']) |
| 108 IdlType.set_callback_interfaces(interfaces_info['callback_interfaces']) |
| 109 IdlType.set_dictionaries(interfaces_info['dictionaries']) |
| 110 IdlType.set_implemented_as_interfaces(interfaces_info['implemented_as_interf
aces']) |
| 111 IdlType.set_garbage_collected_types(interfaces_info['garbage_collected_inter
faces']) |
| 112 IdlType.set_will_be_garbage_collected_types(interfaces_info['will_be_garbage
_collected_interfaces']) |
| 113 v8_types.set_component_dirs(interfaces_info['component_dirs']) |
| 114 |
| 115 |
| 106 class CodeGeneratorBase(object): | 116 class CodeGeneratorBase(object): |
| 107 """Base class for v8 bindings generator and IDL dictionary impl generator""" | 117 """Base class for v8 bindings generator and IDL dictionary impl generator""" |
| 108 | 118 |
| 109 def __init__(self, interfaces_info, cache_dir, output_dir): | 119 def __init__(self, interfaces_info, cache_dir, output_dir): |
| 110 interfaces_info = interfaces_info or {} | 120 interfaces_info = interfaces_info or {} |
| 111 self.interfaces_info = interfaces_info | 121 self.interfaces_info = interfaces_info |
| 112 self.jinja_env = initialize_jinja_env(cache_dir) | 122 self.jinja_env = initialize_jinja_env(cache_dir) |
| 113 self.output_dir = output_dir | 123 self.output_dir = output_dir |
| 114 | 124 set_global_type_info(interfaces_info) |
| 115 # Set global type info | |
| 116 idl_types.set_ancestors(interfaces_info['ancestors']) | |
| 117 IdlType.set_callback_interfaces(interfaces_info['callback_interfaces']) | |
| 118 IdlType.set_dictionaries(interfaces_info['dictionaries']) | |
| 119 IdlType.set_implemented_as_interfaces(interfaces_info['implemented_as_in
terfaces']) | |
| 120 IdlType.set_garbage_collected_types(interfaces_info['garbage_collected_i
nterfaces']) | |
| 121 IdlType.set_will_be_garbage_collected_types(interfaces_info['will_be_gar
bage_collected_interfaces']) | |
| 122 v8_types.set_component_dirs(interfaces_info['component_dirs']) | |
| 123 | 125 |
| 124 def generate_code(self, definitions, definition_name): | 126 def generate_code(self, definitions, definition_name): |
| 125 """Returns .h/.cpp code as ((path, content)...).""" | 127 """Returns .h/.cpp code as ((path, content)...).""" |
| 126 # Set local type info | 128 # Set local type info |
| 127 IdlType.set_callback_functions(definitions.callback_functions.keys()) | 129 IdlType.set_callback_functions(definitions.callback_functions.keys()) |
| 128 IdlType.set_enums((enum.name, enum.values) | 130 IdlType.set_enums((enum.name, enum.values) |
| 129 for enum in definitions.enumerations.values()) | 131 for enum in definitions.enumerations.values()) |
| 130 return self.generate_code_internal(definitions, definition_name) | 132 return self.generate_code_internal(definitions, definition_name) |
| 131 | 133 |
| 132 def generate_code_internal(self, definitions, definition_name): | 134 def generate_code_internal(self, definitions, definition_name): |
| (...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 252 """Generates union type container classes. | 254 """Generates union type container classes. |
| 253 This generator is different from CodeGeneratorV8 and | 255 This generator is different from CodeGeneratorV8 and |
| 254 CodeGeneratorDictionaryImpl. It assumes that all union types are already | 256 CodeGeneratorDictionaryImpl. It assumes that all union types are already |
| 255 collected. It doesn't process idl files directly. | 257 collected. It doesn't process idl files directly. |
| 256 """ | 258 """ |
| 257 def __init__(self, interfaces_info, cache_dir, output_dir, target_component)
: | 259 def __init__(self, interfaces_info, cache_dir, output_dir, target_component)
: |
| 258 self.interfaces_info = interfaces_info | 260 self.interfaces_info = interfaces_info |
| 259 self.jinja_env = initialize_jinja_env(cache_dir) | 261 self.jinja_env = initialize_jinja_env(cache_dir) |
| 260 self.output_dir = output_dir | 262 self.output_dir = output_dir |
| 261 self.target_component = target_component | 263 self.target_component = target_component |
| 264 set_global_type_info(interfaces_info) |
| 262 | 265 |
| 263 def generate_code(self, union_types): | 266 def generate_code(self, union_types): |
| 264 if not union_types: | 267 if not union_types: |
| 265 return () | 268 return () |
| 266 header_template = self.jinja_env.get_template('union.h') | 269 header_template = self.jinja_env.get_template('union.h') |
| 267 cpp_template = self.jinja_env.get_template('union.cpp') | 270 cpp_template = self.jinja_env.get_template('union.cpp') |
| 268 template_context = v8_union.union_context( | 271 template_context = v8_union.union_context( |
| 269 sorted(union_types, key=lambda union_type: union_type.name)) | 272 sorted(union_types, key=lambda union_type: union_type.name), |
| 273 self.interfaces_info) |
| 270 template_context['code_generator'] = module_pyname | 274 template_context['code_generator'] = module_pyname |
| 271 capitalized_component = self.target_component.capitalize() | 275 capitalized_component = self.target_component.capitalize() |
| 276 template_context['header_filename'] = 'bindings/%s/v8/UnionTypes%s.h' %
( |
| 277 self.target_component, capitalized_component) |
| 272 template_context['macro_guard'] = 'UnionType%s_h' % capitalized_componen
t | 278 template_context['macro_guard'] = 'UnionType%s_h' % capitalized_componen
t |
| 273 header_text = header_template.render(template_context) | 279 header_text = header_template.render(template_context) |
| 274 cpp_text = cpp_template.render(template_context) | 280 cpp_text = cpp_template.render(template_context) |
| 275 header_path = posixpath.join(self.output_dir, | 281 header_path = posixpath.join(self.output_dir, |
| 276 'UnionTypes%s.h' % capitalized_component) | 282 'UnionTypes%s.h' % capitalized_component) |
| 277 cpp_path = posixpath.join(self.output_dir, | 283 cpp_path = posixpath.join(self.output_dir, |
| 278 'UnionTypes%s.cpp' % capitalized_component) | 284 'UnionTypes%s.cpp' % capitalized_component) |
| 279 return ( | 285 return ( |
| 280 (header_path, header_text), | 286 (header_path, header_text), |
| 281 (cpp_path, cpp_text), | 287 (cpp_path, cpp_text), |
| (...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 361 | 367 |
| 362 # Create a dummy file as output for the build system, | 368 # Create a dummy file as output for the build system, |
| 363 # since filenames of individual cache files are unpredictable and opaque | 369 # since filenames of individual cache files are unpredictable and opaque |
| 364 # (they are hashes of the template path, which varies based on environment) | 370 # (they are hashes of the template path, which varies based on environment) |
| 365 with open(dummy_filename, 'w') as dummy_file: | 371 with open(dummy_filename, 'w') as dummy_file: |
| 366 pass # |open| creates or touches the file | 372 pass # |open| creates or touches the file |
| 367 | 373 |
| 368 | 374 |
| 369 if __name__ == '__main__': | 375 if __name__ == '__main__': |
| 370 sys.exit(main(sys.argv)) | 376 sys.exit(main(sys.argv)) |
| OLD | NEW |