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

Unified Diff: media/base/media_tracks.cc

Issue 1922333002: Implement mapping blink track id to demuxer streams (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase Created 4 years, 7 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 side-by-side diff with in-line comments
Download patch
Index: media/base/media_tracks.cc
diff --git a/media/base/media_tracks.cc b/media/base/media_tracks.cc
index 367bd01b3878b4a341be6c23966c4b25e76e7e9a..621d052d1e718cddf5064f1ca18697a4f12c2c01 100644
--- a/media/base/media_tracks.cc
+++ b/media/base/media_tracks.cc
@@ -15,30 +15,66 @@ MediaTracks::MediaTracks() {}
MediaTracks::~MediaTracks() {}
-void MediaTracks::AddAudioTrack(const AudioDecoderConfig& config,
- const std::string& id,
- const std::string& kind,
- const std::string& label,
- const std::string& language) {
+const MediaTrack* MediaTracks::AddAudioTrack(const AudioDecoderConfig& config,
+ const std::string& id,
chcunningham 2016/06/02 21:24:45 What are the plans for this "id"? Its a little con
servolk 2016/06/02 23:53:11 How about byteStreamTrackId? Also, these are typic
chcunningham 2016/06/03 20:42:49 byteStreamTrackId sounds good
+ const std::string& kind,
+ const std::string& label,
+ const std::string& language) {
DCHECK(config.IsValidConfig());
CHECK(audio_configs_.find(id) == audio_configs_.end());
std::unique_ptr<MediaTrack> track = base::WrapUnique(
new MediaTrack(MediaTrack::Audio, id, kind, label, language));
tracks_.push_back(std::move(track));
audio_configs_[id] = config;
+ return tracks_.back().get();
}
-void MediaTracks::AddVideoTrack(const VideoDecoderConfig& config,
- const std::string& id,
- const std::string& kind,
- const std::string& label,
- const std::string& language) {
+const MediaTrack* MediaTracks::AddVideoTrack(const VideoDecoderConfig& config,
+ const std::string& id,
+ const std::string& kind,
+ const std::string& label,
+ const std::string& language) {
DCHECK(config.IsValidConfig());
CHECK(video_configs_.find(id) == video_configs_.end());
std::unique_ptr<MediaTrack> track = base::WrapUnique(
new MediaTrack(MediaTrack::Video, id, kind, label, language));
tracks_.push_back(std::move(track));
video_configs_[id] = config;
+ return tracks_.back().get();
+}
+
+void MediaTracks::SetDemuxerStreamForMediaTrack(const MediaTrack* track,
+ const DemuxerStream* stream) {
+ DCHECK(track_to_demux_stream_map_.find(track) ==
chcunningham 2016/06/02 21:24:45 How are you deciding when to DCHECK vs CHECK? Both
servolk 2016/06/02 23:53:11 In this case dcheck are for things that might indi
chcunningham 2016/06/03 20:42:49 Acknowledged.
+ track_to_demux_stream_map_.end());
+
+ bool track_found = false;
+ for (const auto& t : tracks_) {
+ if (t.get() == track) {
+ track_found = true;
+ break;
+ }
+ }
+ CHECK(track_found);
+
+ track_to_demux_stream_map_[track] = stream;
+}
+
+MediaTracks::TrackIdToDemuxStreamMap MediaTracks::OnTrackIdsAssigned(
+ const std::vector<unsigned>& track_ids) const {
+ TrackIdToDemuxStreamMap result;
+ CHECK_EQ(tracks().size(), track_ids.size());
+ CHECK_EQ(track_to_demux_stream_map_.size(), tracks().size());
+ for (size_t i = 0; i < track_ids.size(); ++i) {
+ const MediaTrack* track = tracks()[i].get();
+ DCHECK(track);
+ const auto& it = track_to_demux_stream_map_.find(track);
+ CHECK(it != track_to_demux_stream_map_.end());
+ DVLOG(3) << "OnTrackIdsAssigned track_id=" << track_ids[i]
+ << " DemuxerStream=" << it->second;
+ result[track_ids[i]] = it->second;
+ }
+ return result;
}
const AudioDecoderConfig& MediaTracks::getAudioConfig(

Powered by Google App Engine
This is Rietveld 408576698