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

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

Issue 1054443002: Make classes for union types exported. (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',
11 'bindings/core/v8/V8Binding.h', 11 'bindings/core/v8/V8Binding.h',
12 'platform/heap/Handle.h', 12 'platform/heap/Handle.h',
13 ]) 13 ])
14 14
15 UNION_CPP_INCLUDES_BLACKLIST = frozenset([ 15 UNION_CPP_INCLUDES_BLACKLIST = frozenset([
16 # This header defines static functions needed to implement event handler 16 # This header defines static functions needed to implement event handler
17 # attributes in interfaces that implement GlobalEventHandlers. They are not 17 # attributes in interfaces that implement GlobalEventHandlers. They are not
18 # needed or used by UnionTypes*.cpp, so including the header causes 18 # needed or used by UnionTypes*.cpp, so including the header causes
19 # compilation errors. 19 # compilation errors.
20 # FIXME: We should solve this problem in a way that doesn't involve special- 20 # FIXME: We should solve this problem in a way that doesn't involve special-
21 # casing a header like this. 21 # casing a header like this.
22 'core/dom/GlobalEventHandlers.h', 22 'core/dom/GlobalEventHandlers.h',
23 ]) 23 ])
24 24
25 25
26 cpp_includes = set() 26 cpp_includes = set()
27 header_forward_decls = set() 27 header_forward_decls = set()
28 28
29 29
30 def union_context(union_types, interfaces_info): 30 def union_context(union_types, interfaces_info, component):
bashi 2015/04/01 07:16:51 nit: we generally put component-specific logic in
tasak 2015/04/02 05:31:36 Done.
31 cpp_includes.clear() 31 cpp_includes.clear()
32 header_forward_decls.clear() 32 header_forward_decls.clear()
33 header_includes = set()
34 header_includes.update(UNION_H_INCLUDES)
33 35
34 # For container classes we strip nullable wrappers. For example, 36 # For container classes we strip nullable wrappers. For example,
35 # both (A or B)? and (A? or B) will become AOrB. This should be OK 37 # both (A or B)? and (A? or B) will become AOrB. This should be OK
36 # because container classes can handle null and it seems that 38 # because container classes can handle null and it seems that
37 # distinguishing (A or B)? and (A? or B) doesn't make sense. 39 # distinguishing (A or B)? and (A? or B) doesn't make sense.
38 container_cpp_types = set() 40 container_cpp_types = set()
39 union_types_for_containers = set() 41 union_types_for_containers = set()
40 nullable_cpp_types = set() 42 nullable_cpp_types = set()
41 for union_type in union_types: 43 for union_type in union_types:
42 cpp_type = union_type.cpp_type 44 cpp_type = union_type.cpp_type
43 if cpp_type not in container_cpp_types: 45 if cpp_type not in container_cpp_types:
44 union_types_for_containers.add(union_type) 46 union_types_for_containers.add(union_type)
45 container_cpp_types.add(cpp_type) 47 container_cpp_types.add(cpp_type)
46 if union_type.includes_nullable_type: 48 if union_type.includes_nullable_type:
47 nullable_cpp_types.add(cpp_type) 49 nullable_cpp_types.add(cpp_type)
48 50
49 union_types_for_containers = sorted(union_types_for_containers, 51 union_types_for_containers = sorted(union_types_for_containers,
50 key=lambda union_type: union_type.cpp_ty pe) 52 key=lambda union_type: union_type.cpp_ty pe)
51 nullable_cpp_types = sorted(nullable_cpp_types) 53 nullable_cpp_types = sorted(nullable_cpp_types)
54 header_includes.add('%s/%sExport.h' % (component, component.capitalize()))
bashi 2015/04/01 07:16:51 nit: how about adding ComonentInfo.include_path_fo
tasak 2015/04/02 05:31:36 Done.
52 55
53 return { 56 return {
54 'containers': [container_context(union_type, interfaces_info) 57 'containers': [container_context(union_type, interfaces_info)
55 for union_type in union_types_for_containers], 58 for union_type in union_types_for_containers],
56 'cpp_includes': sorted(cpp_includes - UNION_CPP_INCLUDES_BLACKLIST), 59 'cpp_includes': sorted(cpp_includes - UNION_CPP_INCLUDES_BLACKLIST),
57 'header_forward_decls': sorted(header_forward_decls), 60 'header_forward_decls': sorted(header_forward_decls),
58 'header_includes': sorted(UNION_H_INCLUDES), 61 'header_includes': sorted(header_includes),
59 'nullable_cpp_types': nullable_cpp_types, 62 'nullable_cpp_types': nullable_cpp_types,
63 'exported': '%s_EXPORT ' % component.upper(),
bashi 2015/04/01 07:16:51 nit: I'd prefer dropping the trailing space and ad
bashi 2015/04/01 07:16:51 nit: alphabetical order.
tasak 2015/04/02 05:31:36 Moved 'exported' in the almost same way as Compone
tasak 2015/04/02 05:31:36 Temporarily I would like to use the trailing space
60 } 64 }
61 65
62 66
63 def container_context(union_type, interfaces_info): 67 def container_context(union_type, interfaces_info):
64 members = [] 68 members = []
65 69
66 # These variables refer to member contexts if the given union type has 70 # These variables refer to member contexts if the given union type has
67 # corresponding types. They are used for V8 -> impl conversion. 71 # corresponding types. They are used for V8 -> impl conversion.
68 array_buffer_type = None 72 array_buffer_type = None
69 array_buffer_view_type = None 73 array_buffer_view_type = None
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after
145 creation_context='creationContext'), 149 creation_context='creationContext'),
146 'enum_validation_expression': member.enum_validation_expression, 150 'enum_validation_expression': member.enum_validation_expression,
147 'is_traceable': member.is_traceable, 151 'is_traceable': member.is_traceable,
148 'rvalue_cpp_type': member.cpp_type_args(used_as_rvalue_type=True), 152 'rvalue_cpp_type': member.cpp_type_args(used_as_rvalue_type=True),
149 'specific_type_enum': 'SpecificType' + member.name, 153 'specific_type_enum': 'SpecificType' + member.name,
150 'type_name': member.name, 154 'type_name': member.name,
151 'v8_value_to_local_cpp_value': member.v8_value_to_local_cpp_value( 155 'v8_value_to_local_cpp_value': member.v8_value_to_local_cpp_value(
152 {}, 'v8Value', 'cppValue', isolate='isolate', 156 {}, 'v8Value', 'cppValue', isolate='isolate',
153 use_exception_state=True, restricted_float=True), 157 use_exception_state=True, restricted_float=True),
154 } 158 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698