Chromium Code Reviews| Index: media/filters/source_buffer_range.cc |
| diff --git a/media/filters/source_buffer_range.cc b/media/filters/source_buffer_range.cc |
| index 6c8bc8daee1344dc955a2e7ef8a432c0f1c21f5d..caad8cf70aa234064953f34255ff128b8ba3800b 100644 |
| --- a/media/filters/source_buffer_range.cc |
| +++ b/media/filters/source_buffer_range.cc |
| @@ -106,6 +106,47 @@ void SourceBufferRange::Seek(DecodeTimestamp timestamp) { |
| << next_buffer_index_ << ", size = " << buffers_.size(); |
| } |
| +int SourceBufferRange::GetConfigIdAtTime(DecodeTimestamp timestamp) { |
| + DCHECK(CanSeekTo(timestamp)); |
| + DCHECK(!keyframe_map_.empty()); |
| + |
| + KeyframeMap::iterator result = GetFirstKeyframeAtOrBefore(timestamp); |
| + CHECK(result != keyframe_map_.end()); |
|
wolenetz
2016/12/02 00:18:49
aside: This is a good addition.
|
| + size_t buffer_index = result->second - keyframe_map_index_base_; |
| + CHECK_LT(buffer_index, buffers_.size()) << buffer_index |
| + << ", size = " << buffers_.size(); |
| + |
| + return buffers_[buffer_index]->GetConfigId(); |
| +} |
| + |
| +bool SourceBufferRange::SameConfigThruRange(DecodeTimestamp start, |
| + DecodeTimestamp end) { |
| + DCHECK(CanSeekTo(start)); |
| + DCHECK(CanSeekTo(end)); |
| + DCHECK(start <= end); |
| + DCHECK(!keyframe_map_.empty()); |
| + |
| + if (start == end) |
| + return true; |
| + |
| + KeyframeMap::const_iterator result = GetFirstKeyframeAtOrBefore(start); |
| + CHECK(result != keyframe_map_.end()); |
|
wolenetz
2016/12/02 00:18:49
ditto aside
|
| + size_t buffer_index = result->second - keyframe_map_index_base_; |
| + CHECK_LT(buffer_index, buffers_.size()) << buffer_index |
| + << ", size = " << buffers_.size(); |
| + |
| + int start_config = buffers_[buffer_index]->GetConfigId(); |
| + buffer_index++; |
| + while (buffer_index < buffers_.size() && |
| + buffers_[buffer_index]->GetDecodeTimestamp() <= end) { |
| + if (buffers_[buffer_index]->GetConfigId() != start_config) |
| + return false; |
| + buffer_index++; |
| + } |
| + |
| + return true; |
| +} |
| + |
| void SourceBufferRange::SeekAheadTo(DecodeTimestamp timestamp) { |
| SeekAhead(timestamp, false); |
| } |