blob: 6e7b482c98928decef72dc55db3c159b9e3cdacb [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef MEDIA_FORMATS_MP2T_ES_PARSER_H_
#define MEDIA_FORMATS_MP2T_ES_PARSER_H_
#include <stdint.h>
#include <list>
#include <memory>
#include <utility>
#include "base/functional/callback.h"
#include "base/memory/scoped_refptr.h"
#include "base/time/time.h"
#include "media/base/media_export.h"
#include "media/base/stream_parser_buffer.h"
namespace media {
class DecryptConfig;
class OffsetByteQueue;
class StreamParserBuffer;
namespace mp2t {
class MEDIA_EXPORT EsParser {
public:
using EmitBufferCB =
base::RepeatingCallback<void(scoped_refptr<StreamParserBuffer>)>;
using GetDecryptConfigCB = base::RepeatingCallback<const DecryptConfig*()>;
EsParser();
EsParser(const EsParser&) = delete;
EsParser& operator=(const EsParser&) = delete;
virtual ~EsParser();
// ES parsing.
// Should use kNoTimestamp when a timestamp is not valid.
bool Parse(const uint8_t* buf,
int size,
base::TimeDelta pts,
DecodeTimestamp dts);
// Flush any pending buffer.
virtual void Flush() = 0;
// Reset the state of the ES parser.
void Reset();
protected:
struct TimingDesc {
TimingDesc();
TimingDesc(DecodeTimestamp dts, base::TimeDelta pts);
DecodeTimestamp dts;
base::TimeDelta pts;
};
// Parse ES data from |es_queue_|.
// Return true when successful.
virtual bool ParseFromEsQueue() = 0;
// Reset the internal state of the ES parser.
virtual void ResetInternal() = 0;
// Get the timing descriptor with the largest byte count that is less or
// equal to |es_byte_count|.
// This timing descriptor and all the ones that come before (in stream order)
// are removed from list |timing_desc_list_|.
// If no timing descriptor is found, then the default TimingDesc is returned.
TimingDesc GetTimingDescriptor(int64_t es_byte_count);
// Bytes of the ES stream that have not been emitted yet.
std::unique_ptr<media::OffsetByteQueue> es_queue_;
private:
// Anchor some timing information into the ES queue.
// Here are two examples how this timing info is applied according to
// the MPEG-2 TS spec - ISO/IEC 13818:
// - "In the case of audio, if a PTS is present in PES packet header it shall
// refer to the first access unit commencing in the PES packet. An audio
// access unit commences in a PES packet if the first byte of the audio
// access unit is present in the PES packet."
// - "For AVC video streams conforming to one or more profiles defined
// in Annex A of Rec. ITU-T H.264 | ISO/IEC 14496-10 video, if a PTS is
// present in the PES packet header, it shall refer to the first AVC access
// unit that commences in this PES packet.
std::list<std::pair<int64_t, TimingDesc>> timing_desc_list_;
};
} // namespace mp2t
} // namespace media
#endif // MEDIA_FORMATS_MP2T_ES_PARSER_H_