OLD | NEW |
---|---|
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 Loading... | |
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 Loading... | |
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 |
OLD | NEW |