diff options
| author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-05-24 08:28:08 +0000 |
|---|---|---|
| committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2016-05-24 08:28:08 +0000 |
| commit | a4e969f4965059196ca948db781e52f7cfebf19e (patch) | |
| tree | 6ca352808c8fdc52006a0f33f6ae3c593b23867d /Source/JavaScriptCore/runtime/JSPromiseDeferred.h | |
| parent | 41386e9cb918eed93b3f13648cbef387e371e451 (diff) | |
| download | WebKitGtk-tarball-a4e969f4965059196ca948db781e52f7cfebf19e.tar.gz | |
webkitgtk-2.12.3webkitgtk-2.12.3
Diffstat (limited to 'Source/JavaScriptCore/runtime/JSPromiseDeferred.h')
| -rw-r--r-- | Source/JavaScriptCore/runtime/JSPromiseDeferred.h | 31 |
1 files changed, 13 insertions, 18 deletions
diff --git a/Source/JavaScriptCore/runtime/JSPromiseDeferred.h b/Source/JavaScriptCore/runtime/JSPromiseDeferred.h index ff509d77a..db7dc55d9 100644 --- a/Source/JavaScriptCore/runtime/JSPromiseDeferred.h +++ b/Source/JavaScriptCore/runtime/JSPromiseDeferred.h @@ -31,49 +31,44 @@ 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 |
