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

Side by Side Diff: Source/platform/mediastream/MediaStreamDescriptor.h

Issue 534473002: Revert of Oilpan: Move MediaStreamSource, MediaStreamComponent and MediaStreamDescriptor (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 years, 3 months 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
1 /* 1 /*
2 * Copyright (C) 2011 Ericsson AB. All rights reserved. 2 * Copyright (C) 2011 Ericsson AB. All rights reserved.
3 * Copyright (C) 2012 Google Inc. All rights reserved. 3 * Copyright (C) 2012 Google Inc. All rights reserved.
4 * 4 *
5 * Redistribution and use in source and binary forms, with or without 5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions 6 * modification, are permitted provided that the following conditions
7 * are met: 7 * are met:
8 * 8 *
9 * 1. Redistributions of source code must retain the above copyright 9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer. 10 * notice, this list of conditions and the following disclaimer.
(...skipping 14 matching lines...) Expand all
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */ 30 */
31 31
32 #ifndef MediaStreamDescriptor_h 32 #ifndef MediaStreamDescriptor_h
33 #define MediaStreamDescriptor_h 33 #define MediaStreamDescriptor_h
34 34
35 #include "platform/heap/Handle.h"
36 #include "platform/mediastream/MediaStreamComponent.h" 35 #include "platform/mediastream/MediaStreamComponent.h"
37 #include "platform/mediastream/MediaStreamSource.h" 36 #include "platform/mediastream/MediaStreamSource.h"
38 #include "wtf/PassOwnPtr.h" 37 #include "wtf/PassOwnPtr.h"
38 #include "wtf/RefCounted.h"
39 #include "wtf/Vector.h" 39 #include "wtf/Vector.h"
40 40
41 namespace blink { 41 namespace blink {
42 42
43 class MediaStreamDescriptorClient : public GarbageCollectedMixin { 43 class MediaStreamDescriptorClient {
44 public: 44 public:
45 virtual ~MediaStreamDescriptorClient() { } 45 virtual ~MediaStreamDescriptorClient() { }
46 46
47 virtual void streamEnded() = 0; 47 virtual void streamEnded() = 0;
48 virtual void addRemoteTrack(MediaStreamComponent*) = 0; 48 virtual void addRemoteTrack(MediaStreamComponent*) = 0;
49 virtual void removeRemoteTrack(MediaStreamComponent*) = 0; 49 virtual void removeRemoteTrack(MediaStreamComponent*) = 0;
50 virtual void trace(Visitor*) { }
51 }; 50 };
52 51
53 class PLATFORM_EXPORT MediaStreamDescriptor FINAL : public GarbageCollectedFinal ized<MediaStreamDescriptor> { 52 class PLATFORM_EXPORT MediaStreamDescriptor FINAL : public RefCounted<MediaStrea mDescriptor> {
54 public: 53 public:
55 class ExtraData { 54 class ExtraData {
56 public: 55 public:
57 virtual ~ExtraData() { } 56 virtual ~ExtraData() { }
58 }; 57 };
59 58
60 // Only used for AudioDestinationNode. 59 // Only used for AudioDestinationNode.
61 static MediaStreamDescriptor* create(const MediaStreamSourceVector& audioSou rces, const MediaStreamSourceVector& videoSources); 60 static PassRefPtr<MediaStreamDescriptor> create(const MediaStreamSourceVecto r& audioSources, const MediaStreamSourceVector& videoSources);
62 61
63 static MediaStreamDescriptor* create(const MediaStreamComponentVector& audio Components, const MediaStreamComponentVector& videoComponents); 62 static PassRefPtr<MediaStreamDescriptor> create(const MediaStreamComponentVe ctor& audioComponents, const MediaStreamComponentVector& videoComponents);
64 63
65 static MediaStreamDescriptor* create(const String& id, const MediaStreamComp onentVector& audioComponents, const MediaStreamComponentVector& videoComponents) ; 64 static PassRefPtr<MediaStreamDescriptor> create(const String& id, const Medi aStreamComponentVector& audioComponents, const MediaStreamComponentVector& video Components);
66 65
67 MediaStreamDescriptorClient* client() const { return m_client; } 66 MediaStreamDescriptorClient* client() const { return m_client; }
68 void setClient(MediaStreamDescriptorClient* client) { m_client = client; } 67 void setClient(MediaStreamDescriptorClient* client) { m_client = client; }
69 68
70 String id() const { return m_id; } 69 String id() const { return m_id; }
71 70
72 unsigned numberOfAudioComponents() const { return m_audioComponents.size(); } 71 unsigned numberOfAudioComponents() const { return m_audioComponents.size(); }
73 MediaStreamComponent* audioComponent(unsigned index) const { return m_audioC omponents[index].get(); } 72 MediaStreamComponent* audioComponent(unsigned index) const { return m_audioC omponents[index].get(); }
74 73
75 unsigned numberOfVideoComponents() const { return m_videoComponents.size(); } 74 unsigned numberOfVideoComponents() const { return m_videoComponents.size(); }
76 MediaStreamComponent* videoComponent(unsigned index) const { return m_videoC omponents[index].get(); } 75 MediaStreamComponent* videoComponent(unsigned index) const { return m_videoC omponents[index].get(); }
77 76
78 void addComponent(MediaStreamComponent*); 77 void addComponent(PassRefPtr<MediaStreamComponent>);
79 void removeComponent(MediaStreamComponent*); 78 void removeComponent(PassRefPtr<MediaStreamComponent>);
80 79
81 void addRemoteTrack(MediaStreamComponent*); 80 void addRemoteTrack(MediaStreamComponent*);
82 void removeRemoteTrack(MediaStreamComponent*); 81 void removeRemoteTrack(MediaStreamComponent*);
83 82
84 bool ended() const { return m_ended; } 83 bool ended() const { return m_ended; }
85 void setEnded() { m_ended = true; } 84 void setEnded() { m_ended = true; }
86 85
87 ExtraData* extraData() const { return m_extraData.get(); } 86 ExtraData* extraData() const { return m_extraData.get(); }
88 void setExtraData(PassOwnPtr<ExtraData> extraData) { m_extraData = extraData ; } 87 void setExtraData(PassOwnPtr<ExtraData> extraData) { m_extraData = extraData ; }
89 88
90 void trace(Visitor*);
91
92 private: 89 private:
93 MediaStreamDescriptor(const String& id, const MediaStreamSourceVector& audio Sources, const MediaStreamSourceVector& videoSources); 90 MediaStreamDescriptor(const String& id, const MediaStreamSourceVector& audio Sources, const MediaStreamSourceVector& videoSources);
94 MediaStreamDescriptor(const String& id, const MediaStreamComponentVector& au dioComponents, const MediaStreamComponentVector& videoComponents); 91 MediaStreamDescriptor(const String& id, const MediaStreamComponentVector& au dioComponents, const MediaStreamComponentVector& videoComponents);
95 92
96 Member<MediaStreamDescriptorClient> m_client; 93 MediaStreamDescriptorClient* m_client;
97 String m_id; 94 String m_id;
98 MediaStreamComponentVector m_audioComponents; 95 Vector<RefPtr<MediaStreamComponent> > m_audioComponents;
99 MediaStreamComponentVector m_videoComponents; 96 Vector<RefPtr<MediaStreamComponent> > m_videoComponents;
100 bool m_ended; 97 bool m_ended;
101 98
102 OwnPtr<ExtraData> m_extraData; 99 OwnPtr<ExtraData> m_extraData;
103 }; 100 };
104 101
102 typedef Vector<RefPtr<MediaStreamDescriptor> > MediaStreamDescriptorVector;
103
105 } // namespace blink 104 } // namespace blink
106 105
107 #endif // MediaStreamDescriptor_h 106 #endif // MediaStreamDescriptor_h
OLDNEW
« no previous file with comments | « Source/platform/mediastream/MediaStreamComponent.cpp ('k') | Source/platform/mediastream/MediaStreamDescriptor.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698