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

Side by Side Diff: content/renderer/media/media_stream_track.h

Issue 675013005: Split libjingle's signaling thread from the UI thread (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Update tests, remove circular dependency Created 6 years, 1 month 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
« no previous file with comments | « no previous file | content/renderer/media/media_stream_track.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_TRACK_H_ 5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_TRACK_H_
6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_TRACK_H_ 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_TRACK_H_
7 7
8 #include "base/callback.h" 8 #include "base/callback.h"
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/memory/ref_counted.h" 10 #include "base/memory/ref_counted.h"
11 #include "base/threading/thread_checker.h" 11 #include "base/threading/thread_checker.h"
12 #include "content/common/content_export.h" 12 #include "content/common/content_export.h"
13 #include "third_party/WebKit/public/platform/WebMediaStreamTrack.h" 13 #include "third_party/WebKit/public/platform/WebMediaStreamTrack.h"
14 14
15 namespace webrtc { 15 namespace webrtc {
16 class AudioTrackInterface; 16 class AudioTrackInterface;
17 class MediaStreamTrackInterface; 17 class MediaStreamTrackInterface;
18 } // namespace webrtc 18 } // namespace webrtc
19 19
20 namespace content { 20 namespace content {
21 21
22 // MediaStreamTrack is a Chrome representation of blink::WebMediaStreamTrack. 22 // MediaStreamTrack is a Chrome representation of blink::WebMediaStreamTrack.
23 // It is owned by blink::WebMediaStreamTrack as 23 // It is owned by blink::WebMediaStreamTrack as
24 // blink::WebMediaStreamTrack::ExtraData. 24 // blink::WebMediaStreamTrack::ExtraData.
25 class CONTENT_EXPORT MediaStreamTrack 25 class CONTENT_EXPORT MediaStreamTrack
26 : NON_EXPORTED_BASE(public blink::WebMediaStreamTrack::ExtraData) { 26 : NON_EXPORTED_BASE(public blink::WebMediaStreamTrack::ExtraData) {
27 public: 27 public:
28 MediaStreamTrack( 28 explicit MediaStreamTrack(bool is_local_track);
29 const scoped_refptr<webrtc::MediaStreamTrackInterface>& track,
30 bool is_local_track);
31 virtual ~MediaStreamTrack(); 29 virtual ~MediaStreamTrack();
32 30
33 static MediaStreamTrack* GetTrack( 31 static MediaStreamTrack* GetTrack(
34 const blink::WebMediaStreamTrack& track); 32 const blink::WebMediaStreamTrack& track);
35 33
36 // If a subclass overrides this method it has to call the base class. 34 virtual void SetEnabled(bool enabled) = 0;
37 virtual void SetEnabled(bool enabled);
38 35
39 // TODO(xians): Make this pure virtual when Stop[Track] has been 36 virtual void Stop() = 0;
40 // implemented for remote audio tracks.
41 virtual void Stop();
42 37
38 // TODO(tommi, xians): Remove this method.
43 virtual webrtc::AudioTrackInterface* GetAudioAdapter(); 39 virtual webrtc::AudioTrackInterface* GetAudioAdapter();
44 40
45 bool is_local_track() const { return is_local_track_; } 41 bool is_local_track() const { return is_local_track_; }
46 42
47 protected: 43 protected:
48 const scoped_refptr<webrtc::MediaStreamTrackInterface> track_;
49
50 private:
51 const bool is_local_track_; 44 const bool is_local_track_;
52 45
53 base::ThreadChecker thread_checker_; 46 base::ThreadChecker thread_checker_;
54 47
55 DISALLOW_COPY_AND_ASSIGN(MediaStreamTrack); 48 DISALLOW_COPY_AND_ASSIGN(MediaStreamTrack);
56 }; 49 };
57 50
58 } // namespace content 51 } // namespace content
59 52
60 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_TRACK_H_ 53 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_TRACK_H_
OLDNEW
« no previous file with comments | « no previous file | content/renderer/media/media_stream_track.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698