ArrayConstructor.h [plain text]
#pragma once
#include "InternalFunction.h"
#include "ProxyObject.h"
namespace JSC {
class ArrayAllocationProfile;
class ArrayPrototype;
class JSArray;
class GetterSetter;
class ArrayConstructor final : public InternalFunction {
public:
typedef InternalFunction Base;
static constexpr unsigned StructureFlags = Base::StructureFlags | HasStaticPropertyTable;
static ArrayConstructor* create(VM& vm, JSGlobalObject* globalObject, Structure* structure, ArrayPrototype* arrayPrototype, GetterSetter* speciesSymbol)
{
ArrayConstructor* constructor = new (NotNull, allocateCell<ArrayConstructor>(vm.heap)) ArrayConstructor(vm, structure);
constructor->finishCreation(vm, globalObject, arrayPrototype, speciesSymbol);
return constructor;
}
DECLARE_INFO;
static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype)
{
return Structure::create(vm, globalObject, prototype, TypeInfo(InternalFunctionType, StructureFlags), info());
}
private:
ArrayConstructor(VM&, Structure*);
void finishCreation(VM&, JSGlobalObject*, ArrayPrototype*, GetterSetter* speciesSymbol);
};
STATIC_ASSERT_ISO_SUBSPACE_SHARABLE(ArrayConstructor, InternalFunction);
JSArray* constructArrayWithSizeQuirk(JSGlobalObject*, ArrayAllocationProfile*, JSValue length, JSValue prototype = JSValue());
JSC_DECLARE_HOST_FUNCTION(arrayConstructorPrivateFuncIsArraySlow);
bool isArraySlow(JSGlobalObject*, ProxyObject* argument);
inline bool isArray(JSGlobalObject* globalObject, JSValue argumentValue)
{
if (!argumentValue.isObject())
return false;
JSObject* argument = jsCast<JSObject*>(argumentValue);
if (argument->type() == ArrayType || argument->type() == DerivedArrayType)
return true;
if (argument->type() != ProxyObjectType)
return false;
return isArraySlow(globalObject, jsCast<ProxyObject*>(argument));
}
}