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

Side by Side Diff: Source/bindings/templates/methods.cpp

Issue 555133003: Use ExceptionState to throw exceptions when converting arrays (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: rebased 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 unified diff | Download patch
OLDNEW
1 {##############################################################################} 1 {##############################################################################}
2 {% macro generate_method(method, world_suffix) %} 2 {% macro generate_method(method, world_suffix) %}
3 {% filter conditional(method.conditional_string) %} 3 {% filter conditional(method.conditional_string) %}
4 static void {{method.name}}{{method.overload_index}}Method{{world_suffix}}(const v8::FunctionCallbackInfo<v8::Value>& info) 4 static void {{method.name}}{{method.overload_index}}Method{{world_suffix}}(const v8::FunctionCallbackInfo<v8::Value>& info)
5 { 5 {
6 {# Local variables #} 6 {# Local variables #}
7 {% if method.has_exception_state %} 7 {% if method.has_exception_state %}
8 ExceptionState exceptionState(ExceptionState::ExecutionContext, "{{method.na me}}", "{{interface_name}}", info.Holder(), info.GetIsolate()); 8 ExceptionState exceptionState(ExceptionState::ExecutionContext, "{{method.na me}}", "{{interface_name}}", info.Holder(), info.GetIsolate());
9 {% endif %} 9 {% endif %}
10 {# Overloaded methods have length checked during overload resolution #} 10 {# Overloaded methods have length checked during overload resolution #}
(...skipping 432 matching lines...) Expand 10 before | Expand all | Expand 10 after
443 {% endif %} 443 {% endif %}
444 {% endif %}{# not method.overloads #} 444 {% endif %}{# not method.overloads #}
445 {% if world_suffix in method.activity_logging_world_list %} 445 {% if world_suffix in method.activity_logging_world_list %}
446 ScriptState* scriptState = ScriptState::from(info.GetIsolate()->GetCurrentCo ntext()); 446 ScriptState* scriptState = ScriptState::from(info.GetIsolate()->GetCurrentCo ntext());
447 V8PerContextData* contextData = scriptState->perContextData(); 447 V8PerContextData* contextData = scriptState->perContextData();
448 {% if method.activity_logging_world_check %} 448 {% if method.activity_logging_world_check %}
449 if (scriptState->world().isIsolatedWorld() && contextData && contextData->ac tivityLogger()) 449 if (scriptState->world().isIsolatedWorld() && contextData && contextData->ac tivityLogger())
450 {% else %} 450 {% else %}
451 if (contextData && contextData->activityLogger()) { 451 if (contextData && contextData->activityLogger()) {
452 {% endif %} 452 {% endif %}
453 Vector<v8::Handle<v8::Value> > loggerArgs = toImplArguments<v8::Handle<v 8::Value> >(info, 0); 453 ExceptionState exceptionState(ExceptionState::ExecutionContext, "{{metho d.name}}", "{{interface_name}}", info.Holder(), info.GetIsolate());
454 Vector<v8::Handle<v8::Value> > loggerArgs = toImplArguments<v8::Handle<v 8::Value> >(info, 0, exceptionState);
454 contextData->activityLogger()->logMethod("{{interface_name}}.{{method.na me}}", info.Length(), loggerArgs.data()); 455 contextData->activityLogger()->logMethod("{{interface_name}}.{{method.na me}}", info.Length(), loggerArgs.data());
455 } 456 }
456 {% endif %} 457 {% endif %}
457 {% if method.is_custom %} 458 {% if method.is_custom %}
458 {{v8_class}}::{{method.name}}MethodCustom(info); 459 {{v8_class}}::{{method.name}}MethodCustom(info);
459 {% else %} 460 {% else %}
460 {{cpp_class}}V8Internal::{{method.name}}Method{{world_suffix}}(info); 461 {{cpp_class}}V8Internal::{{method.name}}Method{{world_suffix}}(info);
461 {% endif %} 462 {% endif %}
462 TRACE_EVENT_SET_SAMPLING_STATE("v8", "V8Execution"); 463 TRACE_EVENT_SET_SAMPLING_STATE("v8", "V8Execution");
463 } 464 }
(...skipping 163 matching lines...) Expand 10 before | Expand all | Expand 10 after
627 if method.is_per_world_bindings else '0' %} 628 if method.is_per_world_bindings else '0' %}
628 {% set property_attribute = 629 {% set property_attribute =
629 'static_cast<v8::PropertyAttribute>(%s)' % ' | '.join(method.property_attribut es) 630 'static_cast<v8::PropertyAttribute>(%s)' % ' | '.join(method.property_attribut es)
630 if method.property_attributes else 'v8::None' %} 631 if method.property_attributes else 'v8::None' %}
631 {% set only_exposed_to_private_script = 'V8DOMConfiguration::OnlyExposedToPrivat eScript' if method.only_exposed_to_private_script else 'V8DOMConfiguration::Expo sedToAllScripts' %} 632 {% set only_exposed_to_private_script = 'V8DOMConfiguration::OnlyExposedToPrivat eScript' if method.only_exposed_to_private_script else 'V8DOMConfiguration::Expo sedToAllScripts' %}
632 static const V8DOMConfiguration::MethodConfiguration {{method.name}}MethodConfig uration = { 633 static const V8DOMConfiguration::MethodConfiguration {{method.name}}MethodConfig uration = {
633 "{{method.name}}", {{method_callback}}, {{method_callback_for_main_world}}, {{method.length}}, {{only_exposed_to_private_script}}, 634 "{{method.name}}", {{method_callback}}, {{method_callback_for_main_world}}, {{method.length}}, {{only_exposed_to_private_script}},
634 }; 635 };
635 V8DOMConfiguration::installMethod({{method.function_template}}, {{method.signatu re}}, {{property_attribute}}, {{method.name}}MethodConfiguration, isolate); 636 V8DOMConfiguration::installMethod({{method.function_template}}, {{method.signatu re}}, {{property_attribute}}, {{method.name}}MethodConfiguration, isolate);
636 {%- endmacro %} 637 {%- endmacro %}
OLDNEW
« no previous file with comments | « Source/bindings/scripts/v8_types.py ('k') | Source/bindings/tests/results/core/V8TestInterfaceConstructor.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698