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

Side by Side Diff: third_party/WebKit/Source/modules/mediasession/MediaSession.cpp

Issue 1412933005: Revert of Introduce WebMediaSession (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 1 month 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
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "config.h" 5 #include "config.h"
6 #include "modules/mediasession/MediaSession.h" 6 #include "modules/mediasession/MediaSession.h"
7 7
8 #include "bindings/core/v8/CallbackPromiseAdapter.h"
9 #include "bindings/core/v8/ScriptPromiseResolver.h"
10 #include "bindings/core/v8/ScriptState.h"
11 #include "core/dom/DOMException.h"
12 #include "core/dom/ExceptionCode.h"
13 #include "core/frame/LocalDOMWindow.h"
14 #include "core/frame/LocalFrame.h"
15 #include "core/loader/FrameLoaderClient.h"
16 #include "modules/mediasession/MediaSessionError.h"
17
18 namespace blink { 8 namespace blink {
19 9
20 MediaSession::MediaSession(PassOwnPtr<WebMediaSession> webMediaSession) 10 MediaSession* MediaSession::create()
21 : m_webMediaSession(webMediaSession)
22 { 11 {
23 ASSERT(m_webMediaSession); 12 return new MediaSession;
24 } 13 }
25 14
26 MediaSession* MediaSession::create(ExecutionContext* context, ExceptionState& ex ceptionState) 15 void MediaSession::activate()
27 { 16 {
28 Document* document = toDocument(context);
29 LocalFrame* frame = document->frame();
30 FrameLoaderClient* client = frame->loader().client();
31 OwnPtr<WebMediaSession> webMediaSession = client->createWebMediaSession();
32 if (!webMediaSession) {
33 exceptionState.throwDOMException(NotSupportedError, "Missing platform im plementation.");
34 return nullptr;
35 }
36 return new MediaSession(webMediaSession.release());
37 } 17 }
38 18
39 ScriptPromise MediaSession::activate(ScriptState* scriptState) 19 void MediaSession::deactivate()
40 { 20 {
41 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ;
42 ScriptPromise promise = resolver->promise();
43
44 m_webMediaSession->activate(new CallbackPromiseAdapter<void, MediaSessionErr or>(resolver));
45 return promise;
46 }
47
48 ScriptPromise MediaSession::deactivate(ScriptState* scriptState)
49 {
50 ScriptPromiseResolver* resolver = ScriptPromiseResolver::create(scriptState) ;
51 ScriptPromise promise = resolver->promise();
52
53 m_webMediaSession->deactivate(new CallbackPromiseAdapter<void, void>(resolve r));
54 return promise;
55 } 21 }
56 22
57 } // namespace blink 23 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698