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 |