2020-08-14 16:58:22 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2011 The WebRTC project authors. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license
|
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
|
|
|
* in the file PATENTS. All contributing project authors may
|
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PC_STREAM_COLLECTION_H_
|
|
|
|
#define PC_STREAM_COLLECTION_H_
|
|
|
|
|
|
|
|
#include <string>
|
2023-02-18 21:24:25 +00:00
|
|
|
#include <utility>
|
2020-08-14 16:58:22 +00:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "api/peer_connection_interface.h"
|
|
|
|
|
|
|
|
namespace webrtc {
|
|
|
|
|
|
|
|
// Implementation of StreamCollection.
|
|
|
|
class StreamCollection : public StreamCollectionInterface {
|
|
|
|
public:
|
|
|
|
static rtc::scoped_refptr<StreamCollection> Create() {
|
2021-06-25 00:43:10 +00:00
|
|
|
return rtc::make_ref_counted<StreamCollection>();
|
2020-08-14 16:58:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static rtc::scoped_refptr<StreamCollection> Create(
|
|
|
|
StreamCollection* streams) {
|
2021-06-25 00:43:10 +00:00
|
|
|
return rtc::make_ref_counted<StreamCollection>(streams);
|
2020-08-14 16:58:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual size_t count() { return media_streams_.size(); }
|
|
|
|
|
|
|
|
virtual MediaStreamInterface* at(size_t index) {
|
2023-02-18 21:24:25 +00:00
|
|
|
return media_streams_.at(index).get();
|
2020-08-14 16:58:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual MediaStreamInterface* find(const std::string& id) {
|
|
|
|
for (StreamVector::iterator it = media_streams_.begin();
|
|
|
|
it != media_streams_.end(); ++it) {
|
|
|
|
if ((*it)->id().compare(id) == 0) {
|
2023-02-18 21:24:25 +00:00
|
|
|
return (*it).get();
|
2020-08-14 16:58:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual MediaStreamTrackInterface* FindAudioTrack(const std::string& id) {
|
|
|
|
for (size_t i = 0; i < media_streams_.size(); ++i) {
|
2023-02-18 21:24:25 +00:00
|
|
|
MediaStreamTrackInterface* track =
|
|
|
|
media_streams_[i]->FindAudioTrack(id).get();
|
2020-08-14 16:58:22 +00:00
|
|
|
if (track) {
|
|
|
|
return track;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual MediaStreamTrackInterface* FindVideoTrack(const std::string& id) {
|
|
|
|
for (size_t i = 0; i < media_streams_.size(); ++i) {
|
2023-02-18 21:24:25 +00:00
|
|
|
MediaStreamTrackInterface* track =
|
|
|
|
media_streams_[i]->FindVideoTrack(id).get();
|
2020-08-14 16:58:22 +00:00
|
|
|
if (track) {
|
|
|
|
return track;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2023-02-18 21:24:25 +00:00
|
|
|
void AddStream(rtc::scoped_refptr<MediaStreamInterface> stream) {
|
2020-08-14 16:58:22 +00:00
|
|
|
for (StreamVector::iterator it = media_streams_.begin();
|
|
|
|
it != media_streams_.end(); ++it) {
|
|
|
|
if ((*it)->id().compare(stream->id()) == 0)
|
|
|
|
return;
|
|
|
|
}
|
2023-02-18 21:24:25 +00:00
|
|
|
media_streams_.push_back(std::move(stream));
|
2020-08-14 16:58:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void RemoveStream(MediaStreamInterface* remove_stream) {
|
|
|
|
for (StreamVector::iterator it = media_streams_.begin();
|
|
|
|
it != media_streams_.end(); ++it) {
|
|
|
|
if ((*it)->id().compare(remove_stream->id()) == 0) {
|
|
|
|
media_streams_.erase(it);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected:
|
|
|
|
StreamCollection() {}
|
|
|
|
explicit StreamCollection(StreamCollection* original)
|
|
|
|
: media_streams_(original->media_streams_) {}
|
|
|
|
typedef std::vector<rtc::scoped_refptr<MediaStreamInterface> > StreamVector;
|
|
|
|
StreamVector media_streams_;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace webrtc
|
|
|
|
|
|
|
|
#endif // PC_STREAM_COLLECTION_H_
|