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/JSPromiseDeferred.h | |
parent | 32761a6cee1d0dee366b885b7b9c777e67885688 (diff) | |
download | WebKitGtk-tarball-master.tar.gz |
webkitgtk-2.16.5HEADwebkitgtk-2.16.5master
Diffstat (limited to 'Source/JavaScriptCore/runtime/JSPromiseDeferred.h')
-rw-r--r-- | Source/JavaScriptCore/runtime/JSPromiseDeferred.h | 36 |
1 files changed, 14 insertions, 22 deletions
diff --git a/Source/JavaScriptCore/runtime/JSPromiseDeferred.h b/Source/JavaScriptCore/runtime/JSPromiseDeferred.h index ff509d77a..cf7693a21 100644 --- a/Source/JavaScriptCore/runtime/JSPromiseDeferred.h +++ b/Source/JavaScriptCore/runtime/JSPromiseDeferred.h @@ -23,58 +23,50 @@ * THE POSSIBILITY OF SUCH DAMAGE. */ -#ifndef JSPromiseDeferred_h -#define JSPromiseDeferred_h +#pragma once #include "JSCell.h" #include "Structure.h" namespace JSC { +class JSPromiseConstructor; + class JSPromiseDeferred : public JSCell { public: typedef JSCell Base; + static const unsigned StructureFlags = Base::StructureFlags | StructureIsImmortal; JS_EXPORT_PRIVATE static JSPromiseDeferred* create(ExecState*, JSGlobalObject*); JS_EXPORT_PRIVATE static JSPromiseDeferred* create(VM&, JSObject* promise, JSValue resolve, JSValue reject); static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype) { - return Structure::create(vm, globalObject, prototype, TypeInfo(CompoundType, StructureFlags), info()); + return Structure::create(vm, globalObject, prototype, TypeInfo(CellType, StructureFlags), info()); } - static const bool hasImmortalStructure = true; - DECLARE_EXPORT_INFO; JSObject* promise() const { return m_promise.get(); } JSValue resolve() const { return m_resolve.get(); } JSValue reject() const { return m_reject.get(); } -private: - JSPromiseDeferred(VM&); + JS_EXPORT_PRIVATE void resolve(ExecState*, JSValue); + JS_EXPORT_PRIVATE void reject(ExecState*, JSValue); + +protected: + JSPromiseDeferred(VM&, Structure*); void finishCreation(VM&, JSObject*, JSValue, JSValue); - static const unsigned StructureFlags = OverridesVisitChildren | Base::StructureFlags; static void visitChildren(JSCell*, SlotVisitor&); +private: + JSPromiseDeferred(VM&); + WriteBarrier<JSObject> m_promise; WriteBarrier<Unknown> m_resolve; WriteBarrier<Unknown> m_reject; }; -enum ThenableStatus { - WasAThenable, - NotAThenable -}; - -JSValue createJSPromiseDeferredFromConstructor(ExecState*, JSValue constructor); -ThenableStatus updateDeferredFromPotentialThenable(ExecState*, JSValue, JSPromiseDeferred*); - -void performDeferredResolve(ExecState*, JSPromiseDeferred*, JSValue argument); -void performDeferredReject(ExecState*, JSPromiseDeferred*, JSValue argument); - -JSValue abruptRejection(ExecState*, JSPromiseDeferred*); +JSValue newPromiseCapability(ExecState*, JSGlobalObject*, JSPromiseConstructor*); } // namespace JSC - -#endif // JSPromiseDeferred_h |