NameConstructor.cpp [plain text]
#include "config.h"
#include "NameConstructor.h"
#include "JSGlobalObject.h"
#include "NamePrototype.h"
#include "Operations.h"
namespace JSC {
ASSERT_HAS_TRIVIAL_DESTRUCTOR(NameConstructor);
const ClassInfo NameConstructor::s_info = { "Function", &Base::s_info, 0, 0, CREATE_METHOD_TABLE(NameConstructor) };
NameConstructor::NameConstructor(JSGlobalObject* globalObject, Structure* structure)
: InternalFunction(globalObject, structure)
{
}
void NameConstructor::finishCreation(ExecState* exec, NamePrototype* prototype)
{
Base::finishCreation(exec->vm(), prototype->classInfo()->className);
putDirectWithoutTransition(exec->vm(), exec->propertyNames().prototype, prototype, DontEnum | DontDelete | ReadOnly);
putDirectWithoutTransition(exec->vm(), exec->propertyNames().length, jsNumber(1), DontDelete | ReadOnly | DontEnum);
}
static EncodedJSValue JSC_HOST_CALL constructPrivateName(ExecState* exec)
{
JSValue publicName = exec->argumentCount() ? exec->argument(0) : jsUndefined();
return JSValue::encode(NameInstance::create(exec->vm(), exec->lexicalGlobalObject()->privateNameStructure(), publicName.toString(exec)));
}
ConstructType NameConstructor::getConstructData(JSCell*, ConstructData& constructData)
{
constructData.native.function = constructPrivateName;
return ConstructTypeHost;
}
CallType NameConstructor::getCallData(JSCell*, CallData& callData)
{
callData.native.function = constructPrivateName;
return CallTypeHost;
}
}