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..142a34f221a52afd2b7b84ee5fcc189e5737cb7d |
| --- /dev/null |
| +++ b/third_party/WebKit/Source/modules/mediastream/RTCVoidRequestPromiseImpl.cpp |
| @@ -0,0 +1,71 @@ |
| +// 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/DOMError.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); |
| + request->suspendIfNeeded(); |
| + return request; |
| +} |
| + |
| +RTCVoidRequestPromiseImpl::RTCVoidRequestPromiseImpl(RTCPeerConnection* requester, ScriptPromiseResolver* resolver, const String& errorName) |
| + : ActiveDOMObject(resolver->executionContext()) |
| + , m_resolver(resolver) |
| + , m_errorName(errorName) |
| + , m_requester(requester) |
| +{ |
| + ASSERT(m_resolver); |
| + ASSERT(m_requester); |
| +} |
| + |
| +RTCVoidRequestPromiseImpl::~RTCVoidRequestPromiseImpl() |
| +{ |
| +} |
| + |
| +void RTCVoidRequestPromiseImpl::requestSucceeded() |
| +{ |
| + bool shouldFireCallback = m_requester ? m_requester->shouldFireDefaultCallbacks() : false; |
|
philipj_slow
2016/02/09 12:02:03
true/false in ternary expressions can always be re
Guido Urdaneta
2016/02/09 16:51:01
Done.
|
| + if (shouldFireCallback) |
| + m_resolver->resolve(); |
| + |
| + clear(); |
| +} |
| + |
| +void RTCVoidRequestPromiseImpl::requestFailed(const String& error) |
| +{ |
| + bool shouldFireCallback = m_requester ? m_requester->shouldFireDefaultCallbacks() : false; |
| + if (shouldFireCallback) |
| + m_resolver->reject(DOMError::create(m_errorName, error)); |
|
philipj_slow
2016/02/09 12:02:03
Ah, DOMError. Whatever the spec may say, we should
Guido Urdaneta
2016/02/09 16:51:01
Should I use DOMException instead then?
philipj_slow
2016/02/09 18:59:17
I would recommend that, yes. Is https://github.com
|
| + |
| + clear(); |
| +} |
| + |
| +void RTCVoidRequestPromiseImpl::stop() |
| +{ |
| + clear(); |
| +} |
| + |
| +void RTCVoidRequestPromiseImpl::clear() |
| +{ |
| + m_resolver.clear(); |
| + m_requester.clear(); |
| +} |
| + |
| +DEFINE_TRACE(RTCVoidRequestPromiseImpl) |
| +{ |
| + visitor->trace(m_resolver); |
| + visitor->trace(m_requester); |
| + RTCVoidRequest::trace(visitor); |
| + ActiveDOMObject::trace(visitor); |
| +} |
| + |
| +} // namespace blink |