| // |
| // Copyright (c) 2016, Alliance for Open Media. All rights reserved |
| // |
| // This source code is subject to the terms of the BSD 2 Clause License and |
| // the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License |
| // was not distributed with this source code in the LICENSE file, you can |
| // obtain it at www.aomedia.org/license/software. If the Alliance for Open |
| // Media Patent License 1.0 was not distributed with this source code in the |
| // PATENTS file, you can obtain it at www.aomedia.org/license/patent. |
| // |
| |
| |
| #ifndef MKVMUXERUTIL_HPP |
| #define MKVMUXERUTIL_HPP |
| |
| #include "mkvmuxer.hpp" |
| #include "mkvmuxertypes.hpp" |
| |
| namespace mkvmuxer { |
| |
| class IMkvWriter; |
| |
| const uint64 kEbmlUnknownValue = 0x01FFFFFFFFFFFFFFULL; |
| const int64 kMaxBlockTimecode = 0x07FFFLL; |
| |
| // Writes out |value| in Big Endian order. Returns 0 on success. |
| int32 SerializeInt(IMkvWriter* writer, int64 value, int32 size); |
| |
| // Returns the size in bytes of the element. |
| int32 GetUIntSize(uint64 value); |
| int32 GetIntSize(int64 value); |
| int32 GetCodedUIntSize(uint64 value); |
| uint64 EbmlMasterElementSize(uint64 type, uint64 value); |
| uint64 EbmlElementSize(uint64 type, int64 value); |
| uint64 EbmlElementSize(uint64 type, uint64 value); |
| uint64 EbmlElementSize(uint64 type, float value); |
| uint64 EbmlElementSize(uint64 type, const char* value); |
| uint64 EbmlElementSize(uint64 type, const uint8* value, uint64 size); |
| uint64 EbmlDateElementSize(uint64 type); |
| |
| // Creates an EBML coded number from |value| and writes it out. The size of |
| // the coded number is determined by the value of |value|. |value| must not |
| // be in a coded form. Returns 0 on success. |
| int32 WriteUInt(IMkvWriter* writer, uint64 value); |
| |
| // Creates an EBML coded number from |value| and writes it out. The size of |
| // the coded number is determined by the value of |size|. |value| must not |
| // be in a coded form. Returns 0 on success. |
| int32 WriteUIntSize(IMkvWriter* writer, uint64 value, int32 size); |
| |
| // Output an Mkv master element. Returns true if the element was written. |
| bool WriteEbmlMasterElement(IMkvWriter* writer, uint64 value, uint64 size); |
| |
| // Outputs an Mkv ID, calls |IMkvWriter::ElementStartNotify|, and passes the |
| // ID to |SerializeInt|. Returns 0 on success. |
| int32 WriteID(IMkvWriter* writer, uint64 type); |
| |
| // Output an Mkv non-master element. Returns true if the element was written. |
| bool WriteEbmlElement(IMkvWriter* writer, uint64 type, uint64 value); |
| bool WriteEbmlElement(IMkvWriter* writer, uint64 type, int64 value); |
| bool WriteEbmlElement(IMkvWriter* writer, uint64 type, float value); |
| bool WriteEbmlElement(IMkvWriter* writer, uint64 type, const char* value); |
| bool WriteEbmlElement(IMkvWriter* writer, uint64 type, const uint8* value, |
| uint64 size); |
| bool WriteEbmlDateElement(IMkvWriter* writer, uint64 type, int64 value); |
| |
| // Output a Mkv Frame. It decides the correct element to write (Block vs |
| // SimpleBlock) based on the parameters of the Frame. |
| uint64 WriteFrame(IMkvWriter* writer, const Frame* const frame, |
| Cluster* cluster); |
| |
| // Output a void element. |size| must be the entire size in bytes that will be |
| // void. The function will calculate the size of the void header and subtract |
| // it from |size|. |
| uint64 WriteVoidElement(IMkvWriter* writer, uint64 size); |
| |
| // Returns the version number of the muxer in |major|, |minor|, |build|, |
| // and |revision|. |
| void GetVersion(int32* major, int32* minor, int32* build, int32* revision); |
| |
| // Returns a random number to be used for UID, using |seed| to seed |
| // the random-number generator (see POSIX rand_r() for semantics). |
| uint64 MakeUID(unsigned int* seed); |
| |
| } // end namespace mkvmuxer |
| |
| #endif // MKVMUXERUTIL_HPP |