| Index: media/mpeg2/mpeg2ts_section_parser.h
|
| diff --git a/media/mpeg2/mpeg2ts_section_parser.h b/media/mpeg2/mpeg2ts_section_parser.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..fc299a329aefc75927a9d4110bf6a9da6e648da7
|
| --- /dev/null
|
| +++ b/media/mpeg2/mpeg2ts_section_parser.h
|
| @@ -0,0 +1,40 @@
|
| +// Copyright (c) 2013 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef MEDIA_MPEG2_MPEG2TS_SECTION_PARSER_H_
|
| +#define MEDIA_MPEG2_MPEG2TS_SECTION_PARSER_H_
|
| +
|
| +namespace media {
|
| +namespace mpeg2ts {
|
| +
|
| +class Mpeg2TsSectionParser {
|
| + public:
|
| + // From ISO/IEC 13818-1 or ITU H.222 spec: Table 2-3 - PID table.
|
| + enum SpecialPid {
|
| + kPidPat = 0x0,
|
| + kPidCat = 0x1,
|
| + kPidTsdt = 0x2,
|
| + kPidNullPacket = 0x1fff,
|
| + kPidMax = 0x1fff,
|
| + };
|
| +
|
| + virtual ~Mpeg2TsSectionParser() {}
|
| +
|
| + // Parse the data bytes of the TS packet.
|
| + // Return true if parsing is successful.
|
| + virtual bool Parse(bool payload_unit_start_indicator,
|
| + const uint8* buf, int size) = 0;
|
| +
|
| + // Process bytes that have not been processed yet (pending buffers in the
|
| + // pipe). Flush might thus results in frame emission, as an example.
|
| + virtual void Flush() = 0;
|
| +
|
| + // Reset the state of the parser to its initial state.
|
| + virtual void Reset() = 0;
|
| +};
|
| +
|
| +} // namespace mpeg2ts
|
| +} // namespace media
|
| +
|
| +#endif
|
|
|