X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/14957cd040308e3eeec43d26bae5d76da13fcd85..6fe7ccc865dc7d7541b93c5bcaf6368d2c98a174:/API/JSCallbackConstructor.cpp diff --git a/API/JSCallbackConstructor.cpp b/API/JSCallbackConstructor.cpp index fa9d216..c8b4c06 100644 --- a/API/JSCallbackConstructor.cpp +++ b/API/JSCallbackConstructor.cpp @@ -36,13 +36,18 @@ namespace JSC { -const ClassInfo JSCallbackConstructor::s_info = { "CallbackConstructor", &JSObjectWithGlobalObject::s_info, 0, 0 }; +const ClassInfo JSCallbackConstructor::s_info = { "CallbackConstructor", &JSNonFinalObject::s_info, 0, 0, CREATE_METHOD_TABLE(JSCallbackConstructor) }; JSCallbackConstructor::JSCallbackConstructor(JSGlobalObject* globalObject, Structure* structure, JSClassRef jsClass, JSObjectCallAsConstructorCallback callback) - : JSObjectWithGlobalObject(globalObject, structure) + : JSNonFinalObject(globalObject->globalData(), structure) , m_class(jsClass) , m_callback(callback) { +} + +void JSCallbackConstructor::finishCreation(JSGlobalObject* globalObject, JSClassRef jsClass) +{ + Base::finishCreation(globalObject->globalData()); ASSERT(inherits(&s_info)); if (m_class) JSClassRetain(jsClass); @@ -54,13 +59,18 @@ JSCallbackConstructor::~JSCallbackConstructor() JSClassRelease(m_class); } +void JSCallbackConstructor::destroy(JSCell* cell) +{ + jsCast(cell)->JSCallbackConstructor::~JSCallbackConstructor(); +} + static EncodedJSValue JSC_HOST_CALL constructJSCallback(ExecState* exec) { JSObject* constructor = exec->callee(); JSContextRef ctx = toRef(exec); JSObjectRef constructorRef = toRef(constructor); - JSObjectCallAsConstructorCallback callback = static_cast(constructor)->callback(); + JSObjectCallAsConstructorCallback callback = jsCast(constructor)->callback(); if (callback) { int argumentCount = static_cast(exec->argumentCount()); Vector arguments(argumentCount); @@ -75,13 +85,16 @@ static EncodedJSValue JSC_HOST_CALL constructJSCallback(ExecState* exec) } if (exception) throwError(exec, toJS(exec, exception)); + // result must be a valid JSValue. + if (!result) + return throwVMTypeError(exec); return JSValue::encode(toJS(result)); } - return JSValue::encode(toJS(JSObjectMake(ctx, static_cast(constructor)->classRef(), 0))); + return JSValue::encode(toJS(JSObjectMake(ctx, jsCast(constructor)->classRef(), 0))); } -ConstructType JSCallbackConstructor::getConstructData(ConstructData& constructData) +ConstructType JSCallbackConstructor::getConstructData(JSCell*, ConstructData& constructData) { constructData.native.function = constructJSCallback; return ConstructTypeHost;