/* This file is part of the WebKit open source project. This file has been generated by generate-bindings.pl. DO NOT MODIFY! This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "config.h" #include "JSTestObj.h" #include "ExceptionCode.h" #include "HTMLNames.h" #include "IDBBindingUtilities.h" #include "IDBKey.h" #include "JSDOMBinding.h" #include "JSEventListener.h" #include "JSOptionsObject.h" #include "JSTestCallback.h" #include "JSTestObj.h" #include "JSlog.h" #include "KURL.h" #include "ScriptArguments.h" #include "ScriptCallStack.h" #include "ScriptCallStackFactory.h" #include "SerializedScriptValue.h" #include "TestObj.h" #include #include #include #include using namespace JSC; namespace WebCore { ASSERT_CLASS_FITS_IN_CELL(JSTestObj); /* Hash table */ #if ENABLE(JIT) #define THUNK_GENERATOR(generator) , generator #else #define THUNK_GENERATOR(generator) #endif static const HashTableValue JSTestObjTableValues[37] = { { "readOnlyIntAttr", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjReadOnlyIntAttr), (intptr_t)0 THUNK_GENERATOR(0) }, { "readOnlyStringAttr", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjReadOnlyStringAttr), (intptr_t)0 THUNK_GENERATOR(0) }, { "readOnlyTestObjAttr", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjReadOnlyTestObjAttr), (intptr_t)0 THUNK_GENERATOR(0) }, { "shortAttr", DontDelete, (intptr_t)static_cast(jsTestObjShortAttr), (intptr_t)setJSTestObjShortAttr THUNK_GENERATOR(0) }, { "unsignedShortAttr", DontDelete, (intptr_t)static_cast(jsTestObjUnsignedShortAttr), (intptr_t)setJSTestObjUnsignedShortAttr THUNK_GENERATOR(0) }, { "intAttr", DontDelete, (intptr_t)static_cast(jsTestObjIntAttr), (intptr_t)setJSTestObjIntAttr THUNK_GENERATOR(0) }, { "longLongAttr", DontDelete, (intptr_t)static_cast(jsTestObjLongLongAttr), (intptr_t)setJSTestObjLongLongAttr THUNK_GENERATOR(0) }, { "unsignedLongLongAttr", DontDelete, (intptr_t)static_cast(jsTestObjUnsignedLongLongAttr), (intptr_t)setJSTestObjUnsignedLongLongAttr THUNK_GENERATOR(0) }, { "stringAttr", DontDelete, (intptr_t)static_cast(jsTestObjStringAttr), (intptr_t)setJSTestObjStringAttr THUNK_GENERATOR(0) }, { "testObjAttr", DontDelete, (intptr_t)static_cast(jsTestObjTestObjAttr), (intptr_t)setJSTestObjTestObjAttr THUNK_GENERATOR(0) }, { "XMLObjAttr", DontDelete, (intptr_t)static_cast(jsTestObjXMLObjAttr), (intptr_t)setJSTestObjXMLObjAttr THUNK_GENERATOR(0) }, { "create", DontDelete, (intptr_t)static_cast(jsTestObjCreate), (intptr_t)setJSTestObjCreate THUNK_GENERATOR(0) }, { "reflectedStringAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedStringAttr), (intptr_t)setJSTestObjReflectedStringAttr THUNK_GENERATOR(0) }, { "reflectedIntegralAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedIntegralAttr), (intptr_t)setJSTestObjReflectedIntegralAttr THUNK_GENERATOR(0) }, { "reflectedUnsignedIntegralAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedUnsignedIntegralAttr), (intptr_t)setJSTestObjReflectedUnsignedIntegralAttr THUNK_GENERATOR(0) }, { "reflectedBooleanAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedBooleanAttr), (intptr_t)setJSTestObjReflectedBooleanAttr THUNK_GENERATOR(0) }, { "reflectedURLAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedURLAttr), (intptr_t)setJSTestObjReflectedURLAttr THUNK_GENERATOR(0) }, { "reflectedNonEmptyURLAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedNonEmptyURLAttr), (intptr_t)setJSTestObjReflectedNonEmptyURLAttr THUNK_GENERATOR(0) }, { "reflectedStringAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedStringAttr), (intptr_t)setJSTestObjReflectedStringAttr THUNK_GENERATOR(0) }, { "reflectedCustomIntegralAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedCustomIntegralAttr), (intptr_t)setJSTestObjReflectedCustomIntegralAttr THUNK_GENERATOR(0) }, { "reflectedCustomBooleanAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedCustomBooleanAttr), (intptr_t)setJSTestObjReflectedCustomBooleanAttr THUNK_GENERATOR(0) }, { "reflectedCustomURLAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedCustomURLAttr), (intptr_t)setJSTestObjReflectedCustomURLAttr THUNK_GENERATOR(0) }, { "reflectedCustomNonEmptyURLAttr", DontDelete, (intptr_t)static_cast(jsTestObjReflectedCustomNonEmptyURLAttr), (intptr_t)setJSTestObjReflectedCustomNonEmptyURLAttr THUNK_GENERATOR(0) }, { "attrWithGetterException", DontDelete, (intptr_t)static_cast(jsTestObjAttrWithGetterException), (intptr_t)setJSTestObjAttrWithGetterException THUNK_GENERATOR(0) }, { "attrWithSetterException", DontDelete, (intptr_t)static_cast(jsTestObjAttrWithSetterException), (intptr_t)setJSTestObjAttrWithSetterException THUNK_GENERATOR(0) }, { "stringAttrWithGetterException", DontDelete, (intptr_t)static_cast(jsTestObjStringAttrWithGetterException), (intptr_t)setJSTestObjStringAttrWithGetterException THUNK_GENERATOR(0) }, { "stringAttrWithSetterException", DontDelete, (intptr_t)static_cast(jsTestObjStringAttrWithSetterException), (intptr_t)setJSTestObjStringAttrWithSetterException THUNK_GENERATOR(0) }, { "customAttr", DontDelete, (intptr_t)static_cast(jsTestObjCustomAttr), (intptr_t)setJSTestObjCustomAttr THUNK_GENERATOR(0) }, { "scriptStringAttr", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjScriptStringAttr), (intptr_t)0 THUNK_GENERATOR(0) }, #if ENABLE(Condition1) { "conditionalAttr1", DontDelete, (intptr_t)static_cast(jsTestObjConditionalAttr1), (intptr_t)setJSTestObjConditionalAttr1 THUNK_GENERATOR(0) }, #endif #if ENABLE(Condition1) && ENABLE(Condition2) { "conditionalAttr2", DontDelete, (intptr_t)static_cast(jsTestObjConditionalAttr2), (intptr_t)setJSTestObjConditionalAttr2 THUNK_GENERATOR(0) }, #endif #if ENABLE(Condition1) || ENABLE(Condition2) { "conditionalAttr3", DontDelete, (intptr_t)static_cast(jsTestObjConditionalAttr3), (intptr_t)setJSTestObjConditionalAttr3 THUNK_GENERATOR(0) }, #endif { "description", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjDescription), (intptr_t)0 THUNK_GENERATOR(0) }, { "id", DontDelete, (intptr_t)static_cast(jsTestObjId), (intptr_t)setJSTestObjId THUNK_GENERATOR(0) }, { "hash", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjHash), (intptr_t)0 THUNK_GENERATOR(0) }, { "constructor", DontEnum | ReadOnly, (intptr_t)static_cast(jsTestObjConstructor), (intptr_t)0 THUNK_GENERATOR(0) }, { 0, 0, 0, 0 THUNK_GENERATOR(0) } }; #undef THUNK_GENERATOR static JSC_CONST_HASHTABLE HashTable JSTestObjTable = { 133, 127, JSTestObjTableValues, 0 }; /* Hash table for constructor */ #if ENABLE(JIT) #define THUNK_GENERATOR(generator) , generator #else #define THUNK_GENERATOR(generator) #endif static const HashTableValue JSTestObjConstructorTableValues[12] = { { "CONST_VALUE_0", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_0), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_1", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_1), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_2", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_2), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_4", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_4), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_8", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_8), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_9", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_9), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_10", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_10), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_11", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_11), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_12", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_12), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_13", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_13), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_14", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_14), (intptr_t)0 THUNK_GENERATOR(0) }, { 0, 0, 0, 0 THUNK_GENERATOR(0) } }; #undef THUNK_GENERATOR static JSC_CONST_HASHTABLE HashTable JSTestObjConstructorTable = { 33, 31, JSTestObjConstructorTableValues, 0 }; COMPILE_ASSERT(0 == TestObj::CONST_VALUE_0, TestObjEnumCONST_VALUE_0IsWrongUseDontCheckEnums); COMPILE_ASSERT(1 == TestObj::CONST_VALUE_1, TestObjEnumCONST_VALUE_1IsWrongUseDontCheckEnums); COMPILE_ASSERT(2 == TestObj::CONST_VALUE_2, TestObjEnumCONST_VALUE_2IsWrongUseDontCheckEnums); COMPILE_ASSERT(4 == TestObj::CONST_VALUE_4, TestObjEnumCONST_VALUE_4IsWrongUseDontCheckEnums); COMPILE_ASSERT(8 == TestObj::CONST_VALUE_8, TestObjEnumCONST_VALUE_8IsWrongUseDontCheckEnums); COMPILE_ASSERT(-1 == TestObj::CONST_VALUE_9, TestObjEnumCONST_VALUE_9IsWrongUseDontCheckEnums); COMPILE_ASSERT("my constant string" == TestObj::CONST_VALUE_10, TestObjEnumCONST_VALUE_10IsWrongUseDontCheckEnums); COMPILE_ASSERT(0xffffffff == TestObj::CONST_VALUE_11, TestObjEnumCONST_VALUE_11IsWrongUseDontCheckEnums); COMPILE_ASSERT(0x01 == TestObj::CONST_VALUE_12, TestObjEnumCONST_VALUE_12IsWrongUseDontCheckEnums); COMPILE_ASSERT(0X20 == TestObj::CONST_VALUE_13, TestObjEnumCONST_VALUE_13IsWrongUseDontCheckEnums); COMPILE_ASSERT(0x1abc == TestObj::CONST_VALUE_14, TestObjEnumCONST_VALUE_14IsWrongUseDontCheckEnums); class JSTestObjConstructor : public DOMConstructorObject { public: JSTestObjConstructor(JSC::ExecState*, JSDOMGlobalObject*); virtual bool getOwnPropertySlot(JSC::ExecState*, const JSC::Identifier&, JSC::PropertySlot&); virtual bool getOwnPropertyDescriptor(JSC::ExecState*, const JSC::Identifier&, JSC::PropertyDescriptor&); virtual const JSC::ClassInfo* classInfo() const { return &s_info; } static const JSC::ClassInfo s_info; static PassRefPtr createStructure(JSC::JSValue prototype) { return JSC::Structure::create(prototype, JSC::TypeInfo(JSC::ObjectType, StructureFlags), AnonymousSlotCount); } protected: static const unsigned StructureFlags = JSC::OverridesGetOwnPropertySlot | JSC::ImplementsHasInstance | DOMConstructorObject::StructureFlags; }; const ClassInfo JSTestObjConstructor::s_info = { "TestObjConstructor", 0, &JSTestObjConstructorTable, 0 }; JSTestObjConstructor::JSTestObjConstructor(ExecState* exec, JSDOMGlobalObject* globalObject) : DOMConstructorObject(JSTestObjConstructor::createStructure(globalObject->objectPrototype()), globalObject) { putDirect(exec->propertyNames().prototype, JSTestObjPrototype::self(exec, globalObject), DontDelete | ReadOnly); } bool JSTestObjConstructor::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) { return getStaticValueSlot(exec, &JSTestObjConstructorTable, this, propertyName, slot); } bool JSTestObjConstructor::getOwnPropertyDescriptor(ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor) { return getStaticValueDescriptor(exec, &JSTestObjConstructorTable, this, propertyName, descriptor); } /* Hash table for prototype */ #if ENABLE(JIT) #define THUNK_GENERATOR(generator) , generator #else #define THUNK_GENERATOR(generator) #endif static const HashTableValue JSTestObjPrototypeTableValues[48] = { { "CONST_VALUE_0", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_0), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_1", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_1), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_2", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_2), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_4", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_4), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_8", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_8), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_9", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_9), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_10", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_10), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_11", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_11), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_12", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_12), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_13", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_13), (intptr_t)0 THUNK_GENERATOR(0) }, { "CONST_VALUE_14", DontDelete | ReadOnly, (intptr_t)static_cast(jsTestObjCONST_VALUE_14), (intptr_t)0 THUNK_GENERATOR(0) }, { "voidMethod", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionVoidMethod), (intptr_t)0 THUNK_GENERATOR(0) }, { "voidMethodWithArgs", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionVoidMethodWithArgs), (intptr_t)3 THUNK_GENERATOR(0) }, { "intMethod", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionIntMethod), (intptr_t)0 THUNK_GENERATOR(0) }, { "intMethodWithArgs", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionIntMethodWithArgs), (intptr_t)3 THUNK_GENERATOR(0) }, { "objMethod", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionObjMethod), (intptr_t)0 THUNK_GENERATOR(0) }, { "objMethodWithArgs", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionObjMethodWithArgs), (intptr_t)3 THUNK_GENERATOR(0) }, { "methodThatRequiresAllArgs", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodThatRequiresAllArgs), (intptr_t)2 THUNK_GENERATOR(0) }, { "methodThatRequiresAllArgsAndThrows", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodThatRequiresAllArgsAndThrows), (intptr_t)2 THUNK_GENERATOR(0) }, { "serializedValue", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionSerializedValue), (intptr_t)1 THUNK_GENERATOR(0) }, { "idbKey", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionIdbKey), (intptr_t)1 THUNK_GENERATOR(0) }, { "optionsObject", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionOptionsObject), (intptr_t)2 THUNK_GENERATOR(0) }, { "methodWithException", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodWithException), (intptr_t)0 THUNK_GENERATOR(0) }, { "customMethod", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionCustomMethod), (intptr_t)0 THUNK_GENERATOR(0) }, { "customMethodWithArgs", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionCustomMethodWithArgs), (intptr_t)3 THUNK_GENERATOR(0) }, { "customArgsAndException", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionCustomArgsAndException), (intptr_t)1 THUNK_GENERATOR(0) }, { "addEventListener", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionAddEventListener), (intptr_t)3 THUNK_GENERATOR(0) }, { "removeEventListener", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionRemoveEventListener), (intptr_t)3 THUNK_GENERATOR(0) }, { "withDynamicFrame", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithDynamicFrame), (intptr_t)0 THUNK_GENERATOR(0) }, { "withDynamicFrameAndArg", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithDynamicFrameAndArg), (intptr_t)1 THUNK_GENERATOR(0) }, { "withDynamicFrameAndOptionalArg", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithDynamicFrameAndOptionalArg), (intptr_t)2 THUNK_GENERATOR(0) }, { "withDynamicFrameAndUserGesture", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithDynamicFrameAndUserGesture), (intptr_t)1 THUNK_GENERATOR(0) }, { "withDynamicFrameAndUserGestureASAD", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithDynamicFrameAndUserGestureASAD), (intptr_t)2 THUNK_GENERATOR(0) }, { "withScriptStateVoid", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithScriptStateVoid), (intptr_t)0 THUNK_GENERATOR(0) }, { "withScriptStateObj", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithScriptStateObj), (intptr_t)0 THUNK_GENERATOR(0) }, { "withScriptStateVoidException", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithScriptStateVoidException), (intptr_t)0 THUNK_GENERATOR(0) }, { "withScriptStateObjException", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithScriptStateObjException), (intptr_t)0 THUNK_GENERATOR(0) }, { "withScriptExecutionContext", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionWithScriptExecutionContext), (intptr_t)0 THUNK_GENERATOR(0) }, { "methodWithOptionalArg", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodWithOptionalArg), (intptr_t)1 THUNK_GENERATOR(0) }, { "methodWithNonOptionalArgAndOptionalArg", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodWithNonOptionalArgAndOptionalArg), (intptr_t)2 THUNK_GENERATOR(0) }, { "methodWithNonOptionalArgAndTwoOptionalArgs", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodWithNonOptionalArgAndTwoOptionalArgs), (intptr_t)3 THUNK_GENERATOR(0) }, { "methodWithCallbackArg", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodWithCallbackArg), (intptr_t)1 THUNK_GENERATOR(0) }, { "methodWithNonCallbackArgAndCallbackArg", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodWithNonCallbackArgAndCallbackArg), (intptr_t)2 THUNK_GENERATOR(0) }, { "methodWithCallbackAndOptionalArg", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionMethodWithCallbackAndOptionalArg), (intptr_t)1 THUNK_GENERATOR(0) }, { "overloadedMethod", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionOverloadedMethod), (intptr_t)2 THUNK_GENERATOR(0) }, { "classMethod", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionClassMethod), (intptr_t)0 THUNK_GENERATOR(0) }, { "classMethodWithOptional", DontDelete | Function, (intptr_t)static_cast(jsTestObjPrototypeFunctionClassMethodWithOptional), (intptr_t)1 THUNK_GENERATOR(0) }, { 0, 0, 0, 0 THUNK_GENERATOR(0) } }; #undef THUNK_GENERATOR static JSC_CONST_HASHTABLE HashTable JSTestObjPrototypeTable = { 136, 127, JSTestObjPrototypeTableValues, 0 }; const ClassInfo JSTestObjPrototype::s_info = { "TestObjPrototype", 0, &JSTestObjPrototypeTable, 0 }; JSObject* JSTestObjPrototype::self(ExecState* exec, JSGlobalObject* globalObject) { return getDOMPrototype(exec, globalObject); } bool JSTestObjPrototype::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) { return getStaticPropertySlot(exec, &JSTestObjPrototypeTable, this, propertyName, slot); } bool JSTestObjPrototype::getOwnPropertyDescriptor(ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor) { return getStaticPropertyDescriptor(exec, &JSTestObjPrototypeTable, this, propertyName, descriptor); } const ClassInfo JSTestObj::s_info = { "TestObj", 0, &JSTestObjTable, 0 }; JSTestObj::JSTestObj(NonNullPassRefPtr structure, JSDOMGlobalObject* globalObject, PassRefPtr impl) : DOMObjectWithGlobalPointer(structure, globalObject) , m_impl(impl) { } JSTestObj::~JSTestObj() { forgetDOMObject(this, impl()); } JSObject* JSTestObj::createPrototype(ExecState* exec, JSGlobalObject* globalObject) { return new (exec) JSTestObjPrototype(globalObject, JSTestObjPrototype::createStructure(globalObject->objectPrototype())); } bool JSTestObj::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) { return getStaticValueSlot(exec, &JSTestObjTable, this, propertyName, slot); } bool JSTestObj::getOwnPropertyDescriptor(ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor) { return getStaticValueDescriptor(exec, &JSTestObjTable, this, propertyName, descriptor); } JSValue jsTestObjReadOnlyIntAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->readOnlyIntAttr()); return result; } JSValue jsTestObjReadOnlyStringAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->readOnlyStringAttr()); return result; } JSValue jsTestObjReadOnlyTestObjAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->readOnlyTestObjAttr())); return result; } JSValue jsTestObjShortAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->shortAttr()); return result; } JSValue jsTestObjUnsignedShortAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->unsignedShortAttr()); return result; } JSValue jsTestObjIntAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->intAttr()); return result; } JSValue jsTestObjLongLongAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->longLongAttr()); return result; } JSValue jsTestObjUnsignedLongLongAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->unsignedLongLongAttr()); return result; } JSValue jsTestObjStringAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->stringAttr()); return result; } JSValue jsTestObjTestObjAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->testObjAttr())); return result; } JSValue jsTestObjXMLObjAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->xmlObjAttr())); return result; } JSValue jsTestObjCreate(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->isCreate()); return result; } JSValue jsTestObjReflectedStringAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->getAttribute(WebCore::HTMLNames::reflectedstringattrAttr)); return result; } JSValue jsTestObjReflectedIntegralAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->getIntegralAttribute(WebCore::HTMLNames::reflectedintegralattrAttr)); return result; } JSValue jsTestObjReflectedUnsignedIntegralAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(std::max(0, imp->getIntegralAttribute(WebCore::HTMLNames::reflectedunsignedintegralattrAttr))); return result; } JSValue jsTestObjReflectedBooleanAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->hasAttribute(WebCore::HTMLNames::reflectedbooleanattrAttr)); return result; } JSValue jsTestObjReflectedURLAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->getURLAttribute(WebCore::HTMLNames::reflectedurlattrAttr)); return result; } JSValue jsTestObjReflectedNonEmptyURLAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->getNonEmptyURLAttribute(WebCore::HTMLNames::reflectednonemptyurlattrAttr)); return result; } JSValue jsTestObjReflectedStringAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->getAttribute(WebCore::HTMLNames::customContentStringAttrAttr)); return result; } JSValue jsTestObjReflectedCustomIntegralAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->getIntegralAttribute(WebCore::HTMLNames::customContentIntegralAttrAttr)); return result; } JSValue jsTestObjReflectedCustomBooleanAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->hasAttribute(WebCore::HTMLNames::customContentBooleanAttrAttr)); return result; } JSValue jsTestObjReflectedCustomURLAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->getURLAttribute(WebCore::HTMLNames::customContentURLAttrAttr)); return result; } JSValue jsTestObjReflectedCustomNonEmptyURLAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->getNonEmptyURLAttribute(WebCore::HTMLNames::customContentNonEmptyURLAttrAttr)); return result; } JSValue jsTestObjAttrWithGetterException(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); ExceptionCode ec = 0; TestObj* imp = static_cast(castedThis->impl()); JSC::JSValue result = jsNumber(imp->attrWithGetterException(ec)); setDOMException(exec, ec); return result; } JSValue jsTestObjAttrWithSetterException(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->attrWithSetterException()); return result; } JSValue jsTestObjStringAttrWithGetterException(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); ExceptionCode ec = 0; TestObj* imp = static_cast(castedThis->impl()); JSC::JSValue result = jsString(exec, imp->stringAttrWithGetterException(ec)); setDOMException(exec, ec); return result; } JSValue jsTestObjStringAttrWithSetterException(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->stringAttrWithSetterException()); return result; } JSValue jsTestObjCustomAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); return castedThis->customAttr(exec); } JSValue jsTestObjScriptStringAttr(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsOwnedStringOrNull(exec, imp->scriptStringAttr()); return result; } #if ENABLE(Condition1) JSValue jsTestObjConditionalAttr1(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->conditionalAttr1()); return result; } #endif #if ENABLE(Condition1) && ENABLE(Condition2) JSValue jsTestObjConditionalAttr2(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->conditionalAttr2()); return result; } #endif #if ENABLE(Condition1) || ENABLE(Condition2) JSValue jsTestObjConditionalAttr3(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->conditionalAttr3()); return result; } #endif JSValue jsTestObjDescription(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->description()); return result; } JSValue jsTestObjId(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->id()); return result; } JSValue jsTestObjHash(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); TestObj* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->hash()); return result; } JSValue jsTestObjConstructor(ExecState* exec, JSValue slotBase, const Identifier&) { JSTestObj* domObject = static_cast(asObject(slotBase)); return JSTestObj::getConstructor(exec, domObject->globalObject()); } void JSTestObj::put(ExecState* exec, const Identifier& propertyName, JSValue value, PutPropertySlot& slot) { lookupPut(exec, propertyName, value, &JSTestObjTable, this, slot); } void setJSTestObjShortAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setShortAttr(value.toInt32(exec)); } void setJSTestObjUnsignedShortAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setUnsignedShortAttr(value.toUInt32(exec)); } void setJSTestObjIntAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setIntAttr(value.toInt32(exec)); } void setJSTestObjLongLongAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setLongLongAttr(static_cast(value.toInteger(exec))); } void setJSTestObjUnsignedLongLongAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setUnsignedLongLongAttr(static_cast(value.toInteger(exec))); } void setJSTestObjStringAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setStringAttr(ustringToString(value.toString(exec))); } void setJSTestObjTestObjAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setTestObjAttr(toTestObj(value)); } void setJSTestObjXMLObjAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setXMLObjAttr(toTestObj(value)); } void setJSTestObjCreate(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setCreate(value.toBoolean(exec)); } void setJSTestObjReflectedStringAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setAttribute(WebCore::HTMLNames::reflectedstringattrAttr, valueToStringWithNullCheck(exec, value)); } void setJSTestObjReflectedIntegralAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setIntegralAttribute(WebCore::HTMLNames::reflectedintegralattrAttr, value.toInt32(exec)); } void setJSTestObjReflectedUnsignedIntegralAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setUnsignedIntegralAttribute(WebCore::HTMLNames::reflectedunsignedintegralattrAttr, value.toUInt32(exec)); } void setJSTestObjReflectedBooleanAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setBooleanAttribute(WebCore::HTMLNames::reflectedbooleanattrAttr, value.toBoolean(exec)); } void setJSTestObjReflectedURLAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setAttribute(WebCore::HTMLNames::reflectedurlattrAttr, valueToStringWithNullCheck(exec, value)); } void setJSTestObjReflectedNonEmptyURLAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setAttribute(WebCore::HTMLNames::reflectednonemptyurlattrAttr, valueToStringWithNullCheck(exec, value)); } void setJSTestObjReflectedStringAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setAttribute(WebCore::HTMLNames::customContentStringAttrAttr, valueToStringWithNullCheck(exec, value)); } void setJSTestObjReflectedCustomIntegralAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setIntegralAttribute(WebCore::HTMLNames::customContentIntegralAttrAttr, value.toInt32(exec)); } void setJSTestObjReflectedCustomBooleanAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setBooleanAttribute(WebCore::HTMLNames::customContentBooleanAttrAttr, value.toBoolean(exec)); } void setJSTestObjReflectedCustomURLAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setAttribute(WebCore::HTMLNames::customContentURLAttrAttr, valueToStringWithNullCheck(exec, value)); } void setJSTestObjReflectedCustomNonEmptyURLAttr(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setAttribute(WebCore::HTMLNames::customContentNonEmptyURLAttrAttr, valueToStringWithNullCheck(exec, value)); } void setJSTestObjAttrWithGetterException(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->setAttrWithGetterException(value.toInt32(exec), ec); setDOMException(exec, ec); } void setJSTestObjAttrWithSetterException(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->setAttrWithSetterException(value.toInt32(exec), ec); setDOMException(exec, ec); } void setJSTestObjStringAttrWithGetterException(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->setStringAttrWithGetterException(ustringToString(value.toString(exec)), ec); setDOMException(exec, ec); } void setJSTestObjStringAttrWithSetterException(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->setStringAttrWithSetterException(ustringToString(value.toString(exec)), ec); setDOMException(exec, ec); } void setJSTestObjCustomAttr(ExecState* exec, JSObject* thisObject, JSValue value) { static_cast(thisObject)->setCustomAttr(exec, value); } #if ENABLE(Condition1) void setJSTestObjConditionalAttr1(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setConditionalAttr1(value.toInt32(exec)); } #endif #if ENABLE(Condition1) && ENABLE(Condition2) void setJSTestObjConditionalAttr2(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setConditionalAttr2(value.toInt32(exec)); } #endif #if ENABLE(Condition1) || ENABLE(Condition2) void setJSTestObjConditionalAttr3(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setConditionalAttr3(value.toInt32(exec)); } #endif void setJSTestObjId(ExecState* exec, JSObject* thisObject, JSValue value) { JSTestObj* castedThis = static_cast(thisObject); TestObj* imp = static_cast(castedThis->impl()); imp->setId(value.toInt32(exec)); } JSValue JSTestObj::getConstructor(ExecState* exec, JSGlobalObject* globalObject) { return getDOMConstructor(exec, static_cast(globalObject)); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionVoidMethod(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); imp->voidMethod(); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionVoidMethodWithArgs(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); const String& strArg = ustringToString(exec->argument(1).toString(exec)); if (exec->hadException()) return JSValue::encode(jsUndefined()); TestObj* objArg = toTestObj(exec->argument(2)); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->voidMethodWithArgs(intArg, strArg, objArg); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionIntMethod(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); JSC::JSValue result = jsNumber(imp->intMethod()); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionIntMethodWithArgs(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); const String& strArg = ustringToString(exec->argument(1).toString(exec)); if (exec->hadException()) return JSValue::encode(jsUndefined()); TestObj* objArg = toTestObj(exec->argument(2)); if (exec->hadException()) return JSValue::encode(jsUndefined()); JSC::JSValue result = jsNumber(imp->intMethodWithArgs(intArg, strArg, objArg)); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionObjMethod(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); JSC::JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->objMethod())); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionObjMethodWithArgs(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); const String& strArg = ustringToString(exec->argument(1).toString(exec)); if (exec->hadException()) return JSValue::encode(jsUndefined()); TestObj* objArg = toTestObj(exec->argument(2)); if (exec->hadException()) return JSValue::encode(jsUndefined()); JSC::JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->objMethodWithArgs(intArg, strArg, objArg))); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodThatRequiresAllArgs(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); if (exec->argumentCount() < 2) return JSValue::encode(jsUndefined()); const String& strArg = ustringToString(exec->argument(0).toString(exec)); if (exec->hadException()) return JSValue::encode(jsUndefined()); TestObj* objArg = toTestObj(exec->argument(1)); if (exec->hadException()) return JSValue::encode(jsUndefined()); JSC::JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->methodThatRequiresAllArgs(strArg, objArg))); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodThatRequiresAllArgsAndThrows(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); if (exec->argumentCount() < 2) return throwVMError(exec, createSyntaxError(exec, "Not enough arguments")); ExceptionCode ec = 0; const String& strArg = ustringToString(exec->argument(0).toString(exec)); if (exec->hadException()) return JSValue::encode(jsUndefined()); TestObj* objArg = toTestObj(exec->argument(1)); if (exec->hadException()) return JSValue::encode(jsUndefined()); JSC::JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->methodThatRequiresAllArgsAndThrows(strArg, objArg, ec))); setDOMException(exec, ec); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionSerializedValue(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); RefPtr serializedArg = SerializedScriptValue::create(exec, exec->argument(0)); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->serializedValue(serializedArg); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionIdbKey(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); RefPtr key = createIDBKeyFromValue(exec, exec->argument(0)); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->idbKey(key); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionOptionsObject(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); OptionsObject* oo = toOptionsObject(exec->argument(0)); if (exec->hadException()) return JSValue::encode(jsUndefined()); int argsCount = exec->argumentCount(); if (argsCount <= 1) { imp->optionsObject(oo); return JSValue::encode(jsUndefined()); } OptionsObject* ooo = toOptionsObject(exec->argument(1)); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->optionsObject(oo, ooo); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodWithException(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->methodWithException(ec); setDOMException(exec, ec); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionCustomMethod(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); return JSValue::encode(castedThis->customMethod(exec)); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionCustomMethodWithArgs(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); return JSValue::encode(castedThis->customMethodWithArgs(exec)); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionCustomArgsAndException(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; RefPtr scriptArguments(createScriptArguments(exec, 1)); size_t maxStackSize = imp->shouldCaptureFullStackTrace() ? ScriptCallStack::maxCallStackSizeToCapture : 1; RefPtr callStack(createScriptCallStack(exec, maxStackSize)); log* intArg = tolog(exec->argument(0)); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->customArgsAndException(intArg, scriptArguments, callStack, ec); setDOMException(exec, ec); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionAddEventListener(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); JSValue listener = exec->argument(1); if (!listener.isObject()) return JSValue::encode(jsUndefined()); imp->addEventListener(ustringToAtomicString(exec->argument(0).toString(exec)), JSEventListener::create(asObject(listener), castedThis, false, currentWorld(exec)), exec->argument(2).toBoolean(exec)); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionRemoveEventListener(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); JSValue listener = exec->argument(1); if (!listener.isObject()) return JSValue::encode(jsUndefined()); imp->removeEventListener(ustringToAtomicString(exec->argument(0).toString(exec)), JSEventListener::create(asObject(listener), castedThis, false, currentWorld(exec)).get(), exec->argument(2).toBoolean(exec)); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithDynamicFrame(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); Frame* dynamicFrame = toDynamicFrame(exec); if (!dynamicFrame) return JSValue::encode(jsUndefined()); imp->withDynamicFrame(dynamicFrame); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithDynamicFrameAndArg(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); Frame* dynamicFrame = toDynamicFrame(exec); if (!dynamicFrame) return JSValue::encode(jsUndefined()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->withDynamicFrameAndArg(dynamicFrame, intArg); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithDynamicFrameAndOptionalArg(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); Frame* dynamicFrame = toDynamicFrame(exec); if (!dynamicFrame) return JSValue::encode(jsUndefined()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); int argsCount = exec->argumentCount(); if (argsCount <= 1) { imp->withDynamicFrameAndOptionalArg(dynamicFrame, intArg); return JSValue::encode(jsUndefined()); } int optionalArg = exec->argument(1).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->withDynamicFrameAndOptionalArg(dynamicFrame, intArg, optionalArg); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithDynamicFrameAndUserGesture(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); Frame* dynamicFrame = toDynamicFrame(exec); if (!dynamicFrame) return JSValue::encode(jsUndefined()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->withDynamicFrameAndUserGesture(dynamicFrame, intArg, processingUserGesture()); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithDynamicFrameAndUserGestureASAD(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); Frame* dynamicFrame = toDynamicFrame(exec); if (!dynamicFrame) return JSValue::encode(jsUndefined()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); int argsCount = exec->argumentCount(); if (argsCount <= 1) { imp->withDynamicFrameAndUserGestureASAD(dynamicFrame, intArg); return JSValue::encode(jsUndefined()); } int optionalArg = exec->argument(1).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->withDynamicFrameAndUserGestureASAD(dynamicFrame, intArg, optionalArg, processingUserGesture()); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithScriptStateVoid(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); imp->withScriptStateVoid(exec); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithScriptStateObj(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); JSC::JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->withScriptStateObj(exec))); if (exec->hadException()) return JSValue::encode(jsUndefined()); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithScriptStateVoidException(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->withScriptStateVoidException(exec, ec); setDOMException(exec, ec); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithScriptStateObjException(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; JSC::JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->withScriptStateObjException(exec, ec))); setDOMException(exec, ec); if (exec->hadException()) return JSValue::encode(jsUndefined()); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionWithScriptExecutionContext(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); ScriptExecutionContext* scriptContext = static_cast(exec->lexicalGlobalObject())->scriptExecutionContext(); if (!scriptContext) return JSValue::encode(jsUndefined()); imp->withScriptExecutionContext(scriptContext); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodWithOptionalArg(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int argsCount = exec->argumentCount(); if (argsCount <= 0) { imp->methodWithOptionalArg(); return JSValue::encode(jsUndefined()); } int opt = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->methodWithOptionalArg(opt); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodWithNonOptionalArgAndOptionalArg(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int nonOpt = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); int argsCount = exec->argumentCount(); if (argsCount <= 1) { imp->methodWithNonOptionalArgAndOptionalArg(nonOpt); return JSValue::encode(jsUndefined()); } int opt = exec->argument(1).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->methodWithNonOptionalArgAndOptionalArg(nonOpt, opt); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodWithNonOptionalArgAndTwoOptionalArgs(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int nonOpt = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); int argsCount = exec->argumentCount(); if (argsCount <= 1) { imp->methodWithNonOptionalArgAndTwoOptionalArgs(nonOpt); return JSValue::encode(jsUndefined()); } int opt1 = exec->argument(1).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); int opt2 = exec->argument(2).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->methodWithNonOptionalArgAndTwoOptionalArgs(nonOpt, opt1, opt2); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodWithCallbackArg(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); if (exec->argumentCount() <= 0 || !exec->argument(0).isObject()) { setDOMException(exec, TYPE_MISMATCH_ERR); return JSValue::encode(jsUndefined()); } RefPtr callback = JSTestCallback::create(asObject(exec->argument(0)), castedThis->globalObject()); imp->methodWithCallbackArg(callback); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodWithNonCallbackArgAndCallbackArg(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int nonCallback = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); if (exec->argumentCount() <= 1 || !exec->argument(1).isObject()) { setDOMException(exec, TYPE_MISMATCH_ERR); return JSValue::encode(jsUndefined()); } RefPtr callback = JSTestCallback::create(asObject(exec->argument(1)), castedThis->globalObject()); imp->methodWithNonCallbackArgAndCallbackArg(nonCallback, callback); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionMethodWithCallbackAndOptionalArg(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); RefPtr callback; if (exec->argumentCount() > 0 && !exec->argument(0).isNull() && !exec->argument(0).isUndefined()) { if (!exec->argument(0).isObject()) { setDOMException(exec, TYPE_MISMATCH_ERR); return JSValue::encode(jsUndefined()); } callback = JSTestCallback::create(asObject(exec->argument(0)), castedThis->globalObject()); } imp->methodWithCallbackAndOptionalArg(callback); return JSValue::encode(jsUndefined()); } static EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionOverloadedMethod1(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); TestObj* objArg = toTestObj(exec->argument(0)); if (exec->hadException()) return JSValue::encode(jsUndefined()); const String& strArg = ustringToString(exec->argument(1).toString(exec)); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->overloadedMethod(objArg, strArg); return JSValue::encode(jsUndefined()); } static EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionOverloadedMethod2(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); TestObj* objArg = toTestObj(exec->argument(0)); if (exec->hadException()) return JSValue::encode(jsUndefined()); int argsCount = exec->argumentCount(); if (argsCount <= 1) { imp->overloadedMethod(objArg); return JSValue::encode(jsUndefined()); } int intArg = exec->argument(1).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->overloadedMethod(objArg, intArg); return JSValue::encode(jsUndefined()); } static EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionOverloadedMethod3(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); const String& strArg = ustringToString(exec->argument(0).toString(exec)); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->overloadedMethod(strArg); return JSValue::encode(jsUndefined()); } static EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionOverloadedMethod4(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int intArg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); imp->overloadedMethod(intArg); return JSValue::encode(jsUndefined()); } static EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionOverloadedMethod5(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); if (exec->argumentCount() <= 0 || !exec->argument(0).isObject()) { setDOMException(exec, TYPE_MISMATCH_ERR); return JSValue::encode(jsUndefined()); } RefPtr callback = JSTestCallback::create(asObject(exec->argument(0)), castedThis->globalObject()); imp->overloadedMethod(callback); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionOverloadedMethod(ExecState* exec) { if ((exec->argumentCount() == 2 && (exec->argument(0).isNull() || (exec->argument(0).isObject() && asObject(exec->argument(0))->inherits(&JSTestObj::s_info))) && (exec->argument(1).isNull() || exec->argument(1).isUndefined() || exec->argument(1).isString() || exec->argument(1).isObject()))) return jsTestObjPrototypeFunctionOverloadedMethod1(exec); if ((exec->argumentCount() == 1 && (exec->argument(0).isNull() || (exec->argument(0).isObject() && asObject(exec->argument(0))->inherits(&JSTestObj::s_info)))) || (exec->argumentCount() == 2 && (exec->argument(0).isNull() || (exec->argument(0).isObject() && asObject(exec->argument(0))->inherits(&JSTestObj::s_info))))) return jsTestObjPrototypeFunctionOverloadedMethod2(exec); if ((exec->argumentCount() == 1 && (exec->argument(0).isNull() || exec->argument(0).isUndefined() || exec->argument(0).isString() || exec->argument(0).isObject()))) return jsTestObjPrototypeFunctionOverloadedMethod3(exec); if (exec->argumentCount() == 1) return jsTestObjPrototypeFunctionOverloadedMethod4(exec); if ((exec->argumentCount() == 1 && (exec->argument(0).isNull() || exec->argument(0).isObject()))) return jsTestObjPrototypeFunctionOverloadedMethod5(exec); return throwVMTypeError(exec); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionClassMethod(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); imp->classMethod(); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsTestObjPrototypeFunctionClassMethodWithOptional(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSTestObj::s_info)) return throwVMTypeError(exec); JSTestObj* castedThis = static_cast(asObject(thisValue)); TestObj* imp = static_cast(castedThis->impl()); int argsCount = exec->argumentCount(); if (argsCount <= 0) { JSC::JSValue result = jsNumber(imp->classMethodWithOptional()); return JSValue::encode(result); } int arg = exec->argument(0).toInt32(exec); if (exec->hadException()) return JSValue::encode(jsUndefined()); JSC::JSValue result = jsNumber(imp->classMethodWithOptional(arg)); return JSValue::encode(result); } // Constant getters JSValue jsTestObjCONST_VALUE_0(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(0)); } JSValue jsTestObjCONST_VALUE_1(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(1)); } JSValue jsTestObjCONST_VALUE_2(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(2)); } JSValue jsTestObjCONST_VALUE_4(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(4)); } JSValue jsTestObjCONST_VALUE_8(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(8)); } JSValue jsTestObjCONST_VALUE_9(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(-1)); } JSValue jsTestObjCONST_VALUE_10(ExecState* exec, JSValue, const Identifier&) { return jsStringOrNull(exec, String("my constant string")); } JSValue jsTestObjCONST_VALUE_11(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(0xffffffff)); } JSValue jsTestObjCONST_VALUE_12(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(0x01)); } JSValue jsTestObjCONST_VALUE_13(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(0X20)); } JSValue jsTestObjCONST_VALUE_14(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(0x1abc)); } JSC::JSValue toJS(JSC::ExecState* exec, JSDOMGlobalObject* globalObject, TestObj* object) { return getDOMObjectWrapper(exec, globalObject, object); } TestObj* toTestObj(JSC::JSValue value) { return value.inherits(&JSTestObj::s_info) ? static_cast(asObject(value))->impl() : 0; } }