OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 MEDIA_FILTERS_CHUNK_DEMUXER_H_ | 5 #ifndef MEDIA_FILTERS_CHUNK_DEMUXER_H_ |
6 #define MEDIA_FILTERS_CHUNK_DEMUXER_H_ | 6 #define MEDIA_FILTERS_CHUNK_DEMUXER_H_ |
7 | 7 |
8 #include <deque> | 8 #include <deque> |
9 #include <map> | 9 #include <map> |
10 #include <string> | 10 #include <string> |
11 #include <utility> | 11 #include <utility> |
12 #include <vector> | 12 #include <vector> |
13 | 13 |
14 #include "base/synchronization/lock.h" | 14 #include "base/synchronization/lock.h" |
15 #include "media/base/byte_queue.h" | 15 #include "media/base/byte_queue.h" |
16 #include "media/base/demuxer.h" | 16 #include "media/base/demuxer.h" |
17 #include "media/base/ranges.h" | 17 #include "media/base/ranges.h" |
18 #include "media/base/stream_parser.h" | 18 #include "media/base/stream_parser.h" |
19 #include "media/filters/source_buffer_stream.h" | 19 #include "media/filters/source_buffer_stream.h" |
20 | 20 |
21 namespace media { | 21 namespace media { |
22 | 22 |
23 class FFmpegURLProtocol; | 23 class FFmpegURLProtocol; |
24 class SourceState; | 24 class SourceState; |
25 | 25 |
26 class ChunkDemuxerStream : public DemuxerStream { | 26 class MEDIA_EXPORT ChunkDemuxerStream : public DemuxerStream { |
27 public: | 27 public: |
28 typedef std::deque<scoped_refptr<StreamParserBuffer> > BufferQueue; | 28 typedef std::deque<scoped_refptr<StreamParserBuffer> > BufferQueue; |
29 | 29 |
30 explicit ChunkDemuxerStream(Type type, bool splice_frames_enabled); | 30 explicit ChunkDemuxerStream(Type type, bool splice_frames_enabled); |
31 virtual ~ChunkDemuxerStream(); | 31 virtual ~ChunkDemuxerStream(); |
32 | 32 |
33 // ChunkDemuxerStream control methods. | 33 // ChunkDemuxerStream control methods. |
34 void StartReturningData(); | 34 void StartReturningData(); |
35 void AbortReads(); | 35 void AbortReads(); |
36 void CompletePendingReadIfPossible(); | 36 void CompletePendingReadIfPossible(); |
(...skipping 150 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
187 // call received before a StartWaitingForSeek() call to immediately call its | 187 // call received before a StartWaitingForSeek() call to immediately call its |
188 // callback without waiting for any data. | 188 // callback without waiting for any data. |
189 // |seek_time| - The presentation timestamp for the seek request that | 189 // |seek_time| - The presentation timestamp for the seek request that |
190 // triggered this call. It represents the most recent position the caller is | 190 // triggered this call. It represents the most recent position the caller is |
191 // trying to seek to. | 191 // trying to seek to. |
192 void CancelPendingSeek(base::TimeDelta seek_time); | 192 void CancelPendingSeek(base::TimeDelta seek_time); |
193 | 193 |
194 // Registers a new |id| to use for AppendData() calls. |type| indicates | 194 // Registers a new |id| to use for AppendData() calls. |type| indicates |
195 // the MIME type for the data that we intend to append for this ID. | 195 // the MIME type for the data that we intend to append for this ID. |
196 // |use_legacy_frame_processor| determines which of LegacyFrameProcessor or | 196 // |use_legacy_frame_processor| determines which of LegacyFrameProcessor or |
197 // a (not yet implemented) more compliant frame processor to use to process | 197 // FrameProcessor to use to process parsed frames from AppendData() calls. |
198 // parsed frames from AppendData() calls. | |
199 // TODO(wolenetz): Enable usage of new frame processor based on this flag. | |
200 // See http://crbug.com/249422. | |
201 // kOk is returned if the demuxer has enough resources to support another ID | 198 // kOk is returned if the demuxer has enough resources to support another ID |
202 // and supports the format indicated by |type|. | 199 // and supports the format indicated by |type|. |
203 // kNotSupported is returned if |type| is not a supported format. | 200 // kNotSupported is returned if |type| is not a supported format. |
204 // kReachedIdLimit is returned if the demuxer cannot handle another ID right | 201 // kReachedIdLimit is returned if the demuxer cannot handle another ID right |
205 // now. | 202 // now. |
206 Status AddId(const std::string& id, const std::string& type, | 203 Status AddId(const std::string& id, const std::string& type, |
207 std::vector<std::string>& codecs, | 204 std::vector<std::string>& codecs, |
208 const bool use_legacy_frame_processor); | 205 const bool use_legacy_frame_processor); |
209 | 206 |
210 // Removed an ID & associated resources that were previously added with | 207 // Removed an ID & associated resources that were previously added with |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
249 // Returns true if the source buffer associated with |id| is currently parsing | 246 // Returns true if the source buffer associated with |id| is currently parsing |
250 // a media segment, or false otherwise. | 247 // a media segment, or false otherwise. |
251 bool IsParsingMediaSegment(const std::string& id); | 248 bool IsParsingMediaSegment(const std::string& id); |
252 | 249 |
253 // Set the append mode to be applied to subsequent buffers appended to the | 250 // Set the append mode to be applied to subsequent buffers appended to the |
254 // source buffer associated with |id|. If |sequence_mode| is true, caller | 251 // source buffer associated with |id|. If |sequence_mode| is true, caller |
255 // is requesting "sequence" mode. Otherwise, caller is requesting "segments" | 252 // is requesting "sequence" mode. Otherwise, caller is requesting "segments" |
256 // mode. | 253 // mode. |
257 void SetSequenceMode(const std::string& id, bool sequence_mode); | 254 void SetSequenceMode(const std::string& id, bool sequence_mode); |
258 | 255 |
| 256 // Signals the coded frame processor for the source buffer associated with |
| 257 // |id| to update its group start timestamp to be |timestamp_offset| if it is |
| 258 // in sequence append mode. |
| 259 void SetGroupStartTimestampIfInSequenceMode(const std::string& id, |
| 260 base::TimeDelta timestamp_offset); |
| 261 |
259 // Called to signal changes in the "end of stream" | 262 // Called to signal changes in the "end of stream" |
260 // state. UnmarkEndOfStream() must not be called if a matching | 263 // state. UnmarkEndOfStream() must not be called if a matching |
261 // MarkEndOfStream() has not come before it. | 264 // MarkEndOfStream() has not come before it. |
262 void MarkEndOfStream(PipelineStatus status); | 265 void MarkEndOfStream(PipelineStatus status); |
263 void UnmarkEndOfStream(); | 266 void UnmarkEndOfStream(); |
264 | 267 |
265 void Shutdown(); | 268 void Shutdown(); |
266 | 269 |
267 // Sets the memory limit on each stream. |memory_limit| is the | 270 // Sets the memory limit on each stream. |memory_limit| is the |
268 // maximum number of bytes each stream is allowed to hold in its buffer. | 271 // maximum number of bytes each stream is allowed to hold in its buffer. |
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
390 | 393 |
391 // Indicates that splice frame generation is enabled. | 394 // Indicates that splice frame generation is enabled. |
392 const bool splice_frames_enabled_; | 395 const bool splice_frames_enabled_; |
393 | 396 |
394 DISALLOW_COPY_AND_ASSIGN(ChunkDemuxer); | 397 DISALLOW_COPY_AND_ASSIGN(ChunkDemuxer); |
395 }; | 398 }; |
396 | 399 |
397 } // namespace media | 400 } // namespace media |
398 | 401 |
399 #endif // MEDIA_FILTERS_CHUNK_DEMUXER_H_ | 402 #endif // MEDIA_FILTERS_CHUNK_DEMUXER_H_ |
OLD | NEW |