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

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: rebase 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
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 // TODO(xians): Make this pure virtual when Stop[Track] has been
perkj_chrome 2014/10/31 08:37:24 nit: remove this todo or move it to the new implem
tommi (sloooow) - chröme 2014/10/31 10:06:32 Done.
40 // implemented for remote audio tracks. 37 // implemented for remote audio tracks.
41 virtual void Stop(); 38 virtual void Stop() = 0;
42 39
40 // TODO(tommi, xians): Remove this method.
43 virtual webrtc::AudioTrackInterface* GetAudioAdapter(); 41 virtual webrtc::AudioTrackInterface* GetAudioAdapter();
44 42
45 bool is_local_track() const { return is_local_track_; } 43 bool is_local_track() const { return is_local_track_; }
46 44
47 protected: 45 protected:
48 const scoped_refptr<webrtc::MediaStreamTrackInterface> track_;
49
50 private:
51 const bool is_local_track_; 46 const bool is_local_track_;
52 47
53 base::ThreadChecker thread_checker_; 48 base::ThreadChecker thread_checker_;
54 49
55 DISALLOW_COPY_AND_ASSIGN(MediaStreamTrack); 50 DISALLOW_COPY_AND_ASSIGN(MediaStreamTrack);
56 }; 51 };
57 52
58 } // namespace content 53 } // namespace content
59 54
60 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_TRACK_H_ 55 #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') | content/renderer/media/media_stream_track.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698