X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/4e4e5a6f2694187498445a6ac6f1634ce8141119..81345200c95645a1b0d2635520f96ad55dfde63f:/runtime/StringConstructor.cpp diff --git a/runtime/StringConstructor.cpp b/runtime/StringConstructor.cpp index 94bee43..f8221d7 100644 --- a/runtime/StringConstructor.cpp +++ b/runtime/StringConstructor.cpp @@ -21,71 +21,99 @@ #include "config.h" #include "StringConstructor.h" +#include "Executable.h" +#include "JITCode.h" #include "JSFunction.h" #include "JSGlobalObject.h" -#include "PrototypeFunction.h" +#include "JSCInlines.h" #include "StringPrototype.h" namespace JSC { -static NEVER_INLINE JSValue stringFromCharCodeSlowCase(ExecState* exec, const ArgList& args) +static EncodedJSValue JSC_HOST_CALL stringFromCharCode(ExecState*); + +} + +#include "StringConstructor.lut.h" + +namespace JSC { + +const ClassInfo StringConstructor::s_info = { "Function", &InternalFunction::s_info, 0, ExecState::stringConstructorTable, CREATE_METHOD_TABLE(StringConstructor) }; + +/* Source for StringConstructor.lut.h +@begin stringConstructorTable + fromCharCode stringFromCharCode DontEnum|Function 1 +@end +*/ + +STATIC_ASSERT_IS_TRIVIALLY_DESTRUCTIBLE(StringConstructor); + +StringConstructor::StringConstructor(VM& vm, Structure* structure) + : InternalFunction(vm, structure) { - unsigned length = args.size(); +} + +void StringConstructor::finishCreation(VM& vm, StringPrototype* stringPrototype) +{ + Base::finishCreation(vm, stringPrototype->classInfo()->className); + putDirectWithoutTransition(vm, vm.propertyNames->prototype, stringPrototype, ReadOnly | DontEnum | DontDelete); + putDirectWithoutTransition(vm, vm.propertyNames->length, jsNumber(1), ReadOnly | DontEnum | DontDelete); +} + +bool StringConstructor::getOwnPropertySlot(JSObject* object, ExecState* exec, PropertyName propertyName, PropertySlot &slot) +{ + return getStaticFunctionSlot(exec, ExecState::stringConstructorTable(exec->vm()), jsCast(object), propertyName, slot); +} + +// ------------------------------ Functions -------------------------------- + +static NEVER_INLINE JSValue stringFromCharCodeSlowCase(ExecState* exec) +{ + unsigned length = exec->argumentCount(); UChar* buf; - PassRefPtr impl = UStringImpl::createUninitialized(length, buf); + PassRefPtr impl = StringImpl::createUninitialized(length, buf); for (unsigned i = 0; i < length; ++i) - buf[i] = static_cast(args.at(i).toUInt32(exec)); + buf[i] = static_cast(exec->uncheckedArgument(i).toUInt32(exec)); return jsString(exec, impl); } -static JSValue JSC_HOST_CALL stringFromCharCode(ExecState* exec, JSObject*, JSValue, const ArgList& args) +static EncodedJSValue JSC_HOST_CALL stringFromCharCode(ExecState* exec) { - if (LIKELY(args.size() == 1)) - return jsSingleCharacterString(exec, args.at(0).toUInt32(exec)); - return stringFromCharCodeSlowCase(exec, args); + if (LIKELY(exec->argumentCount() == 1)) + return JSValue::encode(jsSingleCharacterString(exec, exec->uncheckedArgument(0).toUInt32(exec))); + return JSValue::encode(stringFromCharCodeSlowCase(exec)); } -ASSERT_CLASS_FITS_IN_CELL(StringConstructor); - -StringConstructor::StringConstructor(ExecState* exec, NonNullPassRefPtr structure, Structure* prototypeFunctionStructure, StringPrototype* stringPrototype) - : InternalFunction(&exec->globalData(), structure, Identifier(exec, stringPrototype->classInfo()->className)) +JSCell* JSC_HOST_CALL stringFromCharCode(ExecState* exec, int32_t arg) { - // ECMA 15.5.3.1 String.prototype - putDirectWithoutTransition(exec->propertyNames().prototype, stringPrototype, ReadOnly | DontEnum | DontDelete); - - // ECMA 15.5.3.2 fromCharCode() -#if ENABLE(JIT) && ENABLE(JIT_OPTIMIZE_NATIVE_CALL) - putDirectFunctionWithoutTransition(exec, new (exec) NativeFunctionWrapper(exec, prototypeFunctionStructure, 1, exec->propertyNames().fromCharCode, exec->globalData().getThunk(fromCharCodeThunkGenerator), stringFromCharCode), DontEnum); -#else - putDirectFunctionWithoutTransition(exec, new (exec) NativeFunctionWrapper(exec, prototypeFunctionStructure, 1, exec->propertyNames().fromCharCode, stringFromCharCode), DontEnum); -#endif - // no. of arguments for constructor - putDirectWithoutTransition(exec->propertyNames().length, jsNumber(exec, 1), ReadOnly | DontEnum | DontDelete); + return jsSingleCharacterString(exec, arg); } -// ECMA 15.5.2 -static JSObject* constructWithStringConstructor(ExecState* exec, JSObject*, const ArgList& args) +static EncodedJSValue JSC_HOST_CALL constructWithStringConstructor(ExecState* exec) { - if (args.isEmpty()) - return new (exec) StringObject(exec, exec->lexicalGlobalObject()->stringObjectStructure()); - return new (exec) StringObject(exec, exec->lexicalGlobalObject()->stringObjectStructure(), args.at(0).toString(exec)); + JSGlobalObject* globalObject = asInternalFunction(exec->callee())->globalObject(); + VM& vm = exec->vm(); + + if (!exec->argumentCount()) + return JSValue::encode(StringObject::create(vm, globalObject->stringObjectStructure())); + + return JSValue::encode(StringObject::create(vm, globalObject->stringObjectStructure(), exec->uncheckedArgument(0).toString(exec))); } -ConstructType StringConstructor::getConstructData(ConstructData& constructData) +ConstructType StringConstructor::getConstructData(JSCell*, ConstructData& constructData) { constructData.native.function = constructWithStringConstructor; return ConstructTypeHost; } -// ECMA 15.5.1 -static JSValue JSC_HOST_CALL callStringConstructor(ExecState* exec, JSObject*, JSValue, const ArgList& args) +static EncodedJSValue JSC_HOST_CALL callStringConstructor(ExecState* exec) { - if (args.isEmpty()) - return jsEmptyString(exec); - return jsString(exec, args.at(0).toString(exec)); + if (!exec->argumentCount()) + return JSValue::encode(jsEmptyString(exec)); + return JSValue::encode(exec->uncheckedArgument(0).toString(exec)); } -CallType StringConstructor::getCallData(CallData& callData) +CallType StringConstructor::getCallData(JSCell*, CallData& callData) { callData.native.function = callStringConstructor; return CallTypeHost;