static EncodedJSValue JSC_HOST_CALL constructJSCallback(ExecState* exec) { JSObject* constructor = exec->callee(); JSContextRef ctx = toRef(exec); JSObjectRef constructorRef = toRef(constructor); JSObjectCallAsConstructorCallback callback = static_cast<JSCallbackConstructor*>(constructor)->callback(); if (callback) { int argumentCount = static_cast<int>(exec->argumentCount()); Vector<JSValueRef, 16> arguments(argumentCount); for (int i = 0; i < argumentCount; i++) arguments[i] = toRef(exec, exec->argument(i)); JSValueRef exception = 0; JSObjectRef result; { APICallbackShim callbackShim(exec); result = callback(ctx, constructorRef, argumentCount, arguments.data(), &exception); } if (exception) throwError(exec, toJS(exec, exception)); return JSValue::encode(toJS(result)); } return JSValue::encode(toJS(JSObjectMake(ctx, static_cast<JSCallbackConstructor*>(constructor)->classRef(), 0))); }
EncodedJSValue JSCallbackFunction::call(ExecState* exec) { JSContextRef execRef = toRef(exec); JSObjectRef functionRef = toRef(exec->callee()); JSObjectRef thisObjRef = toRef(exec->hostThisValue().toThisObject(exec)); int argumentCount = static_cast<int>(exec->argumentCount()); Vector<JSValueRef, 16> arguments(argumentCount); for (int i = 0; i < argumentCount; i++) arguments[i] = toRef(exec, exec->argument(i)); JSValueRef exception = 0; JSValueRef result; { APICallbackShim callbackShim(exec); result = static_cast<JSCallbackFunction*>(toJS(functionRef))->m_callback(execRef, functionRef, thisObjRef, argumentCount, arguments.data(), &exception); } if (exception) throwError(exec, toJS(exec, exception)); // result must be a valid JSValue. if (!result) return throwVMTypeError(exec); return JSValue::encode(toJS(exec, result)); }
static EncodedJSValue JSC_HOST_CALL constructJSCallback(ExecState* exec) { JSObject* constructor = exec->callee(); JSContextRef ctx = toRef(exec); JSObjectRef constructorRef = toRef(constructor); JSObjectCallAsConstructorCallback callback = jsCast<JSCallbackConstructor*>(constructor)->callback(); if (callback) { size_t argumentCount = exec->argumentCount(); Vector<JSValueRef, 16> arguments; arguments.reserveInitialCapacity(argumentCount); for (size_t i = 0; i < argumentCount; ++i) arguments.uncheckedAppend(toRef(exec, exec->uncheckedArgument(i))); JSValueRef exception = 0; JSObjectRef result; { APICallbackShim callbackShim(exec); result = callback(ctx, constructorRef, argumentCount, arguments.data(), &exception); } if (exception) exec->vm().throwException(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, jsCast<JSCallbackConstructor*>(constructor)->classRef(), 0))); }
static JSObject* constructJSCallback(ExecState* exec, JSObject* constructor, const ArgList& args) { JSContextRef ctx = toRef(exec); JSObjectRef constructorRef = toRef(constructor); JSObjectCallAsConstructorCallback callback = static_cast<JSCallbackConstructor*>(constructor)->callback(); if (callback) { int argumentCount = static_cast<int>(args.size()); Vector<JSValueRef, 16> arguments(argumentCount); for (int i = 0; i < argumentCount; i++) arguments[i] = toRef(exec, args.at(i)); JSValueRef exception = 0; JSObjectRef result; { APICallbackShim callbackShim(exec); result = callback(ctx, constructorRef, argumentCount, arguments.data(), &exception); } if (exception) exec->setException(toJS(exec, exception)); return toJS(result); } return toJS(JSObjectMake(ctx, static_cast<JSCallbackConstructor*>(constructor)->classRef(), 0)); }
EncodedJSValue JSCallbackFunction::call(ExecState* exec) { JSContextRef execRef = toRef(exec); JSObjectRef functionRef = toRef(exec->callee()); JSObjectRef thisObjRef = toRef(exec->hostThisValue().toThisObject(exec)); size_t argumentCount = exec->argumentCount(); Vector<JSValueRef, 16> arguments; arguments.reserveInitialCapacity(argumentCount); for (size_t i = 0; i < argumentCount; ++i) arguments.uncheckedAppend(toRef(exec, exec->argument(i))); JSValueRef exception = 0; JSValueRef result; { APICallbackShim callbackShim(exec); result = jsCast<JSCallbackFunction*>(toJS(functionRef))->m_callback(execRef, functionRef, thisObjRef, argumentCount, arguments.data(), &exception); } if (exception) throwError(exec, toJS(exec, exception)); // result must be a valid JSValue. if (!result) return JSValue::encode(jsUndefined()); return JSValue::encode(toJS(exec, result)); }
TiValue TiCallbackFunction::call(TiExcState* exec, TiObject* functionObject, TiValue thisValue, const ArgList& args) { TiContextRef execRef = toRef(exec); TiObjectRef functionRef = toRef(functionObject); TiObjectRef thisObjRef = toRef(thisValue.toThisObject(exec)); int argumentCount = static_cast<int>(args.size()); Vector<TiValueRef, 16> arguments(argumentCount); for (int i = 0; i < argumentCount; i++) arguments[i] = toRef(exec, args.at(i)); TiValueRef exception = 0; TiValueRef result; { APICallbackShim callbackShim(exec); result = static_cast<TiCallbackFunction*>(functionObject)->m_callback(execRef, functionRef, thisObjRef, argumentCount, arguments.data(), &exception); } if (exception) exec->setException(toJS(exec, exception)); return toJS(exec, result); }
EncodedTiValue TiCallbackFunction::call(TiExcState* exec) { TiContextRef execRef = toRef(exec); TiObjectRef functionRef = toRef(exec->callee()); TiObjectRef thisObjRef = toRef(exec->hostThisValue().toThisObject(exec)); int argumentCount = static_cast<int>(exec->argumentCount()); Vector<TiValueRef, 16> arguments(argumentCount); for (int i = 0; i < argumentCount; i++) arguments[i] = toRef(exec, exec->argument(i)); TiValueRef exception = 0; TiValueRef result; { APICallbackShim callbackShim(exec); result = static_cast<TiCallbackFunction*>(toJS(functionRef))->m_callback(execRef, functionRef, thisObjRef, argumentCount, arguments.data(), &exception); } if (exception) throwError(exec, toJS(exec, exception)); return TiValue::encode(toJS(exec, result)); }