| 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 |
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 82 { | 82 { |
| 83 MediaStreamTrackVector audioTracks; | 83 MediaStreamTrackVector audioTracks; |
| 84 MediaStreamTrackVector videoTracks; | 84 MediaStreamTrackVector videoTracks; |
| 85 | 85 |
| 86 for (size_t i = 0; i < tracks.size(); ++i) | 86 for (size_t i = 0; i < tracks.size(); ++i) |
| 87 processTrack(tracks[i].get(), tracks[i]->kind() == "audio" ? audioTracks
: videoTracks); | 87 processTrack(tracks[i].get(), tracks[i]->kind() == "audio" ? audioTracks
: videoTracks); |
| 88 | 88 |
| 89 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, au
dioTracks, videoTracks)); | 89 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, au
dioTracks, videoTracks)); |
| 90 } | 90 } |
| 91 | 91 |
| 92 MediaStream* MediaStream::create(ExecutionContext* context, MediaStreamDescripto
r* streamDescriptor) | 92 MediaStream* MediaStream::create(ExecutionContext* context, PassRefPtr<MediaStre
amDescriptor> streamDescriptor) |
| 93 { | 93 { |
| 94 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, st
reamDescriptor)); | 94 return adoptRefCountedGarbageCollectedWillBeNoop(new MediaStream(context, st
reamDescriptor)); |
| 95 } | 95 } |
| 96 | 96 |
| 97 MediaStream::MediaStream(ExecutionContext* context, MediaStreamDescriptor* strea
mDescriptor) | 97 MediaStream::MediaStream(ExecutionContext* context, PassRefPtr<MediaStreamDescri
ptor> streamDescriptor) |
| 98 : ContextLifecycleObserver(context) | 98 : ContextLifecycleObserver(context) |
| 99 , m_stopped(false) | 99 , m_stopped(false) |
| 100 , m_descriptor(streamDescriptor) | 100 , m_descriptor(streamDescriptor) |
| 101 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired) | 101 , m_scheduledEventTimer(this, &MediaStream::scheduledEventTimerFired) |
| 102 { | 102 { |
| 103 ScriptWrappable::init(this); | 103 ScriptWrappable::init(this); |
| 104 m_descriptor->setClient(this); | 104 m_descriptor->setClient(this); |
| 105 | 105 |
| 106 size_t numberOfAudioTracks = m_descriptor->numberOfAudioComponents(); | 106 size_t numberOfAudioTracks = m_descriptor->numberOfAudioComponents(); |
| 107 m_audioTracks.reserveCapacity(numberOfAudioTracks); | 107 m_audioTracks.reserveCapacity(numberOfAudioTracks); |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 143 m_descriptor = MediaStreamDescriptor::create(audioComponents, videoComponent
s); | 143 m_descriptor = MediaStreamDescriptor::create(audioComponents, videoComponent
s); |
| 144 m_descriptor->setClient(this); | 144 m_descriptor->setClient(this); |
| 145 MediaStreamCenter::instance().didCreateMediaStream(m_descriptor.get()); | 145 MediaStreamCenter::instance().didCreateMediaStream(m_descriptor.get()); |
| 146 | 146 |
| 147 m_audioTracks = audioTracks; | 147 m_audioTracks = audioTracks; |
| 148 m_videoTracks = videoTracks; | 148 m_videoTracks = videoTracks; |
| 149 } | 149 } |
| 150 | 150 |
| 151 MediaStream::~MediaStream() | 151 MediaStream::~MediaStream() |
| 152 { | 152 { |
| 153 m_descriptor->setClient(0); |
| 153 } | 154 } |
| 154 | 155 |
| 155 bool MediaStream::ended() const | 156 bool MediaStream::ended() const |
| 156 { | 157 { |
| 157 return m_stopped || m_descriptor->ended(); | 158 return m_stopped || m_descriptor->ended(); |
| 158 } | 159 } |
| 159 | 160 |
| 160 MediaStreamTrackVector MediaStream::getTracks() | 161 MediaStreamTrackVector MediaStream::getTracks() |
| 161 { | 162 { |
| 162 MediaStreamTrackVector tracks; | 163 MediaStreamTrackVector tracks; |
| (...skipping 224 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 387 URLRegistry& MediaStream::registry() const | 388 URLRegistry& MediaStream::registry() const |
| 388 { | 389 { |
| 389 return MediaStreamRegistry::registry(); | 390 return MediaStreamRegistry::registry(); |
| 390 } | 391 } |
| 391 | 392 |
| 392 void MediaStream::trace(Visitor* visitor) | 393 void MediaStream::trace(Visitor* visitor) |
| 393 { | 394 { |
| 394 visitor->trace(m_audioTracks); | 395 visitor->trace(m_audioTracks); |
| 395 visitor->trace(m_videoTracks); | 396 visitor->trace(m_videoTracks); |
| 396 visitor->trace(m_scheduledEvents); | 397 visitor->trace(m_scheduledEvents); |
| 397 visitor->trace(m_descriptor); | |
| 398 EventTargetWithInlineData::trace(visitor); | 398 EventTargetWithInlineData::trace(visitor); |
| 399 MediaStreamDescriptorClient::trace(visitor); | |
| 400 } | 399 } |
| 401 | 400 |
| 402 } // namespace blink | 401 } // namespace blink |
| OLD | NEW |