diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
commit | 1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch) | |
tree | 46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/JavaScriptCore/runtime/JSBoundFunction.h | |
parent | 32761a6cee1d0dee366b885b7b9c777e67885688 (diff) | |
download | WebKitGtk-tarball-master.tar.gz |
webkitgtk-2.16.5HEADwebkitgtk-2.16.5master
Diffstat (limited to 'Source/JavaScriptCore/runtime/JSBoundFunction.h')
-rw-r--r-- | Source/JavaScriptCore/runtime/JSBoundFunction.h | 31 |
1 files changed, 16 insertions, 15 deletions
diff --git a/Source/JavaScriptCore/runtime/JSBoundFunction.h b/Source/JavaScriptCore/runtime/JSBoundFunction.h index 7852f78ce..2c9e2cde3 100644 --- a/Source/JavaScriptCore/runtime/JSBoundFunction.h +++ b/Source/JavaScriptCore/runtime/JSBoundFunction.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 2011 Apple Inc. All rights reserved. + * Copyright (C) 2011, 2016 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -23,53 +23,54 @@ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ -#ifndef JSBoundFunction_h -#define JSBoundFunction_h +#pragma once #include "JSFunction.h" namespace JSC { +EncodedJSValue JSC_HOST_CALL boundThisNoArgsFunctionCall(ExecState*); EncodedJSValue JSC_HOST_CALL boundFunctionCall(ExecState*); +EncodedJSValue JSC_HOST_CALL boundThisNoArgsFunctionConstruct(ExecState*); EncodedJSValue JSC_HOST_CALL boundFunctionConstruct(ExecState*); +EncodedJSValue JSC_HOST_CALL isBoundFunction(ExecState*); +EncodedJSValue JSC_HOST_CALL hasInstanceBoundFunction(ExecState*); class JSBoundFunction : public JSFunction { public: typedef JSFunction Base; + const static unsigned StructureFlags = ~ImplementsDefaultHasInstance & Base::StructureFlags; - static JSBoundFunction* create(VM&, JSGlobalObject*, JSObject* targetFunction, JSValue boundThis, JSValue boundArgs, int, const String&); + static JSBoundFunction* create(VM&, ExecState*, JSGlobalObject*, JSObject* targetFunction, JSValue boundThis, JSArray* boundArgs, int, const String& name); - static void destroy(JSCell*); - static bool customHasInstance(JSObject*, ExecState*, JSValue); JSObject* targetFunction() { return m_targetFunction.get(); } JSValue boundThis() { return m_boundThis.get(); } - JSValue boundArgs() { return m_boundArgs.get(); } + JSArray* boundArgs() { return m_boundArgs.get(); } - static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype) + static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype) { ASSERT(globalObject); return Structure::create(vm, globalObject, prototype, TypeInfo(JSFunctionType, StructureFlags), info()); } + + static ptrdiff_t offsetOfTargetFunction() { return OBJECT_OFFSETOF(JSBoundFunction, m_targetFunction); } + static ptrdiff_t offsetOfBoundThis() { return OBJECT_OFFSETOF(JSBoundFunction, m_boundThis); } DECLARE_INFO; protected: - const static unsigned StructureFlags = OverridesHasInstance | OverridesVisitChildren | Base::StructureFlags; - static void visitChildren(JSCell*, SlotVisitor&); private: - JSBoundFunction(VM&, JSGlobalObject*, Structure*, JSObject* targetFunction, JSValue boundThis, JSValue boundArgs); + JSBoundFunction(VM&, JSGlobalObject*, Structure*, JSObject* targetFunction, JSValue boundThis, JSArray* boundArgs); - void finishCreation(VM&, NativeExecutable*, int, const String&); + void finishCreation(VM&, NativeExecutable*, int length); WriteBarrier<JSObject> m_targetFunction; WriteBarrier<Unknown> m_boundThis; - WriteBarrier<Unknown> m_boundArgs; + WriteBarrier<JSArray> m_boundArgs; }; } // namespace JSC - -#endif // JSFunction_h |