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 |