diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-10 09:28:39 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-04-10 09:28:39 +0000 |
commit | 32761a6cee1d0dee366b885b7b9c777e67885688 (patch) | |
tree | d6bec92bebfb216f4126356e55518842c2f476a1 /Source/JavaScriptCore/runtime/JSPromiseDeferred.h | |
parent | a4e969f4965059196ca948db781e52f7cfebf19e (diff) | |
download | WebKitGtk-tarball-32761a6cee1d0dee366b885b7b9c777e67885688.tar.gz |
webkitgtk-2.4.11webkitgtk-2.4.11
Diffstat (limited to 'Source/JavaScriptCore/runtime/JSPromiseDeferred.h')
-rw-r--r-- | Source/JavaScriptCore/runtime/JSPromiseDeferred.h | 31 |
1 files changed, 18 insertions, 13 deletions
diff --git a/Source/JavaScriptCore/runtime/JSPromiseDeferred.h b/Source/JavaScriptCore/runtime/JSPromiseDeferred.h index db7dc55d9..ff509d77a 100644 --- a/Source/JavaScriptCore/runtime/JSPromiseDeferred.h +++ b/Source/JavaScriptCore/runtime/JSPromiseDeferred.h @@ -31,44 +31,49 @@ 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(CellType, StructureFlags), info()); + return Structure::create(vm, globalObject, prototype, TypeInfo(CompoundType, 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(); } - 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 void visitChildren(JSCell*, SlotVisitor&); - private: JSPromiseDeferred(VM&); + void finishCreation(VM&, JSObject*, JSValue, JSValue); + static const unsigned StructureFlags = OverridesVisitChildren | Base::StructureFlags; + static void visitChildren(JSCell*, SlotVisitor&); WriteBarrier<JSObject> m_promise; WriteBarrier<Unknown> m_resolve; WriteBarrier<Unknown> m_reject; }; -JSValue newPromiseCapability(ExecState*, JSGlobalObject*, JSPromiseConstructor*); +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*); } // namespace JSC |