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

Side by Side Diff: Source/bindings/scripts/v8_union.py

Issue 1086113002: IDL: Improve "includes for type" mechanism in various ways (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 8 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 unified diff | Download patch
OLDNEW
1 # Copyright 2014 The Chromium Authors. All rights reserved. 1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import v8_utilities 5 import v8_utilities
6 6
7 7
8 UNION_H_INCLUDES = frozenset([ 8 UNION_H_INCLUDES = frozenset([
9 'bindings/core/v8/Dictionary.h', 9 'bindings/core/v8/Dictionary.h',
10 'bindings/core/v8/ExceptionState.h', 10 'bindings/core/v8/ExceptionState.h',
(...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after
122 'interface_types': interface_types, 122 'interface_types': interface_types,
123 'members': members, 123 'members': members,
124 'needs_trace': any(member['is_traceable'] for member in members), 124 'needs_trace': any(member['is_traceable'] for member in members),
125 'numeric_type': numeric_type, 125 'numeric_type': numeric_type,
126 'string_type': string_type, 126 'string_type': string_type,
127 'type_string': str(union_type), 127 'type_string': str(union_type),
128 } 128 }
129 129
130 130
131 def member_context(member, interfaces_info): 131 def member_context(member, interfaces_info):
132 cpp_includes.update(member.includes_for_type) 132 cpp_includes.update(member.includes_for_type())
133 interface_info = interfaces_info.get(member.name, None) 133 interface_info = interfaces_info.get(member.name, None)
134 if interface_info: 134 if interface_info:
135 cpp_includes.update(interface_info.get('dependencies_include_paths', []) ) 135 cpp_includes.update(interface_info.get('dependencies_include_paths', []) )
136 header_forward_decls.add(member.implemented_as) 136 header_forward_decls.add(member.implemented_as)
137 if member.is_nullable: 137 if member.is_nullable:
138 member = member.inner_type 138 member = member.inner_type
139 return { 139 return {
140 'cpp_name': v8_utilities.uncapitalize(member.name), 140 'cpp_name': v8_utilities.uncapitalize(member.name),
141 'cpp_type': member.cpp_type_args(used_in_cpp_sequence=True), 141 'cpp_type': member.cpp_type_args(used_in_cpp_sequence=True),
142 'cpp_local_type': member.cpp_type, 142 'cpp_local_type': member.cpp_type,
143 'cpp_value_to_v8_value': member.cpp_value_to_v8_value( 143 'cpp_value_to_v8_value': member.cpp_value_to_v8_value(
144 cpp_value='impl.getAs%s()' % member.name, isolate='isolate', 144 cpp_value='impl.getAs%s()' % member.name, isolate='isolate',
145 creation_context='creationContext'), 145 creation_context='creationContext'),
146 'enum_values': member.enum_values, 146 'enum_values': member.enum_values,
147 'is_traceable': member.is_traceable, 147 'is_traceable': member.is_traceable,
148 'rvalue_cpp_type': member.cpp_type_args(used_as_rvalue_type=True), 148 'rvalue_cpp_type': member.cpp_type_args(used_as_rvalue_type=True),
149 'specific_type_enum': 'SpecificType' + member.name, 149 'specific_type_enum': 'SpecificType' + member.name,
150 'type_name': member.name, 150 'type_name': member.name,
151 'v8_value_to_local_cpp_value': member.v8_value_to_local_cpp_value( 151 'v8_value_to_local_cpp_value': member.v8_value_to_local_cpp_value(
152 {}, 'v8Value', 'cppValue', isolate='isolate', 152 {}, 'v8Value', 'cppValue', isolate='isolate',
153 use_exception_state=True, restricted_float=True), 153 use_exception_state=True, restricted_float=True),
154 } 154 }
OLDNEW
« no previous file with comments | « Source/bindings/scripts/v8_types.py ('k') | Source/bindings/tests/results/core/V8TestInterface.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698