Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2013 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 "content/renderer/media/media_stream_video_track.h" | |
| 6 | |
| 7 #include "content/renderer/media/webrtc_video_sink_adapter.h" | |
| 8 | |
| 9 namespace content { | |
| 10 | |
| 11 // Wrapper which allows to use std::find_if() when adding and removing | |
| 12 // sinks to/from |sinks_|. | |
| 13 struct SinkWrapper { | |
| 14 explicit SinkWrapper(MediaStreamVideoSink* sink) : sink_(sink) {} | |
| 15 bool operator()( | |
| 16 const WebRtcVideoSinkAdapter* owner) { | |
|
tommi (sloooow) - chröme
2013/11/27 16:53:07
is wrapping necessary? (I mean, I know the class n
perkj_chrome
2013/11/28 13:32:45
What do you mean? xians suggested this trick in or
tommi (sloooow) - chröme
2013/11/28 14:32:21
Sorry, unfortunate mix up of wrapping vs wrapping
| |
| 17 return owner->sink() == sink_; | |
| 18 } | |
| 19 MediaStreamVideoSink* sink_; | |
| 20 }; | |
| 21 | |
| 22 MediaStreamVideoTrack::MediaStreamVideoTrack(webrtc::VideoTrackInterface* track) | |
| 23 : MediaStreamTrackExtraData(track), | |
| 24 video_track_(track) { | |
| 25 } | |
| 26 | |
| 27 MediaStreamVideoTrack::~MediaStreamVideoTrack() { | |
| 28 DCHECK(sinks_.empty()); | |
| 29 } | |
| 30 | |
| 31 void MediaStreamVideoTrack::AddSink(MediaStreamVideoSink* sink) { | |
| 32 DCHECK(thread_checker_.CalledOnValidThread()); | |
| 33 DCHECK(std::find_if(sinks_.begin(), sinks_.end(), | |
| 34 SinkWrapper(sink)) == sinks_.end()); | |
| 35 sinks_.push_back(new WebRtcVideoSinkAdapter(video_track_, sink)); | |
| 36 } | |
| 37 | |
| 38 void MediaStreamVideoTrack::RemoveSink(MediaStreamVideoSink* sink) { | |
| 39 DCHECK(thread_checker_.CalledOnValidThread()); | |
| 40 ScopedVector<WebRtcVideoSinkAdapter>::iterator it = | |
| 41 std::find_if(sinks_.begin(), sinks_.end(), SinkWrapper(sink)); | |
| 42 if (it == sinks_.end()) { | |
| 43 NOTREACHED(); | |
|
tommi (sloooow) - chröme
2013/11/27 16:53:07
NOTREACHED is considered dead code and works out t
perkj_chrome
2013/11/28 13:32:45
Done.DCHECK_NE doesn't compile though.
| |
| 44 return; | |
| 45 } | |
| 46 sinks_.erase(it); | |
| 47 } | |
| 48 | |
| 49 } // namespace content | |
| OLD | NEW |