#ifndef RUNTIME_FUNCTION_H_
#define RUNTIME_FUNCTION_H_
#include "BridgeJSC.h"
#include <JavaScriptCore/InternalFunction.h>
#include <JavaScriptCore/JSGlobalObject.h>
namespace JSC {
class WEBCORE_EXPORT RuntimeMethod : public InternalFunction {
public:
using Base = InternalFunction;
static constexpr unsigned StructureFlags = Base::StructureFlags | OverridesGetOwnPropertySlot | OverridesGetCallData;
template<typename CellType, JSC::SubspaceAccess>
static IsoSubspace* subspaceFor(JSC::VM& vm)
{
static_assert(sizeof(CellType) == sizeof(RuntimeMethod), "RuntimeMethod subclasses that add fields need to override subspaceFor<>()");
static_assert(CellType::destroy == JSC::JSCell::destroy);
return subspaceForImpl(vm);
}
static RuntimeMethod* create(JSGlobalObject*, JSGlobalObject* globalObject, Structure* structure, const String& name, Bindings::Method* method)
{
VM& vm = globalObject->vm();
RuntimeMethod* runtimeMethod = new (NotNull, allocateCell<RuntimeMethod>(vm.heap)) RuntimeMethod(vm, structure, method);
runtimeMethod->finishCreation(vm, name);
return runtimeMethod;
}
Bindings::Method* method() const { return m_method; }
DECLARE_INFO;
static FunctionPrototype* createPrototype(VM&, JSGlobalObject& globalObject)
{
return globalObject.functionPrototype();
}
static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype)
{
return Structure::create(vm, globalObject, prototype, TypeInfo(InternalFunctionType, StructureFlags), info());
}
protected:
RuntimeMethod(VM&, Structure*, Bindings::Method*);
void finishCreation(VM&, const String&);
static bool getOwnPropertySlot(JSObject*, JSGlobalObject*, PropertyName, PropertySlot&);
private:
static IsoSubspace* subspaceForImpl(VM&);
Bindings::Method* m_method;
};
}
#endif