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 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
133 'property_attributes': property_attributes(attribute), | 133 'property_attributes': property_attributes(attribute), |
134 'put_forwards': 'PutForwards' in extended_attributes, | 134 'put_forwards': 'PutForwards' in extended_attributes, |
135 'reflect_empty': extended_attributes.get('ReflectEmpty'), | 135 'reflect_empty': extended_attributes.get('ReflectEmpty'), |
136 'reflect_invalid': extended_attributes.get('ReflectInvalid', ''), | 136 'reflect_invalid': extended_attributes.get('ReflectInvalid', ''), |
137 'reflect_missing': extended_attributes.get('ReflectMissing'), | 137 'reflect_missing': extended_attributes.get('ReflectMissing'), |
138 'reflect_only': extended_attributes['ReflectOnly'].split('|') | 138 'reflect_only': extended_attributes['ReflectOnly'].split('|') |
139 if 'ReflectOnly' in extended_attributes else None, | 139 if 'ReflectOnly' in extended_attributes else None, |
140 'runtime_enabled_function': v8_utilities.runtime_enabled_function_name(a
ttribute), # [RuntimeEnabled] | 140 'runtime_enabled_function': v8_utilities.runtime_enabled_function_name(a
ttribute), # [RuntimeEnabled] |
141 'setter_callback': setter_callback_name(interface, attribute), | 141 'setter_callback': setter_callback_name(interface, attribute), |
142 'should_be_exposed_to_script': not (is_implemented_in_private_script and
is_only_exposed_to_private_script), | 142 'should_be_exposed_to_script': not (is_implemented_in_private_script and
is_only_exposed_to_private_script), |
143 'v8_type': v8_types.v8_type(base_idl_type), | |
144 'world_suffixes': ['', 'ForMainWorld'] | 143 'world_suffixes': ['', 'ForMainWorld'] |
145 if 'PerWorldBindings' in extended_attributes | 144 if 'PerWorldBindings' in extended_attributes |
146 else [''], # [PerWorldBindings] | 145 else [''], # [PerWorldBindings] |
147 } | 146 } |
148 | 147 |
149 if is_constructor_attribute(attribute): | 148 if is_constructor_attribute(attribute): |
150 constructor_getter_context(interface, attribute, context) | 149 constructor_getter_context(interface, attribute, context) |
151 return context | 150 return context |
152 if not has_custom_getter(attribute): | 151 if not has_custom_getter(attribute): |
153 getter_context(interface, attribute, context) | 152 getter_context(interface, attribute, context) |
(...skipping 214 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
368 elif idl_type.base_type == 'EventHandler': | 367 elif idl_type.base_type == 'EventHandler': |
369 getter_name = scoped_name(interface, attribute, cpp_name(attribute)) | 368 getter_name = scoped_name(interface, attribute, cpp_name(attribute)) |
370 context['event_handler_getter_expression'] = '%s(%s)' % ( | 369 context['event_handler_getter_expression'] = '%s(%s)' % ( |
371 getter_name, ', '.join(arguments)) | 370 getter_name, ', '.join(arguments)) |
372 if (interface.name in ['Window', 'WorkerGlobalScope'] and | 371 if (interface.name in ['Window', 'WorkerGlobalScope'] and |
373 attribute.name == 'onerror'): | 372 attribute.name == 'onerror'): |
374 includes.add('bindings/core/v8/V8ErrorHandler.h') | 373 includes.add('bindings/core/v8/V8ErrorHandler.h') |
375 arguments.append('V8EventListenerList::findOrCreateWrapper<V8ErrorHa
ndler>(v8Value, true, ScriptState::current(info.GetIsolate()))') | 374 arguments.append('V8EventListenerList::findOrCreateWrapper<V8ErrorHa
ndler>(v8Value, true, ScriptState::current(info.GetIsolate()))') |
376 else: | 375 else: |
377 arguments.append('V8EventListenerList::getEventListener(ScriptState:
:current(info.GetIsolate()), v8Value, true, ListenerFindOrCreate)') | 376 arguments.append('V8EventListenerList::getEventListener(ScriptState:
:current(info.GetIsolate()), v8Value, true, ListenerFindOrCreate)') |
378 elif idl_type.is_interface_type and not idl_type.array_element_type: | 377 elif idl_type.is_interface_type: |
379 # FIXME: should be able to eliminate WTF::getPtr in most or all cases | 378 # FIXME: should be able to eliminate WTF::getPtr in most or all cases |
380 arguments.append('WTF::getPtr(cppValue)') | 379 arguments.append('WTF::getPtr(cppValue)') |
381 else: | 380 else: |
382 arguments.append('cppValue') | 381 arguments.append('cppValue') |
383 if context['is_setter_raises_exception']: | 382 if context['is_setter_raises_exception']: |
384 arguments.append('exceptionState') | 383 arguments.append('exceptionState') |
385 | 384 |
386 return '%s(%s)' % (setter_name, ', '.join(arguments)) | 385 return '%s(%s)' % (setter_name, ', '.join(arguments)) |
387 | 386 |
388 | 387 |
(...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
489 # Constructors | 488 # Constructors |
490 ################################################################################ | 489 ################################################################################ |
491 | 490 |
492 idl_types.IdlType.constructor_type_name = property( | 491 idl_types.IdlType.constructor_type_name = property( |
493 # FIXME: replace this with a [ConstructorAttribute] extended attribute | 492 # FIXME: replace this with a [ConstructorAttribute] extended attribute |
494 lambda self: strip_suffix(self.base_type, 'Constructor')) | 493 lambda self: strip_suffix(self.base_type, 'Constructor')) |
495 | 494 |
496 | 495 |
497 def is_constructor_attribute(attribute): | 496 def is_constructor_attribute(attribute): |
498 # FIXME: replace this with [ConstructorAttribute] extended attribute | 497 # FIXME: replace this with [ConstructorAttribute] extended attribute |
499 return attribute.idl_type.base_type.endswith('Constructor') | 498 return attribute.idl_type.name.endswith('Constructor') |
500 | 499 |
501 | 500 |
502 def constructor_getter_context(interface, attribute, context): | 501 def constructor_getter_context(interface, attribute, context): |
503 context['needs_constructor_getter_callback'] = context['measure_as'] or cont
ext['deprecate_as'] | 502 context['needs_constructor_getter_callback'] = context['measure_as'] or cont
ext['deprecate_as'] |
OLD | NEW |