summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/runtime/JSPromiseDeferred.h
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2017-06-27 06:07:23 +0000
commit1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch)
tree46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/JavaScriptCore/runtime/JSPromiseDeferred.h
parent32761a6cee1d0dee366b885b7b9c777e67885688 (diff)
downloadWebKitGtk-tarball-master.tar.gz
Diffstat (limited to 'Source/JavaScriptCore/runtime/JSPromiseDeferred.h')
-rw-r--r--Source/JavaScriptCore/runtime/JSPromiseDeferred.h36
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