Tag Parser 12.4.0
C++ library for reading and writing MP4 (iTunes), ID3, Vorbis, Opus, FLAC and Matroska tags
|
The OggIterator class helps iterating through all segments of an Ogg bitstream. More...
#include <oggiterator.h>
Public Member Functions | |
OggIterator (std::istream &stream, std::uint64_t startOffset, std::uint64_t streamSize) | |
Constructs a new iterator for the specified stream of streamSize bytes at the specified startOffset. | |
void | clear (std::istream &stream, std::uint64_t startOffset, std::uint64_t streamSize) |
Sets the stream and related parameters and clears all available pages. | |
std::istream & | stream () |
Returns the stream. | |
void | setStream (std::istream &stream) |
Sets the stream. | |
std::uint64_t | startOffset () const |
Returns the start offset (which has been specified when constructing the iterator). | |
std::uint64_t | streamSize () const |
Returns the stream size (which has been specified when constructing the iterator). | |
void | reset () |
Resets the iterator to point at the first segment of the first page (matching the filter if set). | |
void | nextPage () |
Increases the current position by one page. | |
void | nextSegment () |
Increases the current position by one segment. | |
void | previousPage () |
Decreases the current position by one page. | |
void | previousSegment () |
Decreases the current position by one segment. | |
const std::vector< OggPage > & | pages () const |
Returns a vector of containing the Ogg pages that have been fetched yet. | |
std::vector< OggPage > & | pages () |
Returns a vector of containing the Ogg pages that have been fetched yet. | |
const OggPage & | currentPage () const |
Returns the current Ogg page. | |
std::uint64_t | currentPageOffset () const |
Returns the start offset of the current Ogg page. | |
std::vector< OggPage >::size_type | currentPageIndex () const |
Returns the index of the current page if the iterator is valid; otherwise an undefined index is returned. | |
void | setPageIndex (std::vector< OggPage >::size_type index) |
Sets the current page index. | |
void | setSegmentIndex (std::vector< std::uint32_t >::size_type index) |
Sets the current segment index. | |
std::vector< std::uint32_t >::size_type | currentSegmentIndex () const |
Returns the index of the current segment (in the current page) if the iterator is valid; otherwise an undefined index is returned. | |
std::uint64_t | currentSegmentOffset () const |
Returns the start offset of the current segment in the input stream if the iterator is valid; otherwise an undefined offset is returned. | |
std::uint64_t | currentCharacterOffset () const |
Returns the offset of the current character in the input stream if the iterator is valid; otherwise an undefined offset is returned. | |
std::uint64_t | tellg () const |
Same as currentCharacterOffset(); only provided for compliance with std::istream. | |
std::uint32_t | currentSegmentSize () const |
Returns the size of the current segment. | |
std::uint64_t | remainingBytesInCurrentSegment () const |
Returns the number of bytes left to read in the current segment. | |
std::uint64_t | bytesReadFromCurrentSegment () const |
Returns the number of bytes read from the current segment. | |
void | setFilter (std::uint32_t streamSerialId) |
Allows to filter pages by the specified streamSerialId. | |
void | removeFilter () |
Removes a previously set filter. | |
bool | isLastPageFetched () const |
Returns whether the last page has already been fetched. | |
void | read (char *buffer, std::size_t count) |
Reads count bytes from the Ogg stream and writes it to the specified buffer. | |
std::size_t | readAll (char *buffer, std::size_t max) |
Reads all bytes from the Ogg stream and writes it to the specified buffer. | |
void | ignore (std::size_t count=1) |
Advances the position of the next character to be read from the Ogg stream by count bytes. | |
bool | bytesRemaining (std::size_t atLeast) const |
Returns whether there are atLeast bytes remaining. | |
bool | resyncAt (std::uint64_t offset) |
Fetches the next page at the specified offset. | |
operator bool () const | |
Returns an indication whether the iterator is valid. | |
OggIterator & | operator++ () |
Increments the current position by one segment if the iterator is valid; otherwise nothing happens. | |
OggIterator | operator++ (int) |
Increments the current position by one segment if the iterator is valid; otherwise nothing happens. | |
OggIterator & | operator-- () |
Decrements the current position by one segment if the iterator is valid; otherwise nothing happens. | |
OggIterator | operator-- (int) |
Decrements the current position by one segment if the iterator is valid; otherwise nothing happens. | |
The OggIterator class helps iterating through all segments of an Ogg bitstream.
If an OggIterator has just been constructed it is invalid. To fetch the first page from the stream call the reset() method. The iterator will now point to the first segment of the first page.
To go on call the appropriate methods. Parsing exceptions and IO exceptions might occur during iteration.
The internal buffer of Ogg pages might be accessed using the pages() method.
|
inline |
Constructs a new iterator for the specified stream of streamSize bytes at the specified startOffset.
Definition at line 73 of file oggiterator.h.
|
inline |
Returns the number of bytes read from the current segment.
Definition at line 256 of file oggiterator.h.
|
inline |
Returns whether there are atLeast bytes remaining.
Definition at line 296 of file oggiterator.h.
void TagParser::OggIterator::clear | ( | std::istream & | stream, |
std::uint64_t | startOffset, | ||
std::uint64_t | streamSize ) |
Sets the stream and related parameters and clears all available pages.
Definition at line 32 of file oggiterator.cpp.
|
inline |
Returns the offset of the current character in the input stream if the iterator is valid; otherwise an undefined offset is returned.
Definition at line 222 of file oggiterator.h.
|
inline |
Returns the current Ogg page.
Definition at line 142 of file oggiterator.h.
|
inline |
Returns the index of the current page if the iterator is valid; otherwise an undefined index is returned.
Definition at line 174 of file oggiterator.h.
|
inline |
Returns the start offset of the current Ogg page.
Definition at line 151 of file oggiterator.h.
|
inline |
Returns the index of the current segment (in the current page) if the iterator is valid; otherwise an undefined index is returned.
Definition at line 204 of file oggiterator.h.
|
inline |
Returns the start offset of the current segment in the input stream if the iterator is valid; otherwise an undefined offset is returned.
Definition at line 213 of file oggiterator.h.
|
inline |
Returns the size of the current segment.
This method should never be called on an invalid iterator, since this causes undefined behaviour.
Definition at line 240 of file oggiterator.h.
void TagParser::OggIterator::ignore | ( | std::size_t | count = 1 | ) |
Advances the position of the next character to be read from the Ogg stream by count bytes.
Throws | a TruncatedDataException if the end of the stream is exceeded. |
Definition at line 199 of file oggiterator.cpp.
|
inline |
Returns whether the last page has already been fetched.
Definition at line 287 of file oggiterator.h.
void TagParser::OggIterator::nextPage | ( | ) |
Increases the current position by one page.
Definition at line 63 of file oggiterator.cpp.
void TagParser::OggIterator::nextSegment | ( | ) |
Increases the current position by one segment.
Enters the next page if the current segment is the last one in the current page.
Definition at line 81 of file oggiterator.cpp.
|
inline |
Returns an indication whether the iterator is valid.
The iterator is invalid when it has just been constructed. Incrementing and decrementing might cause invalidation.
If the iterator is invalid, it can be reset using the reset() method.
Some methods cause undefined behaviour if called on an invalid iterator.
Definition at line 166 of file oggiterator.h.
|
inline |
Increments the current position by one segment if the iterator is valid; otherwise nothing happens.
Definition at line 304 of file oggiterator.h.
|
inline |
Increments the current position by one segment if the iterator is valid; otherwise nothing happens.
Definition at line 313 of file oggiterator.h.
|
inline |
Decrements the current position by one segment if the iterator is valid; otherwise nothing happens.
Definition at line 323 of file oggiterator.h.
|
inline |
Decrements the current position by one segment if the iterator is valid; otherwise nothing happens.
Definition at line 332 of file oggiterator.h.
|
inline |
Returns a vector of containing the Ogg pages that have been fetched yet.
Definition at line 133 of file oggiterator.h.
|
inline |
Returns a vector of containing the Ogg pages that have been fetched yet.
Definition at line 125 of file oggiterator.h.
void TagParser::OggIterator::previousPage | ( | ) |
Decreases the current position by one page.
Definition at line 98 of file oggiterator.cpp.
void TagParser::OggIterator::previousSegment | ( | ) |
Decreases the current position by one segment.
Definition at line 113 of file oggiterator.cpp.
void TagParser::OggIterator::read | ( | char * | buffer, |
std::size_t | count ) |
Reads count bytes from the Ogg stream and writes it to the specified buffer.
Throws | a TruncatedDataException if the end of the stream is reached before count bytes have been read. |
Definition at line 134 of file oggiterator.cpp.
std::size_t TagParser::OggIterator::readAll | ( | char * | buffer, |
std::size_t | max ) |
Reads all bytes from the Ogg stream and writes it to the specified buffer.
Definition at line 169 of file oggiterator.cpp.
|
inline |
Returns the number of bytes left to read in the current segment.
Definition at line 248 of file oggiterator.h.
|
inline |
void TagParser::OggIterator::reset | ( | ) |
Resets the iterator to point at the first segment of the first page (matching the filter if set).
Fetched pages (directly accessible through the page() method) remain after resetting the iterator. Use clear() to clear all pages.
Definition at line 46 of file oggiterator.cpp.
bool TagParser::OggIterator::resyncAt | ( | std::uint64_t | offset | ) |
Fetches the next page at the specified offset.
This allows to omit parts of a file which is useful to
Regardless of the current iterator position, this method will assume the page at offset comes after the last known page. Hence offset must be greater than OggPage::startOffset() + OggPage::totalSize() of the last known page. This is checked by the method.
If the Ogg capture pattern is not present at offset, up to 65307 bytes (max. size of an Ogg page) are skipped. So in a valid stream, this method will always succeed if offset is less than the stream size minus 65307.
If a page could be found, it is appended to pages() and the iterator position is set to the first segment of that page. If no page could be found, this method does not alter the iterator.
Throws | std::ios_base::failure when an IO error occurs. |
Throws | Failure when a parsing error occurs. |
Definition at line 237 of file oggiterator.cpp.
|
inline |
Allows to filter pages by the specified streamSerialId.
Pages which do not match the specified streamSerialId will be skipped when getting the previous or the next page.
Definition at line 269 of file oggiterator.h.
|
inline |
Sets the current page index.
Definition at line 183 of file oggiterator.h.
|
inline |
Sets the current segment index.
This method should never be called with an index out of range (which is defined by the number of segments in the current page), since this causes undefined behaviour.
Definition at line 195 of file oggiterator.h.
|
inline |
Sets the stream.
Definition at line 101 of file oggiterator.h.
|
inline |
Returns the start offset (which has been specified when constructing the iterator).
Definition at line 109 of file oggiterator.h.
|
inline |
Returns the stream.
The stream has been specified when constructing the iterator and might be changed using the setStream() methods.
Definition at line 91 of file oggiterator.h.
|
inline |
Returns the stream size (which has been specified when constructing the iterator).
Definition at line 117 of file oggiterator.h.
|
inline |
Same as currentCharacterOffset(); only provided for compliance with std::istream.
Definition at line 230 of file oggiterator.h.