Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "modules/mediastream/RTCVoidRequestPromiseImpl.h" | |
| 6 | |
| 7 #include "bindings/core/v8/ScriptPromiseResolver.h" | |
| 8 #include "core/dom/DOMError.h" | |
| 9 #include "modules/mediastream/RTCPeerConnection.h" | |
| 10 | |
| 11 namespace blink { | |
| 12 | |
| 13 RTCVoidRequestPromiseImpl* RTCVoidRequestPromiseImpl::create(RTCPeerConnection* requester, ScriptPromiseResolver* resolver, const String& errorName) | |
| 14 { | |
| 15 RTCVoidRequestPromiseImpl* request = new RTCVoidRequestPromiseImpl(requester , resolver, errorName); | |
| 16 request->suspendIfNeeded(); | |
| 17 return request; | |
| 18 } | |
| 19 | |
| 20 RTCVoidRequestPromiseImpl::RTCVoidRequestPromiseImpl(RTCPeerConnection* requeste r, ScriptPromiseResolver* resolver, const String& errorName) | |
| 21 : ActiveDOMObject(resolver->executionContext()) | |
| 22 , m_resolver(resolver) | |
| 23 , m_errorName(errorName) | |
| 24 , m_requester(requester) | |
| 25 { | |
| 26 ASSERT(m_resolver); | |
| 27 ASSERT(m_requester); | |
| 28 } | |
| 29 | |
| 30 RTCVoidRequestPromiseImpl::~RTCVoidRequestPromiseImpl() | |
| 31 { | |
| 32 } | |
| 33 | |
| 34 void RTCVoidRequestPromiseImpl::requestSucceeded() | |
| 35 { | |
| 36 bool shouldFireCallback = m_requester ? m_requester->shouldFireDefaultCallba cks() : 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.
| |
| 37 if (shouldFireCallback) | |
| 38 m_resolver->resolve(); | |
| 39 | |
| 40 clear(); | |
| 41 } | |
| 42 | |
| 43 void RTCVoidRequestPromiseImpl::requestFailed(const String& error) | |
| 44 { | |
| 45 bool shouldFireCallback = m_requester ? m_requester->shouldFireDefaultCallba cks() : false; | |
| 46 if (shouldFireCallback) | |
| 47 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
| |
| 48 | |
| 49 clear(); | |
| 50 } | |
| 51 | |
| 52 void RTCVoidRequestPromiseImpl::stop() | |
| 53 { | |
| 54 clear(); | |
| 55 } | |
| 56 | |
| 57 void RTCVoidRequestPromiseImpl::clear() | |
| 58 { | |
| 59 m_resolver.clear(); | |
| 60 m_requester.clear(); | |
| 61 } | |
| 62 | |
| 63 DEFINE_TRACE(RTCVoidRequestPromiseImpl) | |
| 64 { | |
| 65 visitor->trace(m_resolver); | |
| 66 visitor->trace(m_requester); | |
| 67 RTCVoidRequest::trace(visitor); | |
| 68 ActiveDOMObject::trace(visitor); | |
| 69 } | |
| 70 | |
| 71 } // namespace blink | |
| OLD | NEW |