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

Side by Side Diff: Source/modules/mediastream/MediaStream.cpp

Issue 545933002: Implement HTMLMediaElement::srcObject. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Addressed comments. Created 6 years, 3 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
1 /* 1 /*
2 * Copyright (C) 2011 Google Inc. All rights reserved. 2 * Copyright (C) 2011 Google Inc. All rights reserved.
3 * Copyright (C) 2011, 2012 Ericsson AB. All rights reserved. 3 * Copyright (C) 2011, 2012 Ericsson AB. All rights reserved.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions 6 * modification, are permitted provided that the following conditions
7 * are met: 7 * are met:
8 * 1. Redistributions of source code must retain the above copyright 8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright 10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the 11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution. 12 * documentation and/or other materials provided with the distribution.
13 * 13 *
14 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND AN Y 14 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND AN Y
15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
16 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 16 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
17 * DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR AN Y 17 * DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR AN Y
18 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 18 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
19 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 19 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
20 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND O N 20 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND O N
21 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 21 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
23 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 23 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 */ 24 */
25 25
26 #include "config.h" 26 #include "config.h"
27 #include "modules/mediastream/MediaStream.h" 27 #include "modules/mediastream/MediaStream.h"
28 28
29 #include "bindings/core/v8/ExceptionState.h" 29 #include "bindings/core/v8/ExceptionState.h"
30 #include "bindings/core/v8/ScriptValue.h"
31 #include "bindings/modules/v8/V8MediaStream.h"
32 #include "core/dom/DOMURL.h"
30 #include "core/dom/ExceptionCode.h" 33 #include "core/dom/ExceptionCode.h"
31 #include "modules/mediastream/MediaStreamRegistry.h" 34 #include "modules/mediastream/MediaStreamRegistry.h"
32 #include "modules/mediastream/MediaStreamTrackEvent.h" 35 #include "modules/mediastream/MediaStreamTrackEvent.h"
33 #include "platform/mediastream/MediaStreamCenter.h" 36 #include "platform/mediastream/MediaStreamCenter.h"
34 #include "platform/mediastream/MediaStreamSource.h" 37 #include "platform/mediastream/MediaStreamSource.h"
35 38
36 namespace blink { 39 namespace blink {
37 40
38 static bool containsSource(MediaStreamTrackVector& trackVector, MediaStreamSourc e* source) 41 static bool containsSource(MediaStreamTrackVector& trackVector, MediaStreamSourc e* source)
39 { 42 {
40 for (size_t i = 0; i < trackVector.size(); ++i) { 43 for (size_t i = 0; i < trackVector.size(); ++i) {
41 if (source->id() == trackVector[i]->component()->source()->id()) 44 if (source->id() == trackVector[i]->component()->source()->id())
42 return true; 45 return true;
43 } 46 }
44 return false; 47 return false;
45 } 48 }
46 49
47 static void processTrack(MediaStreamTrack* track, MediaStreamTrackVector& trackV ector) 50 static void processTrack(MediaStreamTrack* track, MediaStreamTrackVector& trackV ector)
48 { 51 {
49 if (track->ended()) 52 if (track->ended())
50 return; 53 return;
51 54
52 MediaStreamSource* source = track->component()->source(); 55 MediaStreamSource* source = track->component()->source();
53 if (!containsSource(trackVector, source)) 56 if (!containsSource(trackVector, source))
54 trackVector.append(track); 57 trackVector.append(track);
55 } 58 }
56 59
60 static MediaProvider* MediaProviderConverter(const ScriptValue& value)
61 {
62 v8::Handle<v8::Value> v8Value(value.v8Value());
63 MediaStream* stream = V8MediaStream::toImplWithTypeCheck(value.isolate(), v8 Value);
sof 2014/09/18 07:33:17 Just return this directly -- return V8MediaStre
perkj_chrome 2014/09/18 14:47:09 Done.
64 if (!stream)
65 return nullptr;
66 return stream;
67 }
68
57 MediaStream* MediaStream::create(ExecutionContext* context) 69 MediaStream* MediaStream::create(ExecutionContext* context)
58 { 70 {
59 MediaStreamTrackVector audioTracks; 71 MediaStreamTrackVector audioTracks;
60 MediaStreamTrackVector videoTracks; 72 MediaStreamTrackVector videoTracks;
61 73
62 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, au dioTracks, videoTracks)); 74 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, au dioTracks, videoTracks));
63 } 75 }
64 76
65 MediaStream* MediaStream::create(ExecutionContext* context, MediaStream* stream) 77 MediaStream* MediaStream::create(ExecutionContext* context, MediaStream* stream)
66 { 78 {
(...skipping 21 matching lines...) Expand all
88 100
89 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, au dioTracks, videoTracks)); 101 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, au dioTracks, videoTracks));
90 } 102 }
91 103
92 MediaStream* MediaStream::create(ExecutionContext* context, PassRefPtr<MediaStre amDescriptor> streamDescriptor) 104 MediaStream* MediaStream::create(ExecutionContext* context, PassRefPtr<MediaStre amDescriptor> streamDescriptor)
93 { 105 {
94 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, st reamDescriptor)); 106 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, st reamDescriptor));
95 } 107 }
96 108
97 MediaStream::MediaStream(ExecutionContext* context, PassRefPtr<MediaStreamDescri ptor> streamDescriptor) 109 MediaStream::MediaStream(ExecutionContext* context, PassRefPtr<MediaStreamDescri ptor> streamDescriptor)
98 : ContextLifecycleObserver(context) 110 : MediaProvider(EventTargetNames::MediaStream, bind<const ScriptValue&>(Medi aProviderConverter))
111 , ContextLifecycleObserver(context)
99 , m_stopped(false) 112 , m_stopped(false)
100 , m_descriptor(streamDescriptor) 113 , m_descriptor(streamDescriptor)
101 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired) 114 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired)
102 { 115 {
103 m_descriptor->setClient(this); 116 m_descriptor->setClient(this);
104 117
105 size_t numberOfAudioTracks = m_descriptor->numberOfAudioComponents(); 118 size_t numberOfAudioTracks = m_descriptor->numberOfAudioComponents();
106 m_audioTracks.reserveCapacity(numberOfAudioTracks); 119 m_audioTracks.reserveCapacity(numberOfAudioTracks);
107 for (size_t i = 0; i < numberOfAudioTracks; i++) { 120 for (size_t i = 0; i < numberOfAudioTracks; i++) {
108 MediaStreamTrack* newTrack = MediaStreamTrack::create(context, m_descrip tor->audioComponent(i)); 121 MediaStreamTrack* newTrack = MediaStreamTrack::create(context, m_descrip tor->audioComponent(i));
109 newTrack->registerMediaStream(this); 122 newTrack->registerMediaStream(this);
110 m_audioTracks.append(newTrack); 123 m_audioTracks.append(newTrack);
111 } 124 }
112 125
113 size_t numberOfVideoTracks = m_descriptor->numberOfVideoComponents(); 126 size_t numberOfVideoTracks = m_descriptor->numberOfVideoComponents();
114 m_videoTracks.reserveCapacity(numberOfVideoTracks); 127 m_videoTracks.reserveCapacity(numberOfVideoTracks);
115 for (size_t i = 0; i < numberOfVideoTracks; i++) { 128 for (size_t i = 0; i < numberOfVideoTracks; i++) {
116 MediaStreamTrack* newTrack = MediaStreamTrack::create(context, m_descrip tor->videoComponent(i)); 129 MediaStreamTrack* newTrack = MediaStreamTrack::create(context, m_descrip tor->videoComponent(i));
117 newTrack->registerMediaStream(this); 130 newTrack->registerMediaStream(this);
118 m_videoTracks.append(newTrack); 131 m_videoTracks.append(newTrack);
119 } 132 }
120 } 133 }
121 134
122 MediaStream::MediaStream(ExecutionContext* context, const MediaStreamTrackVector & audioTracks, const MediaStreamTrackVector& videoTracks) 135 MediaStream::MediaStream(ExecutionContext* context, const MediaStreamTrackVector & audioTracks, const MediaStreamTrackVector& videoTracks)
123 : ContextLifecycleObserver(context) 136 : MediaProvider(EventTargetNames::MediaStream, bind<const ScriptValue&>(Medi aProviderConverter))
137 , ContextLifecycleObserver(context)
124 , m_stopped(false) 138 , m_stopped(false)
125 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired) 139 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired)
126 { 140 {
127 MediaStreamComponentVector audioComponents; 141 MediaStreamComponentVector audioComponents;
128 MediaStreamComponentVector videoComponents; 142 MediaStreamComponentVector videoComponents;
129 143
130 MediaStreamTrackVector::const_iterator iter; 144 MediaStreamTrackVector::const_iterator iter;
131 for (iter = audioTracks.begin(); iter != audioTracks.end(); ++iter) { 145 for (iter = audioTracks.begin(); iter != audioTracks.end(); ++iter) {
132 (*iter)->registerMediaStream(this); 146 (*iter)->registerMediaStream(this);
133 audioComponents.append((*iter)->component()); 147 audioComponents.append((*iter)->component());
134 } 148 }
135 for (iter = videoTracks.begin(); iter != videoTracks.end(); ++iter) { 149 for (iter = videoTracks.begin(); iter != videoTracks.end(); ++iter) {
136 (*iter)->registerMediaStream(this); 150 (*iter)->registerMediaStream(this);
137 videoComponents.append((*iter)->component()); 151 videoComponents.append((*iter)->component());
138 } 152 }
139 153
140 m_descriptor = MediaStreamDescriptor::create(audioComponents, videoComponent s); 154 m_descriptor = MediaStreamDescriptor::create(audioComponents, videoComponent s);
141 m_descriptor->setClient(this); 155 m_descriptor->setClient(this);
142 MediaStreamCenter::instance().didCreateMediaStream(m_descriptor.get()); 156 MediaStreamCenter::instance().didCreateMediaStream(m_descriptor.get());
143 157
144 m_audioTracks = audioTracks; 158 m_audioTracks = audioTracks;
145 m_videoTracks = videoTracks; 159 m_videoTracks = videoTracks;
146 } 160 }
147 161
148 MediaStream::~MediaStream() 162 MediaStream::~MediaStream()
149 { 163 {
164 if (!m_objectUrl.isEmpty())
165 DOMURL::revokeObjectURL(executionContext(), m_objectUrl);
150 m_descriptor->setClient(0); 166 m_descriptor->setClient(0);
151 } 167 }
152 168
153 bool MediaStream::ended() const 169 bool MediaStream::ended() const
154 { 170 {
155 return m_stopped || m_descriptor->ended(); 171 return m_stopped || m_descriptor->ended();
156 } 172 }
157 173
158 MediaStreamTrackVector MediaStream::getTracks() 174 MediaStreamTrackVector MediaStream::getTracks()
159 { 175 {
(...skipping 220 matching lines...) Expand 10 before | Expand all | Expand 10 after
380 dispatchEvent((*it).release()); 396 dispatchEvent((*it).release());
381 397
382 events.clear(); 398 events.clear();
383 } 399 }
384 400
385 URLRegistry& MediaStream::registry() const 401 URLRegistry& MediaStream::registry() const
386 { 402 {
387 return MediaStreamRegistry::registry(); 403 return MediaStreamRegistry::registry();
388 } 404 }
389 405
406 const String& MediaStream::getObjectUrl()
407 {
408 if (m_objectUrl.isEmpty())
409 m_objectUrl = m_objectUrl = DOMURL::createPublicURL(executionContext(), this);
sof 2014/09/18 07:33:17 "m_objectUrl = m_objectUrl" => "m_objectUrl" ?
sof 2014/09/18 07:33:17 Should this be using URLMediaStream::createObjectU
perkj_chrome 2014/09/18 14:47:09 good question... Sorry.
perkj_chrome 2014/09/18 14:47:09 It can- but since I use DOMURL::revokeObjectURL I
410 return m_objectUrl;
411 }
412
390 void MediaStream::trace(Visitor* visitor) 413 void MediaStream::trace(Visitor* visitor)
391 { 414 {
392 visitor->trace(m_audioTracks); 415 visitor->trace(m_audioTracks);
393 visitor->trace(m_videoTracks); 416 visitor->trace(m_videoTracks);
394 visitor->trace(m_scheduledEvents); 417 visitor->trace(m_scheduledEvents);
395 EventTargetWithInlineData::trace(visitor); 418 EventTargetWithInlineData::trace(visitor);
396 } 419 }
397 420
398 } // namespace blink 421 } // namespace blink
OLDNEW
« Source/core/html/MediaProvider.cpp ('K') | « Source/modules/mediastream/MediaStream.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698