Chromium Code Reviews| Index: third_party/WebKit/Source/modules/mediastream/RTCVoidRequestPromiseImpl.cpp |
| diff --git a/third_party/WebKit/Source/modules/mediastream/RTCVoidRequestPromiseImpl.cpp b/third_party/WebKit/Source/modules/mediastream/RTCVoidRequestPromiseImpl.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..d9aaf7099ada8ca69daa66c77d30de3ed18c1bc9 |
| --- /dev/null |
| +++ b/third_party/WebKit/Source/modules/mediastream/RTCVoidRequestPromiseImpl.cpp |
| @@ -0,0 +1,64 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "modules/mediastream/RTCVoidRequestPromiseImpl.h" |
| + |
| +#include "bindings/core/v8/ScriptPromiseResolver.h" |
| +#include "core/dom/DOMException.h" |
| +#include "modules/mediastream/RTCPeerConnection.h" |
| + |
| +namespace blink { |
| + |
| +RTCVoidRequestPromiseImpl* RTCVoidRequestPromiseImpl::create(RTCPeerConnection* requester, ScriptPromiseResolver* resolver, const String& errorName) |
| +{ |
| + RTCVoidRequestPromiseImpl* request = new RTCVoidRequestPromiseImpl(requester, resolver, errorName); |
| + return request; |
| +} |
| + |
| +RTCVoidRequestPromiseImpl::RTCVoidRequestPromiseImpl(RTCPeerConnection* requester, ScriptPromiseResolver* resolver, const String& errorName) |
| + : m_resolver(resolver) |
| + , m_errorName(errorName) |
| + , m_requester(requester) |
| +{ |
| + ASSERT(m_resolver); |
| + ASSERT(m_requester); |
| + m_resolver->keepAliveWhilePending(); |
| +} |
| + |
| +RTCVoidRequestPromiseImpl::~RTCVoidRequestPromiseImpl() |
| +{ |
| +} |
| + |
| +void RTCVoidRequestPromiseImpl::requestSucceeded() |
| +{ |
| + bool shouldFireCallback = m_requester && m_requester->shouldFireDefaultCallbacks() && m_resolver->executionContext() && !m_resolver->executionContext()->activeDOMObjectsAreStopped(); |
|
yhirano
2016/02/11 01:58:17
When keepAliveWhilePending is called, the resolver
Guido Urdaneta
2016/02/11 10:47:08
With regards to the ActiveDOMObjectsAreStopped() c
yhirano
2016/02/11 18:28:31
I'd recommend calling resolve or reject unconditio
Guido Urdaneta
2016/02/11 20:00:05
Removed the unnecessary activeDOMObjects check.
Ho
yhirano
2016/02/11 21:56:30
It's problematic because the resolver continues to
Guido Urdaneta
2016/02/11 22:27:36
Done.
haraken
2016/02/15 01:31:31
It sounds weird that a promise is left without get
|
| + if (shouldFireCallback) |
| + m_resolver->resolve(); |
| + |
| + clear(); |
| +} |
| + |
| +void RTCVoidRequestPromiseImpl::requestFailed(const String& error) |
| +{ |
| + bool shouldFireCallback = m_requester && m_requester->shouldFireDefaultCallbacks() && m_resolver->executionContext() && !m_resolver->executionContext()->activeDOMObjectsAreStopped(); |
| + if (shouldFireCallback) |
| + m_resolver->reject(DOMException::create(error, m_errorName)); |
| + |
| + clear(); |
| +} |
| + |
| +void RTCVoidRequestPromiseImpl::clear() |
| +{ |
| + m_resolver.clear(); |
| + m_requester.clear(); |
| +} |
| + |
| +DEFINE_TRACE(RTCVoidRequestPromiseImpl) |
| +{ |
| + visitor->trace(m_resolver); |
| + visitor->trace(m_requester); |
| + RTCVoidRequest::trace(visitor); |
| +} |
| + |
| +} // namespace blink |