Index: trunk/Source/bindings/tests/results/V8TestInterface.cpp |
=================================================================== |
--- trunk/Source/bindings/tests/results/V8TestInterface.cpp (revision 170423) |
+++ trunk/Source/bindings/tests/results/V8TestInterface.cpp (working copy) |
@@ -5,17 +5,19 @@ |
// This file has been auto-generated by code_generator_v8.py. DO NOT MODIFY! |
#include "config.h" |
-#if ENABLE(Condition1) || ENABLE(Condition2) |
+#if ENABLE(CONDITION) |
#include "V8TestInterface.h" |
#include "RuntimeEnabledFeatures.h" |
#include "V8Node.h" |
-#include "V8NodeList.h" |
+#include "V8TestImplementedAs.h" |
#include "V8TestInterfaceEmpty.h" |
-#include "V8TestObject.h" |
#include "bindings/tests/idls/TestImplements.h" |
+#include "bindings/tests/idls/TestImplements2Implementation.h" |
#include "bindings/tests/idls/TestPartialInterface.h" |
+#include "bindings/tests/idls/TestPartialInterfaceImplementation.h" |
#include "bindings/v8/ExceptionState.h" |
+#include "bindings/v8/ScriptValue.h" |
#include "bindings/v8/V8AbstractEventListener.h" |
#include "bindings/v8/V8DOMConfiguration.h" |
#include "bindings/v8/V8EventListenerList.h" |
@@ -23,14 +25,13 @@ |
#include "bindings/v8/V8ObjectConstructor.h" |
#include "core/dom/ContextFeatures.h" |
#include "core/dom/Document.h" |
-#include "core/frame/DOMWindow.h" |
#include "platform/TraceEvent.h" |
#include "wtf/GetPtr.h" |
#include "wtf/RefPtr.h" |
namespace WebCore { |
-static void initializeScriptWrappableForInterface(TestInterface* object) |
+static void initializeScriptWrappableForInterface(TestInterfaceImplementation* object) |
{ |
if (ScriptWrappable::wrapperCanBeStoredInObject(object)) |
ScriptWrappable::setTypeInfoInObject(object, &V8TestInterface::wrapperTypeInfo); |
@@ -40,18 +41,136 @@ |
} // namespace WebCore |
-void webCoreInitializeScriptWrappableForInterface(WebCore::TestInterface* object) |
+void webCoreInitializeScriptWrappableForInterface(WebCore::TestInterfaceImplementation* object) |
{ |
WebCore::initializeScriptWrappableForInterface(object); |
} |
namespace WebCore { |
-const WrapperTypeInfo V8TestInterface::wrapperTypeInfo = { gin::kEmbedderBlink, V8TestInterface::domTemplate, V8TestInterface::derefObject, V8TestInterface::toActiveDOMObject, 0, V8TestInterface::visitDOMWrapper, V8TestInterface::installPerContextEnabledMethods, 0, WrapperTypeObjectPrototype, false }; |
+const WrapperTypeInfo V8TestInterface::wrapperTypeInfo = { gin::kEmbedderBlink, V8TestInterface::domTemplate, V8TestInterface::derefObject, V8TestInterface::toActiveDOMObject, 0, V8TestInterface::visitDOMWrapper, V8TestInterface::installPerContextEnabledMethods, &V8TestInterfaceEmpty::wrapperTypeInfo, WrapperTypeObjectPrototype, false }; |
-namespace TestInterfaceV8Internal { |
+namespace TestInterfaceImplementationV8Internal { |
template <typename T> void V8_USE(T) { } |
+static void testInterfaceAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ v8SetReturnValueFast(info, WTF::getPtr(impl->testInterfaceAttribute()), impl); |
+} |
+ |
+static void testInterfaceAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::testInterfaceAttributeAttributeGetter(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void testInterfaceAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "testInterfaceAttribute", "TestInterface", holder, info.GetIsolate()); |
+ if (!isUndefinedOrNull(v8Value) && !V8TestInterface::hasInstance(v8Value, info.GetIsolate())) { |
+ exceptionState.throwTypeError("The provided value is not of type 'TestInterface'."); |
+ exceptionState.throwIfNeeded(); |
+ return; |
+ } |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ V8TRYCATCH_VOID(TestInterfaceImplementation*, cppValue, V8TestInterface::toNativeWithTypeCheck(info.GetIsolate(), v8Value)); |
+ impl->setTestInterfaceAttribute(WTF::getPtr(cppValue)); |
+} |
+ |
+static void testInterfaceAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::testInterfaceAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void staticStringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8SetReturnValueString(info, TestInterfaceImplementation::staticStringAttribute(), info.GetIsolate()); |
+} |
+ |
+static void staticStringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::staticStringAttributeAttributeGetter(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void staticStringAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
+ TestInterfaceImplementation::setStaticStringAttribute(cppValue); |
+} |
+ |
+static void staticStringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::staticStringAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ v8SetReturnValueString(info, impl->perWorldBindingsStringAttribute(), info.GetIsolate()); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeGetter(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
+ impl->setPerWorldBindingsStringAttribute(cppValue); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeGetterForMainWorld(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ v8SetReturnValueString(info, impl->perWorldBindingsStringAttribute(), info.GetIsolate()); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeGetterCallbackForMainWorld(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeGetterForMainWorld(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeSetterForMainWorld(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
+ impl->setPerWorldBindingsStringAttribute(cppValue); |
+} |
+ |
+static void perWorldBindingsStringAttributeAttributeSetterCallbackForMainWorld(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeSetterForMainWorld(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
static void implementsStaticReadOnlyLongAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8SetReturnValueInt(info, TestImplements::implementsStaticReadOnlyLongAttribute()); |
@@ -60,7 +179,7 @@ |
static void implementsStaticReadOnlyLongAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsStaticReadOnlyLongAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsStaticReadOnlyLongAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
@@ -72,7 +191,7 @@ |
static void implementsStaticStringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsStaticStringAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsStaticStringAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
@@ -85,14 +204,14 @@ |
static void implementsStaticStringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::implementsStaticStringAttributeAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::implementsStaticStringAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsReadonlyStringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
v8SetReturnValueString(info, TestImplements::implementsReadonlyStringAttribute(*impl), info.GetIsolate()); |
} |
@@ -100,14 +219,14 @@ |
static void implementsReadonlyStringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsReadonlyStringAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsReadonlyStringAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsStringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
v8SetReturnValueString(info, TestImplements::implementsStringAttribute(*impl), info.GetIsolate()); |
} |
@@ -115,14 +234,14 @@ |
static void implementsStringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsStringAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsStringAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsStringAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
TestImplements::setImplementsStringAttribute(*impl, cppValue); |
@@ -131,14 +250,14 @@ |
static void implementsStringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::implementsStringAttributeAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::implementsStringAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsNodeAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
v8SetReturnValueFast(info, WTF::getPtr(TestImplements::implementsNodeAttribute(*impl)), impl); |
} |
@@ -146,14 +265,20 @@ |
static void implementsNodeAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsNodeAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsNodeAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsNodeAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "implementsNodeAttribute", "TestInterface", holder, info.GetIsolate()); |
+ if (!isUndefinedOrNull(v8Value) && !V8Node::hasInstance(v8Value, info.GetIsolate())) { |
+ exceptionState.throwTypeError("The provided value is not of type 'Node'."); |
+ exceptionState.throwIfNeeded(); |
+ return; |
+ } |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
V8TRYCATCH_VOID(Node*, cppValue, V8Node::toNativeWithTypeCheck(info.GetIsolate(), v8Value)); |
TestImplements::setImplementsNodeAttribute(*impl, WTF::getPtr(cppValue)); |
@@ -162,14 +287,14 @@ |
static void implementsNodeAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::implementsNodeAttributeAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::implementsNodeAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsEventHandlerAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
EventListener* v8Value = TestImplements::implementsEventHandlerAttribute(*impl); |
v8SetReturnValue(info, v8Value ? v8::Handle<v8::Value>(V8AbstractEventListener::cast(v8Value)->getListenerObject(impl->executionContext())) : v8::Handle<v8::Value>(v8::Null(info.GetIsolate()))); |
@@ -178,14 +303,14 @@ |
static void implementsEventHandlerAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsEventHandlerAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsEventHandlerAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsEventHandlerAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
moveEventListenerToNewWrapper(holder, TestImplements::implementsEventHandlerAttribute(*impl), v8Value, V8TestInterface::eventListenerCacheIndex, info.GetIsolate()); |
TestImplements::setImplementsEventHandlerAttribute(*impl, V8EventListenerList::getEventListener(v8Value, true, ListenerFindOrCreate)); |
@@ -194,14 +319,14 @@ |
static void implementsEventHandlerAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::implementsEventHandlerAttributeAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::implementsEventHandlerAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsRuntimeEnabledNodeAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
v8SetReturnValueFast(info, WTF::getPtr(TestImplements::implementsRuntimeEnabledNodeAttribute(*impl)), impl); |
} |
@@ -209,14 +334,20 @@ |
static void implementsRuntimeEnabledNodeAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsRuntimeEnabledNodeAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsRuntimeEnabledNodeAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsRuntimeEnabledNodeAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "implementsRuntimeEnabledNodeAttribute", "TestInterface", holder, info.GetIsolate()); |
+ if (!isUndefinedOrNull(v8Value) && !V8Node::hasInstance(v8Value, info.GetIsolate())) { |
+ exceptionState.throwTypeError("The provided value is not of type 'Node'."); |
+ exceptionState.throwIfNeeded(); |
+ return; |
+ } |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
V8TRYCATCH_VOID(Node*, cppValue, V8Node::toNativeWithTypeCheck(info.GetIsolate(), v8Value)); |
TestImplements::setImplementsRuntimeEnabledNodeAttribute(*impl, WTF::getPtr(cppValue)); |
@@ -225,14 +356,14 @@ |
static void implementsRuntimeEnabledNodeAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::implementsRuntimeEnabledNodeAttributeAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::implementsRuntimeEnabledNodeAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsPerContextEnabledNodeAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
v8SetReturnValueFast(info, WTF::getPtr(TestImplements::implementsPerContextEnabledNodeAttribute(*impl)), impl); |
} |
@@ -240,14 +371,20 @@ |
static void implementsPerContextEnabledNodeAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::implementsPerContextEnabledNodeAttributeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implementsPerContextEnabledNodeAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void implementsPerContextEnabledNodeAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "implementsPerContextEnabledNodeAttribute", "TestInterface", holder, info.GetIsolate()); |
+ if (!isUndefinedOrNull(v8Value) && !V8Node::hasInstance(v8Value, info.GetIsolate())) { |
+ exceptionState.throwTypeError("The provided value is not of type 'Node'."); |
+ exceptionState.throwIfNeeded(); |
+ return; |
+ } |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
V8TRYCATCH_VOID(Node*, cppValue, V8Node::toNativeWithTypeCheck(info.GetIsolate(), v8Value)); |
TestImplements::setImplementsPerContextEnabledNodeAttribute(*impl, WTF::getPtr(cppValue)); |
@@ -256,229 +393,407 @@ |
static void implementsPerContextEnabledNodeAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::implementsPerContextEnabledNodeAttributeAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::implementsPerContextEnabledNodeAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStaticReadOnlyAttrAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+static void implements2StaticStringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
- v8SetReturnValueInt(info, TestPartialInterface::supplementalStaticReadOnlyAttr()); |
+ v8SetReturnValueString(info, TestImplements2Implementation::implements2StaticStringAttribute(), info.GetIsolate()); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStaticReadOnlyAttrAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+static void implements2StaticStringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::supplementalStaticReadOnlyAttrAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implements2StaticStringAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStaticAttrAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+static void implements2StaticStringAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
- v8SetReturnValueString(info, TestPartialInterface::supplementalStaticAttr(), info.GetIsolate()); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
+ TestImplements2Implementation::setImplements2StaticStringAttribute(cppValue); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStaticAttrAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+static void implements2StaticStringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::implements2StaticStringAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void implements2StringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ ASSERT(impl); |
+ v8SetReturnValueString(info, TestImplements2Implementation::implements2StringAttribute(*impl), info.GetIsolate()); |
+} |
+ |
+static void implements2StringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::supplementalStaticAttrAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::implements2StringAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStaticAttrAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+static void implements2StringAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ ASSERT(impl); |
V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
- TestPartialInterface::setSupplementalStaticAttr(cppValue); |
+ TestImplements2Implementation::setImplements2StringAttribute(*impl, cppValue); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStaticAttrAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+static void implements2StringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::supplementalStaticAttrAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::implements2StringAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStr1AttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+static void implements3StringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ v8SetReturnValueString(info, impl->implements3StringAttribute(), info.GetIsolate()); |
+} |
+ |
+static void implements3StringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::implements3StringAttributeAttributeGetter(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void implements3StringAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
+ impl->setImplements3StringAttribute(cppValue); |
+} |
+ |
+static void implements3StringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::implements3StringAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void implements3StaticStringAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8SetReturnValueString(info, TestInterfaceImplementation::implements3StaticStringAttribute(), info.GetIsolate()); |
+} |
+ |
+static void implements3StaticStringAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::implements3StaticStringAttributeAttributeGetter(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void implements3StaticStringAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
+ TestInterfaceImplementation::setImplements3StaticStringAttribute(cppValue); |
+} |
+ |
+static void implements3StaticStringAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::implements3StaticStringAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialLongAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
- v8SetReturnValueString(info, TestPartialInterface::supplementalStr1(*impl), info.GetIsolate()); |
+ v8SetReturnValueInt(info, TestPartialInterface::partialLongAttribute(*impl)); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStr1AttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialLongAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::supplementalStr1AttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::partialLongAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStr2AttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialLongAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "partialLongAttribute", "TestInterface", holder, info.GetIsolate()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
- v8SetReturnValueString(info, TestPartialInterface::supplementalStr2(*impl), info.GetIsolate()); |
+ V8TRYCATCH_EXCEPTION_VOID(int, cppValue, toInt32(v8Value, exceptionState), exceptionState); |
+ TestPartialInterface::setPartialLongAttribute(*impl, cppValue); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStr2AttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialLongAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::partialLongAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialStaticLongAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8SetReturnValueInt(info, TestPartialInterface::partialStaticLongAttribute()); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialStaticLongAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::supplementalStr2AttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::partialStaticLongAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStr2AttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialStaticLongAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "partialStaticLongAttribute", "TestInterface", holder, info.GetIsolate()); |
+ V8TRYCATCH_EXCEPTION_VOID(int, cppValue, toInt32(v8Value, exceptionState), exceptionState); |
+ TestPartialInterface::setPartialStaticLongAttribute(cppValue); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialStaticLongAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::partialStaticLongAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialCallWithExecutionContextLongAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
- V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
- TestPartialInterface::setSupplementalStr2(*impl, cppValue); |
+ ExecutionContext* scriptContext = currentExecutionContext(info.GetIsolate()); |
+ v8SetReturnValueInt(info, TestPartialInterface::partialCallWithExecutionContextLongAttribute(scriptContext, *impl)); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalStr2AttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialCallWithExecutionContextLongAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::partialCallWithExecutionContextLongAttributeAttributeGetter(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialCallWithExecutionContextLongAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ v8::Handle<v8::Object> holder = info.Holder(); |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "partialCallWithExecutionContextLongAttribute", "TestInterface", holder, info.GetIsolate()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
+ ASSERT(impl); |
+ V8TRYCATCH_EXCEPTION_VOID(int, cppValue, toInt32(v8Value, exceptionState), exceptionState); |
+ ExecutionContext* scriptContext = currentExecutionContext(info.GetIsolate()); |
+ TestPartialInterface::setPartialCallWithExecutionContextLongAttribute(scriptContext, *impl, cppValue); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialCallWithExecutionContextLongAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::supplementalStr2AttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::partialCallWithExecutionContextLongAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalNodeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialPartialEnumTypeAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
- v8SetReturnValueFast(info, WTF::getPtr(TestPartialInterface::supplementalNode(*impl)), impl); |
+ v8SetReturnValueString(info, TestPartialInterface::partialPartialEnumTypeAttribute(*impl), info.GetIsolate()); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalNodeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialPartialEnumTypeAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::supplementalNodeAttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::partialPartialEnumTypeAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalNodeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialPartialEnumTypeAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
- V8TRYCATCH_VOID(Node*, cppValue, V8Node::toNativeWithTypeCheck(info.GetIsolate(), v8Value)); |
- TestPartialInterface::setSupplementalNode(*impl, WTF::getPtr(cppValue)); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, cppValue, v8Value); |
+ String string = cppValue; |
+ if (!(string == "foo" || string == "bar")) |
+ return; |
+ TestPartialInterface::setPartialPartialEnumTypeAttribute(*impl, cppValue); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalNodeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialPartialEnumTypeAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::supplementalNodeAttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::partialPartialEnumTypeAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void Node13AttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
+static void partial2LongAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
- v8SetReturnValueFast(info, WTF::getPtr(TestPartialInterface::node13(*impl)), impl); |
+ v8SetReturnValueInt(info, TestPartialInterfaceImplementation::partial2LongAttribute(*impl)); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void Node13AttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+static void partial2LongAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
- TestInterfaceV8Internal::Node13AttributeGetter(info); |
+ TestInterfaceImplementationV8Internal::partial2LongAttributeAttributeGetter(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void Node13AttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+static void partial2LongAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
v8::Handle<v8::Object> holder = info.Holder(); |
- TestInterface* impl = V8TestInterface::toNative(holder); |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "partial2LongAttribute", "TestInterface", holder, info.GetIsolate()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(holder); |
ASSERT(impl); |
- V8TRYCATCH_VOID(Node*, cppValue, V8Node::toNativeWithTypeCheck(info.GetIsolate(), v8Value)); |
- TestPartialInterface::setNode13(*impl, WTF::getPtr(cppValue)); |
+ V8TRYCATCH_EXCEPTION_VOID(int, cppValue, toInt32(v8Value, exceptionState), exceptionState); |
+ TestPartialInterfaceImplementation::setPartial2LongAttribute(*impl, cppValue); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void Node13AttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+static void partial2LongAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
- TestInterfaceV8Internal::Node13AttributeSetter(v8Value, info); |
+ TestInterfaceImplementationV8Internal::partial2LongAttributeAttributeSetter(v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-static void namedItemMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void partial2StaticLongAttributeAttributeGetter(const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
+ v8SetReturnValueInt(info, TestPartialInterfaceImplementation::partial2StaticLongAttribute()); |
+} |
+ |
+static void partial2StaticLongAttributeAttributeGetterCallback(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMGetter"); |
+ TestInterfaceImplementationV8Internal::partial2StaticLongAttributeAttributeGetter(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void partial2StaticLongAttributeAttributeSetter(v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ ExceptionState exceptionState(ExceptionState::SetterContext, "partial2StaticLongAttribute", "TestInterface", holder, info.GetIsolate()); |
+ V8TRYCATCH_EXCEPTION_VOID(int, cppValue, toInt32(v8Value, exceptionState), exceptionState); |
+ TestPartialInterfaceImplementation::setPartial2StaticLongAttribute(cppValue); |
+} |
+ |
+static void partial2StaticLongAttributeAttributeSetterCallback(v8::Local<v8::String>, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMSetter"); |
+ TestInterfaceImplementationV8Internal::partial2StaticLongAttributeAttributeSetter(v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void TestInterfaceImplementationConstructorGetter(v8::Local<v8::String>, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ v8::Handle<v8::Value> data = info.Data(); |
+ ASSERT(data->IsExternal()); |
+ V8PerContextData* perContextData = V8PerContextData::from(info.Holder()->CreationContext()); |
+ if (!perContextData) |
+ return; |
+ v8SetReturnValue(info, perContextData->constructorForType(WrapperTypeInfo::unwrap(data))); |
+} |
+ |
+static void TestInterfaceImplementationReplaceableAttributeSetter(v8::Local<v8::String> name, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ info.This()->ForceSet(name, v8Value); |
+} |
+ |
+static void TestInterfaceImplementationReplaceableAttributeSetterCallback(v8::Local<v8::String> name, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<void>& info) |
+{ |
+ TestInterfaceImplementationV8Internal::TestInterfaceImplementationReplaceableAttributeSetter(name, v8Value, info); |
+} |
+ |
+static void voidMethodTestInterfaceEmptyArgMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
if (UNLIKELY(info.Length() < 1)) { |
- throwTypeError(ExceptionMessages::failedToExecute("namedItem", "TestInterface", ExceptionMessages::notEnoughArguments(1, info.Length())), info.GetIsolate()); |
+ throwTypeError(ExceptionMessages::failedToExecute("voidMethodTestInterfaceEmptyArg", "TestInterface", ExceptionMessages::notEnoughArguments(1, info.Length())), info.GetIsolate()); |
return; |
} |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
- V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, name, info[0]); |
- bool result0Enabled = false; |
- RefPtr<Node> result0; |
- bool result1Enabled = false; |
- RefPtr<NodeList> result1; |
- impl->getItem(name, result0Enabled, result0, result1Enabled, result1); |
- if (result0Enabled) { |
- v8SetReturnValue(info, result0.release()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ if (info.Length() > 0 && !V8TestInterfaceEmpty::hasInstance(info[0], info.GetIsolate())) { |
+ throwTypeError(ExceptionMessages::failedToExecute("voidMethodTestInterfaceEmptyArg", "TestInterface", "parameter 1 is not of type 'TestInterfaceEmpty'."), info.GetIsolate()); |
return; |
} |
- if (result1Enabled) { |
- v8SetReturnValue(info, result1.release()); |
- return; |
- } |
- v8SetReturnValueNull(info); |
+ V8TRYCATCH_VOID(TestInterfaceEmpty*, testInterfaceEmptyArg, V8TestInterfaceEmpty::toNativeWithTypeCheck(info.GetIsolate(), info[0])); |
+ impl->voidMethodTestInterfaceEmptyArg(testInterfaceEmptyArg); |
} |
-static void namedItemMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void voidMethodTestInterfaceEmptyArgMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- TestInterfaceV8Internal::namedItemMethod(info); |
+ TestInterfaceImplementationV8Internal::voidMethodTestInterfaceEmptyArgMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
+static void voidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ impl->voidMethod(); |
+} |
+ |
+static void voidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::voidMethodMethod(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void voidMethodMethodForMainWorld(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ impl->voidMethod(); |
+} |
+ |
+static void voidMethodMethodCallbackForMainWorld(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::voidMethodMethodForMainWorld(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
static void implementsVoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
ASSERT(impl); |
TestImplements::implementsVoidMethod(*impl); |
} |
@@ -486,7 +801,7 @@ |
static void implementsVoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- TestInterfaceV8Internal::implementsVoidMethodMethod(info); |
+ TestInterfaceImplementationV8Internal::implementsVoidMethodMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
@@ -498,8 +813,13 @@ |
exceptionState.throwIfNeeded(); |
return; |
} |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, strArg, info[0]); |
+ if (info.Length() > 1 && !V8TestInterfaceEmpty::hasInstance(info[1], info.GetIsolate())) { |
+ exceptionState.throwTypeError("parameter 2 is not of type 'TestInterfaceEmpty'."); |
+ exceptionState.throwIfNeeded(); |
+ return; |
+ } |
V8TRYCATCH_VOID(TestInterfaceEmpty*, testInterfaceEmptyArg, V8TestInterfaceEmpty::toNativeWithTypeCheck(info.GetIsolate(), info[1])); |
ASSERT(impl); |
ExecutionContext* scriptContext = currentExecutionContext(info.GetIsolate()); |
@@ -512,7 +832,7 @@ |
static void implementsComplexMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- TestInterfaceV8Internal::implementsComplexMethodMethod(info); |
+ TestInterfaceImplementationV8Internal::implementsComplexMethodMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
@@ -531,104 +851,227 @@ |
static void implementsStaticVoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- TestInterfaceV8Internal::implementsStaticVoidMethodMethod(info); |
+ TestInterfaceImplementationV8Internal::implementsStaticVoidMethodMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalMethod1Method(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void implements2VoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
ASSERT(impl); |
- TestPartialInterface::supplementalMethod1(*impl); |
+ TestImplements2Implementation::implements2VoidMethod(*impl); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalMethod1MethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void implements2VoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- TestInterfaceV8Internal::supplementalMethod1Method(info); |
+ TestInterfaceImplementationV8Internal::implements2VoidMethodMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalMethod2Method(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void implements3VoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
- ExceptionState exceptionState(ExceptionState::ExecutionContext, "supplementalMethod2", "TestInterface", info.Holder(), info.GetIsolate()); |
- if (UNLIKELY(info.Length() < 2)) { |
- exceptionState.throwTypeError(ExceptionMessages::notEnoughArguments(2, info.Length())); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ impl->implements3VoidMethod(); |
+} |
+ |
+static void implements3VoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::implements3VoidMethodMethod(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void implements3StaticVoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TestInterfaceImplementation::implements3StaticVoidMethod(); |
+} |
+ |
+static void implements3StaticVoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::implements3StaticVoidMethodMethod(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialVoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ ASSERT(impl); |
+ TestPartialInterface::partialVoidMethod(*impl); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialVoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::partialVoidMethodMethod(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialStaticVoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TestPartialInterface::partialStaticVoidMethod(); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialStaticVoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::partialStaticVoidMethodMethod(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialVoidMethodLongArgMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ ExceptionState exceptionState(ExceptionState::ExecutionContext, "partialVoidMethodLongArg", "TestInterface", info.Holder(), info.GetIsolate()); |
+ if (UNLIKELY(info.Length() < 1)) { |
+ exceptionState.throwTypeError(ExceptionMessages::notEnoughArguments(1, info.Length())); |
exceptionState.throwIfNeeded(); |
return; |
} |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
- V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, strArg, info[0]); |
- V8TRYCATCH_VOID(TestObject*, objArg, V8TestObject::toNativeWithTypeCheck(info.GetIsolate(), info[1])); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ V8TRYCATCH_EXCEPTION_VOID(int, longArg, toInt32(info[0], exceptionState), exceptionState); |
ASSERT(impl); |
+ TestPartialInterface::partialVoidMethodLongArg(*impl, longArg); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialVoidMethodLongArgMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::partialVoidMethodLongArgMethod(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialCallWithExecutionContextRaisesExceptionVoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ ExceptionState exceptionState(ExceptionState::ExecutionContext, "partialCallWithExecutionContextRaisesExceptionVoidMethod", "TestInterface", info.Holder(), info.GetIsolate()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ ASSERT(impl); |
ExecutionContext* scriptContext = currentExecutionContext(info.GetIsolate()); |
- RefPtr<TestObject> result = TestPartialInterface::supplementalMethod2(scriptContext, *impl, strArg, objArg, exceptionState); |
+ TestPartialInterface::partialCallWithExecutionContextRaisesExceptionVoidMethod(scriptContext, *impl, exceptionState); |
if (exceptionState.throwIfNeeded()) |
return; |
- v8SetReturnValue(info, result.release()); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalMethod2MethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialCallWithExecutionContextRaisesExceptionVoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- TestInterfaceV8Internal::supplementalMethod2Method(info); |
+ TestInterfaceImplementationV8Internal::partialCallWithExecutionContextRaisesExceptionVoidMethodMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalMethod3MethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialVoidMethodPartialCallbackTypeArgMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
+ if (UNLIKELY(info.Length() < 1)) { |
+ throwTypeError(ExceptionMessages::failedToExecute("partialVoidMethodPartialCallbackTypeArg", "TestInterface", ExceptionMessages::notEnoughArguments(1, info.Length())), info.GetIsolate()); |
+ return; |
+ } |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ V8TRYCATCH_VOID(ScriptValue, partialCallbackTypeArg, ScriptValue(info[0], info.GetIsolate())); |
+ ASSERT(impl); |
+ TestPartialInterface::partialVoidMethodPartialCallbackTypeArg(*impl, partialCallbackTypeArg); |
+} |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ |
+#if ENABLE(PARTIAL_CONDITION) |
+static void partialVoidMethodPartialCallbackTypeArgMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- V8TestInterface::supplementalMethod3MethodCustom(info); |
+ TestInterfaceImplementationV8Internal::partialVoidMethodPartialCallbackTypeArgMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#endif // ENABLE(PARTIAL_CONDITION) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalMethod4Method(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void partial2VoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
- TestPartialInterface::supplementalMethod4(); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ ASSERT(impl); |
+ TestPartialInterfaceImplementation::partial2VoidMethod(*impl); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
-static void supplementalMethod4MethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void partial2VoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
- TestInterfaceV8Internal::supplementalMethod4Method(info); |
+ TestInterfaceImplementationV8Internal::partial2VoidMethodMethod(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
-static void constructor(const v8::FunctionCallbackInfo<v8::Value>& info) |
+static void partial2StaticVoidMethodMethod(const v8::FunctionCallbackInfo<v8::Value>& info) |
{ |
- v8::Isolate* isolate = info.GetIsolate(); |
- ExceptionState exceptionState(ExceptionState::ConstructionContext, "TestInterface", info.Holder(), isolate); |
- if (UNLIKELY(info.Length() < 1)) { |
- exceptionState.throwTypeError(ExceptionMessages::notEnoughArguments(1, info.Length())); |
- exceptionState.throwIfNeeded(); |
+ TestPartialInterfaceImplementation::partial2StaticVoidMethod(); |
+} |
+ |
+static void partial2StaticVoidMethodMethodCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMMethod"); |
+ TestInterfaceImplementationV8Internal::partial2StaticVoidMethodMethod(info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void indexedPropertyGetter(uint32_t index, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ String result = impl->anonymousIndexedGetter(index); |
+ if (result.isNull()) |
return; |
- } |
- V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, str1, info[0]); |
- V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, str2, info[1]); |
- ExecutionContext* context = currentExecutionContext(isolate); |
- RefPtr<TestInterface> impl = TestInterface::create(context, str1, str2, exceptionState); |
- if (exceptionState.throwIfNeeded()) |
+ v8SetReturnValueString(info, result, info.GetIsolate()); |
+} |
+ |
+static void indexedPropertyGetterCallback(uint32_t index, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMIndexedProperty"); |
+ TestInterfaceImplementationV8Internal::indexedPropertyGetter(index, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
+static void indexedPropertySetter(uint32_t index, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, propertyValue, v8Value); |
+ bool result = impl->anonymousIndexedSetter(index, propertyValue); |
+ if (!result) |
return; |
+ v8SetReturnValue(info, v8Value); |
+} |
- v8::Handle<v8::Object> wrapper = info.Holder(); |
- V8DOMWrapper::associateObjectWithWrapper<V8TestInterface>(impl.release(), &V8TestInterface::wrapperTypeInfo, wrapper, isolate, WrapperConfiguration::Dependent); |
- v8SetReturnValue(info, wrapper); |
+static void indexedPropertySetterCallback(uint32_t index, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMIndexedProperty"); |
+ TestInterfaceImplementationV8Internal::indexedPropertySetter(index, v8Value, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
+static void indexedPropertyDeleter(uint32_t index, const v8::PropertyCallbackInfo<v8::Boolean>& info) |
+{ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ DeleteResult result = impl->anonymousIndexedDeleter(index); |
+ if (result != DeleteUnknownProperty) |
+ return v8SetReturnValueBool(info, result == DeleteSuccess); |
+} |
+ |
+static void indexedPropertyDeleterCallback(uint32_t index, const v8::PropertyCallbackInfo<v8::Boolean>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMIndexedProperty"); |
+ TestInterfaceImplementationV8Internal::indexedPropertyDeleter(index, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
static void namedPropertyGetter(v8::Local<v8::String> name, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
if (info.Holder()->HasRealNamedProperty(name)) |
@@ -636,43 +1079,47 @@ |
if (!info.Holder()->GetRealNamedPropertyInPrototypeChain(name).IsEmpty()) |
return; |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
AtomicString propertyName = toCoreAtomicString(name); |
- bool result0Enabled = false; |
- RefPtr<Node> result0; |
- bool result1Enabled = false; |
- RefPtr<NodeList> result1; |
- impl->getItem(propertyName, result0Enabled, result0, result1Enabled, result1); |
- if (!result0Enabled && !result1Enabled) |
+ String result = impl->anonymousNamedGetter(propertyName); |
+ if (result.isNull()) |
return; |
- if (result0Enabled) { |
- v8SetReturnValueFast(info, WTF::getPtr(result0.release()), impl); |
- return; |
- } |
- if (result1Enabled) { |
- v8SetReturnValueFast(info, WTF::getPtr(result1.release()), impl); |
- return; |
- } |
- v8SetReturnValueNull(info); |
+ v8SetReturnValueString(info, result, info.GetIsolate()); |
} |
static void namedPropertyGetterCallback(v8::Local<v8::String> name, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMNamedProperty"); |
- TestInterfaceV8Internal::namedPropertyGetter(name, info); |
+ TestInterfaceImplementationV8Internal::namedPropertyGetter(name, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
+static void namedPropertySetter(v8::Local<v8::String> name, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<v8::Value>& info) |
+{ |
+ if (info.Holder()->HasRealNamedProperty(name)) |
+ return; |
+ if (!info.Holder()->GetRealNamedPropertyInPrototypeChain(name).IsEmpty()) |
+ return; |
+ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, propertyName, name); |
+ V8TRYCATCH_FOR_V8STRINGRESOURCE_VOID(V8StringResource<>, propertyValue, v8Value); |
+ bool result = impl->anonymousNamedSetter(propertyName, propertyValue); |
+ if (!result) |
+ return; |
+ v8SetReturnValue(info, v8Value); |
+} |
+ |
static void namedPropertySetterCallback(v8::Local<v8::String> name, v8::Local<v8::Value> v8Value, const v8::PropertyCallbackInfo<v8::Value>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMNamedProperty"); |
- V8TestInterface::namedPropertySetterCustom(name, v8Value, info); |
+ TestInterfaceImplementationV8Internal::namedPropertySetter(name, v8Value, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
static void namedPropertyQuery(v8::Local<v8::String> name, const v8::PropertyCallbackInfo<v8::Integer>& info) |
{ |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
AtomicString propertyName = toCoreAtomicString(name); |
v8::String::Utf8Value namedProperty(name); |
ExceptionState exceptionState(ExceptionState::GetterContext, *namedProperty, "TestInterface", info.Holder(), info.GetIsolate()); |
@@ -687,13 +1134,29 @@ |
static void namedPropertyQueryCallback(v8::Local<v8::String> name, const v8::PropertyCallbackInfo<v8::Integer>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMNamedProperty"); |
- TestInterfaceV8Internal::namedPropertyQuery(name, info); |
+ TestInterfaceImplementationV8Internal::namedPropertyQuery(name, info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
+static void namedPropertyDeleter(v8::Local<v8::String> name, const v8::PropertyCallbackInfo<v8::Boolean>& info) |
+{ |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
+ AtomicString propertyName = toCoreAtomicString(name); |
+ DeleteResult result = impl->anonymousNamedDeleter(propertyName); |
+ if (result != DeleteUnknownProperty) |
+ return v8SetReturnValueBool(info, result == DeleteSuccess); |
+} |
+ |
+static void namedPropertyDeleterCallback(v8::Local<v8::String> name, const v8::PropertyCallbackInfo<v8::Boolean>& info) |
+{ |
+ TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMNamedProperty"); |
+ TestInterfaceImplementationV8Internal::namedPropertyDeleter(name, info); |
+ TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
+} |
+ |
static void namedPropertyEnumerator(const v8::PropertyCallbackInfo<v8::Array>& info) |
{ |
- TestInterface* impl = V8TestInterface::toNative(info.Holder()); |
+ TestInterfaceImplementation* impl = V8TestInterface::toNative(info.Holder()); |
v8::Isolate* isolate = info.GetIsolate(); |
Vector<String> names; |
ExceptionState exceptionState(ExceptionState::EnumerationContext, "TestInterface", info.Holder(), isolate); |
@@ -709,124 +1172,141 @@ |
static void namedPropertyEnumeratorCallback(const v8::PropertyCallbackInfo<v8::Array>& info) |
{ |
TRACE_EVENT_SET_SAMPLING_STATE("Blink", "DOMNamedProperty"); |
- TestInterfaceV8Internal::namedPropertyEnumerator(info); |
+ TestInterfaceImplementationV8Internal::namedPropertyEnumerator(info); |
TRACE_EVENT_SET_SAMPLING_STATE("V8", "V8Execution"); |
} |
-} // namespace TestInterfaceV8Internal |
+} // namespace TestInterfaceImplementationV8Internal |
void V8TestInterface::visitDOMWrapper(void* object, const v8::Persistent<v8::Object>& wrapper, v8::Isolate* isolate) |
{ |
- TestInterface* impl = fromInternalPointer(object); |
+ TestInterfaceImplementation* impl = fromInternalPointer(object); |
v8::Local<v8::Object> creationContext = v8::Local<v8::Object>::New(isolate, wrapper); |
V8WrapperInstantiationScope scope(creationContext, isolate); |
- TestObject* referencedName = impl->referencedName(); |
+ TestInterfaceImplementation* referencedName = impl->referencedName(); |
if (referencedName) { |
- if (!DOMDataStore::containsWrapper<V8TestObject>(referencedName, isolate)) |
+ if (!DOMDataStore::containsWrapper<V8TestInterface>(referencedName, isolate)) |
wrap(referencedName, creationContext, isolate); |
- DOMDataStore::setWrapperReference<V8TestObject>(wrapper, referencedName, isolate); |
+ DOMDataStore::setWrapperReference<V8TestInterface>(wrapper, referencedName, isolate); |
} |
setObjectGroup(object, wrapper, isolate); |
} |
static const V8DOMConfiguration::AttributeConfiguration V8TestInterfaceAttributes[] = { |
- {"implementsReadonlyStringAttribute", TestInterfaceV8Internal::implementsReadonlyStringAttributeAttributeGetterCallback, 0, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
- {"implementsStringAttribute", TestInterfaceV8Internal::implementsStringAttributeAttributeGetterCallback, TestInterfaceV8Internal::implementsStringAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
- {"implementsNodeAttribute", TestInterfaceV8Internal::implementsNodeAttributeAttributeGetterCallback, TestInterfaceV8Internal::implementsNodeAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
- {"implementsEventHandlerAttribute", TestInterfaceV8Internal::implementsEventHandlerAttributeAttributeGetterCallback, TestInterfaceV8Internal::implementsEventHandlerAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
-#if ENABLE(CONDITION_PARTIAL) |
- {"supplementalStr1", TestInterfaceV8Internal::supplementalStr1AttributeGetterCallback, 0, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
- {"supplementalStr2", TestInterfaceV8Internal::supplementalStr2AttributeGetterCallback, TestInterfaceV8Internal::supplementalStr2AttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
- {"supplementalNode", TestInterfaceV8Internal::supplementalNodeAttributeGetterCallback, TestInterfaceV8Internal::supplementalNodeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
-#endif // ENABLE(CONDITION_PARTIAL) |
+ {"testInterfaceAttribute", TestInterfaceImplementationV8Internal::testInterfaceAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::testInterfaceAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
+ {"testImplementedAsConstructorAttribute", TestInterfaceImplementationV8Internal::TestInterfaceImplementationConstructorGetter, TestInterfaceImplementationV8Internal::TestInterfaceImplementationReplaceableAttributeSetterCallback, 0, 0, const_cast<WrapperTypeInfo*>(&V8TestImplementedAs::wrapperTypeInfo), static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::DontEnum), 0 /* on instance */}, |
+ {"perWorldBindingsStringAttribute", TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeSetterCallback, TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeGetterCallbackForMainWorld, TestInterfaceImplementationV8Internal::perWorldBindingsStringAttributeAttributeSetterCallbackForMainWorld, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
+ {"implementsReadonlyStringAttribute", TestInterfaceImplementationV8Internal::implementsReadonlyStringAttributeAttributeGetterCallback, 0, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
+ {"implementsStringAttribute", TestInterfaceImplementationV8Internal::implementsStringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implementsStringAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
+ {"implementsNodeAttribute", TestInterfaceImplementationV8Internal::implementsNodeAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implementsNodeAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
+ {"implementsEventHandlerAttribute", TestInterfaceImplementationV8Internal::implementsEventHandlerAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implementsEventHandlerAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
+ {"implements3StringAttribute", TestInterfaceImplementationV8Internal::implements3StringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implements3StringAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
}; |
static const V8DOMConfiguration::MethodConfiguration V8TestInterfaceMethods[] = { |
- {"namedItem", TestInterfaceV8Internal::namedItemMethodCallback, 0, 1}, |
- {"implementsVoidMethod", TestInterfaceV8Internal::implementsVoidMethodMethodCallback, 0, 0}, |
- {"implementsComplexMethod", TestInterfaceV8Internal::implementsComplexMethodMethodCallback, 0, 2}, |
- {"implementsCustomVoidMethod", TestInterfaceV8Internal::implementsCustomVoidMethodMethodCallback, 0, 0}, |
-#if ENABLE(CONDITION_PARTIAL) |
- {"supplementalMethod1", TestInterfaceV8Internal::supplementalMethod1MethodCallback, 0, 0}, |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
- {"supplementalMethod2", TestInterfaceV8Internal::supplementalMethod2MethodCallback, 0, 2}, |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
- {"supplementalMethod3", TestInterfaceV8Internal::supplementalMethod3MethodCallback, 0, 0}, |
-#endif // ENABLE(CONDITION_PARTIAL) |
+ {"voidMethodTestInterfaceEmptyArg", TestInterfaceImplementationV8Internal::voidMethodTestInterfaceEmptyArgMethodCallback, 0, 1}, |
+ {"voidMethod", TestInterfaceImplementationV8Internal::voidMethodMethodCallback, TestInterfaceImplementationV8Internal::voidMethodMethodCallbackForMainWorld, 0}, |
+ {"implementsVoidMethod", TestInterfaceImplementationV8Internal::implementsVoidMethodMethodCallback, 0, 0}, |
+ {"implementsComplexMethod", TestInterfaceImplementationV8Internal::implementsComplexMethodMethodCallback, 0, 2}, |
+ {"implementsCustomVoidMethod", TestInterfaceImplementationV8Internal::implementsCustomVoidMethodMethodCallback, 0, 0}, |
+ {"implements3VoidMethod", TestInterfaceImplementationV8Internal::implements3VoidMethodMethodCallback, 0, 0}, |
}; |
-void V8TestInterface::constructorCallback(const v8::FunctionCallbackInfo<v8::Value>& info) |
-{ |
- TRACE_EVENT_SCOPED_SAMPLING_STATE("Blink", "DOMConstructor"); |
- if (!info.IsConstructCall()) { |
- throwTypeError(ExceptionMessages::constructorNotCallableAsFunction("TestInterface"), info.GetIsolate()); |
- return; |
- } |
- |
- if (ConstructorMode::current() == ConstructorMode::WrapExistingObject) { |
- v8SetReturnValue(info, info.Holder()); |
- return; |
- } |
- |
- TestInterfaceV8Internal::constructor(info); |
-} |
- |
static void configureV8TestInterfaceTemplate(v8::Handle<v8::FunctionTemplate> functionTemplate, v8::Isolate* isolate) |
{ |
functionTemplate->ReadOnlyPrototype(); |
v8::Local<v8::Signature> defaultSignature; |
- defaultSignature = V8DOMConfiguration::installDOMClassTemplate(functionTemplate, "TestInterface", v8::Local<v8::FunctionTemplate>(), V8TestInterface::internalFieldCount, |
- V8TestInterfaceAttributes, WTF_ARRAY_LENGTH(V8TestInterfaceAttributes), |
- 0, 0, |
- V8TestInterfaceMethods, WTF_ARRAY_LENGTH(V8TestInterfaceMethods), |
- isolate); |
- functionTemplate->SetCallHandler(V8TestInterface::constructorCallback); |
- functionTemplate->SetLength(1); |
+ if (!RuntimeEnabledFeatures::featureNameEnabled()) |
+ defaultSignature = V8DOMConfiguration::installDOMClassTemplate(functionTemplate, "", V8TestInterfaceEmpty::domTemplate(isolate), V8TestInterface::internalFieldCount, 0, 0, 0, 0, 0, 0, isolate); |
+ else |
+ defaultSignature = V8DOMConfiguration::installDOMClassTemplate(functionTemplate, "TestInterface", V8TestInterfaceEmpty::domTemplate(isolate), V8TestInterface::internalFieldCount, |
+ V8TestInterfaceAttributes, WTF_ARRAY_LENGTH(V8TestInterfaceAttributes), |
+ 0, 0, |
+ V8TestInterfaceMethods, WTF_ARRAY_LENGTH(V8TestInterfaceMethods), |
+ isolate); |
v8::Local<v8::ObjectTemplate> ALLOW_UNUSED instanceTemplate = functionTemplate->InstanceTemplate(); |
v8::Local<v8::ObjectTemplate> ALLOW_UNUSED prototypeTemplate = functionTemplate->PrototypeTemplate(); |
if (RuntimeEnabledFeatures::implementsFeatureNameEnabled()) { |
static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
- {"implementsRuntimeEnabledNodeAttribute", TestInterfaceV8Internal::implementsRuntimeEnabledNodeAttributeAttributeGetterCallback, TestInterfaceV8Internal::implementsRuntimeEnabledNodeAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ {"implementsRuntimeEnabledNodeAttribute", TestInterfaceImplementationV8Internal::implementsRuntimeEnabledNodeAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implementsRuntimeEnabledNodeAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
} |
-#if ENABLE(CONDITION_PARTIAL) |
- if (RuntimeEnabledFeatures::condition13Enabled()) { |
+ if (RuntimeEnabledFeatures::implements2FeatureNameEnabled()) { |
static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
- {"Node13", TestInterfaceV8Internal::Node13AttributeGetterCallback, TestInterfaceV8Internal::Node13AttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ {"implements2StringAttribute", TestInterfaceImplementationV8Internal::implements2StringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implements2StringAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
} |
-#endif // ENABLE(CONDITION_PARTIAL) |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) { |
+ static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
+ {"partialLongAttribute", TestInterfaceImplementationV8Internal::partialLongAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::partialLongAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
+ } |
+#endif // ENABLE(PARTIAL_CONDITION) |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) { |
+ static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
+ {"partialCallWithExecutionContextLongAttribute", TestInterfaceImplementationV8Internal::partialCallWithExecutionContextLongAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::partialCallWithExecutionContextLongAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
+ } |
+#endif // ENABLE(PARTIAL_CONDITION) |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) { |
+ static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
+ {"partialPartialEnumTypeAttribute", TestInterfaceImplementationV8Internal::partialPartialEnumTypeAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::partialPartialEnumTypeAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
+ } |
+#endif // ENABLE(PARTIAL_CONDITION) |
static const V8DOMConfiguration::ConstantConfiguration V8TestInterfaceConstants[] = { |
+ {"UNSIGNED_LONG", 0}, |
+ {"CONST_JAVASCRIPT", 1}, |
{"IMPLEMENTS_CONSTANT_1", 1}, |
{"IMPLEMENTS_CONSTANT_2", 2}, |
- {"SUPPLEMENTALCONSTANT1", 1}, |
- {"SUPPLEMENTALCONSTANT2", 2}, |
+ {"PARTIAL2_UNSIGNED_SHORT", 0}, |
}; |
V8DOMConfiguration::installConstants(functionTemplate, prototypeTemplate, V8TestInterfaceConstants, WTF_ARRAY_LENGTH(V8TestInterfaceConstants), isolate); |
- COMPILE_ASSERT(1 == TestImplements::IMPLEMENTS_CONSTANT_1, TheValueOfTestInterface_IMPLEMENTS_CONSTANT_1DoesntMatchWithImplementation); |
- COMPILE_ASSERT(2 == TestImplements::IMPLEMENTS_REFLECT_CONSTANT, TheValueOfTestInterface_IMPLEMENTS_REFLECT_CONSTANTDoesntMatchWithImplementation); |
- COMPILE_ASSERT(1 == TestPartialInterface::SUPPLEMENTALCONSTANT1, TheValueOfTestInterface_SUPPLEMENTALCONSTANT1DoesntMatchWithImplementation); |
- COMPILE_ASSERT(2 == TestPartialInterface::CONST_IMPL, TheValueOfTestInterface_CONST_IMPLDoesntMatchWithImplementation); |
- functionTemplate->InstanceTemplate()->SetNamedPropertyHandler(TestInterfaceV8Internal::namedPropertyGetterCallback, TestInterfaceV8Internal::namedPropertySetterCallback, TestInterfaceV8Internal::namedPropertyQueryCallback, 0, TestInterfaceV8Internal::namedPropertyEnumeratorCallback); |
- functionTemplate->Set(v8AtomicString(isolate, "implementsStaticVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceV8Internal::implementsStaticVoidMethodMethodCallback, v8Undefined(), v8::Local<v8::Signature>(), 0)); |
-#if ENABLE(CONDITION_PARTIAL) |
- functionTemplate->Set(v8AtomicString(isolate, "supplementalMethod4"), v8::FunctionTemplate::New(isolate, TestInterfaceV8Internal::supplementalMethod4MethodCallback, v8Undefined(), v8::Local<v8::Signature>(), 0)); |
-#endif // ENABLE(CONDITION_PARTIAL) |
- functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "implementsStaticReadOnlyLongAttribute"), TestInterfaceV8Internal::implementsStaticReadOnlyLongAttributeAttributeGetterCallback, 0, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
- functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "implementsStaticStringAttribute"), TestInterfaceV8Internal::implementsStaticStringAttributeAttributeGetterCallback, TestInterfaceV8Internal::implementsStaticStringAttributeAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
-#if ENABLE(CONDITION_PARTIAL) |
- functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "supplementalStaticReadOnlyAttr"), TestInterfaceV8Internal::supplementalStaticReadOnlyAttrAttributeGetterCallback, 0, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
-#endif // ENABLE(CONDITION_PARTIAL) |
-#if ENABLE(CONDITION_PARTIAL) |
- functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "supplementalStaticAttr"), TestInterfaceV8Internal::supplementalStaticAttrAttributeGetterCallback, TestInterfaceV8Internal::supplementalStaticAttrAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
-#endif // ENABLE(CONDITION_PARTIAL) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) { |
+ static const V8DOMConfiguration::ConstantConfiguration constantConfiguration = {"PARTIAL_UNSIGNED_SHORT", static_cast<signed int>(0)}; |
+ V8DOMConfiguration::installConstants(functionTemplate, prototypeTemplate, &constantConfiguration, 1, isolate); |
+ } |
+ functionTemplate->InstanceTemplate()->SetIndexedPropertyHandler(TestInterfaceImplementationV8Internal::indexedPropertyGetterCallback, TestInterfaceImplementationV8Internal::indexedPropertySetterCallback, 0, TestInterfaceImplementationV8Internal::indexedPropertyDeleterCallback, indexedPropertyEnumerator<TestInterfaceImplementation>); |
+ functionTemplate->InstanceTemplate()->SetNamedPropertyHandler(TestInterfaceImplementationV8Internal::namedPropertyGetterCallback, TestInterfaceImplementationV8Internal::namedPropertySetterCallback, TestInterfaceImplementationV8Internal::namedPropertyQueryCallback, TestInterfaceImplementationV8Internal::namedPropertyDeleterCallback, TestInterfaceImplementationV8Internal::namedPropertyEnumeratorCallback); |
+ functionTemplate->InstanceTemplate()->SetCallAsFunctionHandler(V8TestInterface::legacyCallCustom); |
+ functionTemplate->Set(v8AtomicString(isolate, "implementsStaticVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::implementsStaticVoidMethodMethodCallback, v8Undefined(), v8::Local<v8::Signature>(), 0)); |
+ if (RuntimeEnabledFeatures::implements2FeatureNameEnabled()) |
+ prototypeTemplate->Set(v8AtomicString(isolate, "implements2VoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::implements2VoidMethodMethodCallback, v8Undefined(), defaultSignature, 0)); |
+ functionTemplate->Set(v8AtomicString(isolate, "implements3StaticVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::implements3StaticVoidMethodMethodCallback, v8Undefined(), v8::Local<v8::Signature>(), 0)); |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) |
+ prototypeTemplate->Set(v8AtomicString(isolate, "partialVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partialVoidMethodMethodCallback, v8Undefined(), defaultSignature, 0)); |
+#endif // ENABLE(PARTIAL_CONDITION) |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) |
+ functionTemplate->Set(v8AtomicString(isolate, "partialStaticVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partialStaticVoidMethodMethodCallback, v8Undefined(), v8::Local<v8::Signature>(), 0)); |
+#endif // ENABLE(PARTIAL_CONDITION) |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) |
+ prototypeTemplate->Set(v8AtomicString(isolate, "partialVoidMethodLongArg"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partialVoidMethodLongArgMethodCallback, v8Undefined(), defaultSignature, 1)); |
+#endif // ENABLE(PARTIAL_CONDITION) |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) |
+ prototypeTemplate->Set(v8AtomicString(isolate, "partialCallWithExecutionContextRaisesExceptionVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partialCallWithExecutionContextRaisesExceptionVoidMethodMethodCallback, v8Undefined(), defaultSignature, 0)); |
+#endif // ENABLE(PARTIAL_CONDITION) |
+#if ENABLE(PARTIAL_CONDITION) |
+ if (RuntimeEnabledFeatures::partialFeatureNameEnabled()) |
+ prototypeTemplate->Set(v8AtomicString(isolate, "partialVoidMethodPartialCallbackTypeArg"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partialVoidMethodPartialCallbackTypeArgMethodCallback, v8Undefined(), defaultSignature, 1)); |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ functionTemplate->Set(v8AtomicString(isolate, "partial2StaticVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partial2StaticVoidMethodMethodCallback, v8Undefined(), v8::Local<v8::Signature>(), 0)); |
+ functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "staticStringAttribute"), TestInterfaceImplementationV8Internal::staticStringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::staticStringAttributeAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
+ functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "implementsStaticReadOnlyLongAttribute"), TestInterfaceImplementationV8Internal::implementsStaticReadOnlyLongAttributeAttributeGetterCallback, 0, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
+ functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "implementsStaticStringAttribute"), TestInterfaceImplementationV8Internal::implementsStaticStringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implementsStaticStringAttributeAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
+ functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "implements2StaticStringAttribute"), TestInterfaceImplementationV8Internal::implements2StaticStringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implements2StaticStringAttributeAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
+ functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "implements3StaticStringAttribute"), TestInterfaceImplementationV8Internal::implements3StaticStringAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implements3StaticStringAttributeAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
+#if ENABLE(PARTIAL_CONDITION) |
+ functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "partialStaticLongAttribute"), TestInterfaceImplementationV8Internal::partialStaticLongAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::partialStaticLongAttributeAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
+#endif // ENABLE(PARTIAL_CONDITION) |
+ functionTemplate->SetNativeDataProperty(v8AtomicString(isolate, "partial2StaticLongAttribute"), TestInterfaceImplementationV8Internal::partial2StaticLongAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::partial2StaticLongAttributeAttributeSetterCallback, v8::External::New(isolate, 0), static_cast<v8::PropertyAttribute>(v8::None), v8::Handle<v8::AccessorSignature>(), static_cast<v8::AccessControl>(v8::DEFAULT)); |
// Custom toString template |
functionTemplate->Set(v8AtomicString(isolate, "toString"), V8PerIsolateData::current()->toStringTemplate()); |
@@ -856,44 +1336,45 @@ |
return V8PerIsolateData::from(isolate)->findInstanceInPrototypeChain(&wrapperTypeInfo, v8Value); |
} |
-TestInterface* V8TestInterface::toNativeWithTypeCheck(v8::Isolate* isolate, v8::Handle<v8::Value> value) |
+TestInterfaceImplementation* V8TestInterface::toNativeWithTypeCheck(v8::Isolate* isolate, v8::Handle<v8::Value> value) |
{ |
return hasInstance(value, isolate) ? fromInternalPointer(v8::Handle<v8::Object>::Cast(value)->GetAlignedPointerFromInternalField(v8DOMWrapperObjectIndex)) : 0; |
} |
-void V8TestInterface::installPerContextEnabledProperties(v8::Handle<v8::Object> instanceTemplate, TestInterface* impl, v8::Isolate* isolate) |
+void V8TestInterface::installPerContextEnabledProperties(v8::Handle<v8::Object> instanceTemplate, TestInterfaceImplementation* impl, v8::Isolate* isolate) |
{ |
v8::Local<v8::Object> prototypeTemplate = v8::Local<v8::Object>::Cast(instanceTemplate->GetPrototype()); |
if (ContextFeatures::implementsContextNameEnabled(impl->document())) { |
static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
- {"implementsPerContextEnabledNodeAttribute", TestInterfaceV8Internal::implementsPerContextEnabledNodeAttributeAttributeGetterCallback, TestInterfaceV8Internal::implementsPerContextEnabledNodeAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ {"implementsPerContextEnabledNodeAttribute", TestInterfaceImplementationV8Internal::implementsPerContextEnabledNodeAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::implementsPerContextEnabledNodeAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
} |
+ if (ContextFeatures::partialContextNameEnabled(impl->document())) { |
+ static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
+ {"partial2LongAttribute", TestInterfaceImplementationV8Internal::partial2LongAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::partial2LongAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
+ } |
+ if (ContextFeatures::partialContextNameEnabled(impl->document())) { |
+ static const V8DOMConfiguration::AttributeConfiguration attributeConfiguration =\ |
+ {"partial2StaticLongAttribute", TestInterfaceImplementationV8Internal::partial2StaticLongAttributeAttributeGetterCallback, TestInterfaceImplementationV8Internal::partial2StaticLongAttributeAttributeSetterCallback, 0, 0, 0, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}; |
+ V8DOMConfiguration::installAttribute(instanceTemplate, prototypeTemplate, attributeConfiguration, isolate); |
+ } |
} |
-ActiveDOMObject* V8TestInterface::toActiveDOMObject(v8::Handle<v8::Object> wrapper) |
+void V8TestInterface::installPerContextEnabledMethods(v8::Handle<v8::Object> prototypeTemplate, v8::Isolate* isolate) |
{ |
- return toNative(wrapper); |
+ v8::Local<v8::Signature> defaultSignature = v8::Signature::New(isolate, domTemplate(isolate)); |
+ |
+ ExecutionContext* context = toExecutionContext(prototypeTemplate->CreationContext()); |
+ if (context && context->isDocument() && ContextFeatures::partialContextNameEnabled(toDocument(context))) |
+ prototypeTemplate->Set(v8AtomicString(isolate, "partial2VoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partial2VoidMethodMethodCallback, v8Undefined(), defaultSignature, 0)->GetFunction()); |
+ if (context && context->isDocument() && ContextFeatures::partialContextNameEnabled(toDocument(context))) |
+ prototypeTemplate->Set(v8AtomicString(isolate, "partial2StaticVoidMethod"), v8::FunctionTemplate::New(isolate, TestInterfaceImplementationV8Internal::partial2StaticVoidMethodMethodCallback, v8Undefined(), defaultSignature, 0)->GetFunction()); |
} |
-v8::Handle<v8::Object> V8TestInterface::createWrapper(PassRefPtr<TestInterface> impl, v8::Handle<v8::Object> creationContext, v8::Isolate* isolate) |
+ActiveDOMObject* V8TestInterface::toActiveDOMObject(v8::Handle<v8::Object> wrapper) |
{ |
- ASSERT(impl); |
- ASSERT(!DOMDataStore::containsWrapper<V8TestInterface>(impl.get(), isolate)); |
- if (ScriptWrappable::wrapperCanBeStoredInObject(impl.get())) { |
- const WrapperTypeInfo* actualInfo = ScriptWrappable::getTypeInfoFromObject(impl.get()); |
- // Might be a XXXConstructor::wrapperTypeInfo instead of an XXX::wrapperTypeInfo. These will both have |
- // the same object de-ref functions, though, so use that as the basis of the check. |
- RELEASE_ASSERT_WITH_SECURITY_IMPLICATION(actualInfo->derefObjectFunction == wrapperTypeInfo.derefObjectFunction); |
- } |
- |
- v8::Handle<v8::Object> wrapper = V8DOMWrapper::createWrapper(creationContext, &wrapperTypeInfo, toInternalPointer(impl.get()), isolate); |
- if (UNLIKELY(wrapper.IsEmpty())) |
- return wrapper; |
- |
- installPerContextEnabledProperties(wrapper, impl.get(), isolate); |
- V8DOMWrapper::associateObjectWithWrapper<V8TestInterface>(impl, &wrapperTypeInfo, wrapper, isolate, WrapperConfiguration::Dependent); |
- return wrapper; |
+ return toNative(wrapper); |
} |
void V8TestInterface::derefObject(void* object) |
@@ -902,10 +1383,10 @@ |
} |
template<> |
-v8::Handle<v8::Value> toV8NoInline(TestInterface* impl, v8::Handle<v8::Object> creationContext, v8::Isolate* isolate) |
+v8::Handle<v8::Value> toV8NoInline(TestInterfaceImplementation* impl, v8::Handle<v8::Object> creationContext, v8::Isolate* isolate) |
{ |
return toV8(impl, creationContext, isolate); |
} |
} // namespace WebCore |
-#endif // ENABLE(Condition1) || ENABLE(Condition2) |
+#endif // ENABLE(CONDITION) |