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

Side by Side Diff: content/renderer/media/media_stream_video_track.cc

Issue 83023005: Add VideoTrackSink interface to content/public (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Added AddToVideoTrack Created 7 years 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 | Annotate | Revision Log
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698