Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(289)

Side by Side Diff: third_party/WebKit/Source/modules/mediastream/RTCVoidRequestPromiseImpl.cpp

Issue 1661493002: Add promise-based addIceCandidate, setLocalDescription and setRemoteDescription to RTCPeerConnection (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Replace "TBD" with "InternalError" Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698