| Index: Source/bindings/v8/ScriptPromise.cpp
|
| diff --git a/Source/bindings/v8/ScriptPromise.cpp b/Source/bindings/v8/ScriptPromise.cpp
|
| index 7279ccc9fbb2e8bf5f7668e49d42bbf7754c7709..c8ce8bbffc63b56b8aa625f307a3b85f74e131fb 100644
|
| --- a/Source/bindings/v8/ScriptPromise.cpp
|
| +++ b/Source/bindings/v8/ScriptPromise.cpp
|
| @@ -40,17 +40,18 @@
|
|
|
| namespace WebCore {
|
|
|
| -ScriptPromise::ScriptPromise(v8::Handle<v8::Value> value, v8::Isolate* isolate)
|
| +ScriptPromise::ScriptPromise(ScriptState* scriptState, v8::Handle<v8::Value> value)
|
| + : m_scriptState(scriptState)
|
| {
|
| if (value.IsEmpty())
|
| return;
|
|
|
| - if (!V8PromiseCustom::isPromise(value, isolate) && !value->IsPromise()) {
|
| - m_promise = ScriptValue(v8::Handle<v8::Value>(), isolate);
|
| - V8ThrowException::throwTypeError("the given value is not a Promise", isolate);
|
| + if (!V8PromiseCustom::isPromise(value, scriptState->isolate()) && !value->IsPromise()) {
|
| + m_promise = ScriptValue(scriptState, v8::Handle<v8::Value>());
|
| + V8ThrowException::throwTypeError("the given value is not a Promise", scriptState->isolate());
|
| return;
|
| }
|
| - m_promise = ScriptValue(value, isolate);
|
| + m_promise = ScriptValue(scriptState, value);
|
| }
|
|
|
| ScriptPromise ScriptPromise::then(PassOwnPtr<ScriptFunction> onFulfilled, PassOwnPtr<ScriptFunction> onRejected)
|
| @@ -62,8 +63,8 @@ ScriptPromise ScriptPromise::then(PassOwnPtr<ScriptFunction> onFulfilled, PassOw
|
| v8::Local<v8::Function> v8OnFulfilled = ScriptFunction::adoptByGarbageCollector(onFulfilled);
|
| v8::Local<v8::Function> v8OnRejected = ScriptFunction::adoptByGarbageCollector(onRejected);
|
|
|
| - if (V8PromiseCustom::isPromise(promise, isolate()))
|
| - return ScriptPromise(V8PromiseCustom::then(promise, v8OnFulfilled, v8OnRejected, isolate()), isolate());
|
| + if (V8PromiseCustom::isPromise(promise, m_scriptState->isolate()))
|
| + return ScriptPromise(m_scriptState.get(), V8PromiseCustom::then(promise, v8OnFulfilled, v8OnRejected, m_scriptState->isolate()));
|
|
|
| ASSERT(promise->IsPromise());
|
| // Return this Promise if no handlers are given.
|
| @@ -82,7 +83,7 @@ ScriptPromise ScriptPromise::then(PassOwnPtr<ScriptFunction> onFulfilled, PassOw
|
| if (!v8OnRejected.IsEmpty())
|
| resultPromise = resultPromise->Catch(v8OnRejected);
|
|
|
| - return ScriptPromise(resultPromise, isolate());
|
| + return ScriptPromise(m_scriptState.get(), resultPromise);
|
| }
|
|
|
| ScriptPromise ScriptPromise::cast(const ScriptValue& value)
|
| @@ -92,7 +93,7 @@ ScriptPromise ScriptPromise::cast(const ScriptValue& value)
|
| v8::Local<v8::Value> v8Value(value.v8Value());
|
| v8::Isolate* isolate = value.isolate();
|
| if (V8PromiseCustom::isPromise(v8Value, isolate) || v8Value->IsPromise()) {
|
| - return ScriptPromise(v8Value, isolate);
|
| + return ScriptPromise(value.scriptState(), v8Value);
|
| }
|
| if (RuntimeEnabledFeatures::scriptPromiseOnV8PromiseEnabled()) {
|
| v8::Local<v8::Promise::Resolver> resolver = v8::Promise::Resolver::New(isolate);
|
| @@ -102,9 +103,9 @@ ScriptPromise ScriptPromise::cast(const ScriptValue& value)
|
| return ScriptPromise();
|
| }
|
| resolver->Resolve(v8Value);
|
| - return ScriptPromise(resolver->GetPromise(), isolate);
|
| + return ScriptPromise(value.scriptState(), resolver->GetPromise());
|
| }
|
| - return ScriptPromise(V8PromiseCustom::toPromise(v8Value, isolate), isolate);
|
| + return ScriptPromise(value.scriptState(), V8PromiseCustom::toPromise(v8Value, isolate));
|
| }
|
|
|
| } // namespace WebCore
|
|
|