taglib-ts
    Preparing search index...

    Class OggFileAbstract

    Abstract base class for OGG-based file formats. Provides packet-level access to the OGG bitstream by iterating pages and reassembling packets.

    On save, only header pages are re-rendered from packets. Audio pages are preserved verbatim (with updated page sequence numbers) so that granule positions, page boundaries, and audio data remain intact — producing output that is fully seekable and playable.

    Hierarchy (View Summary)

    Index

    Constructors

    Properties

    _stream: IOStream

    The underlying I/O stream.

    _valid: boolean = true

    Whether the file was parsed successfully. Subclasses set this to false when a fatal parse error is encountered.

    Accessors

    • get isOpen(): boolean

      Whether the underlying stream is currently open. Synchronous.

      Returns boolean

    • get isValid(): boolean

      Whether this file was parsed successfully.

      Returns boolean

    • get name(): string

      The name (path) of the underlying stream, as reported by the stream itself. Synchronous.

      Returns string

    • get numHeaderPackets(): number

      Number of header packets for this OGG format. Header packets are re-rendered on save; audio pages after them are copied verbatim. Override in subclasses:

      • Vorbis: 3 (identification, comment, setup)
      • Opus/Speex/OGG FLAC: 2 (identification, comment)

      Returns number

    • get readOnly(): boolean

      Whether the underlying stream is read-only. Synchronous.

      Returns boolean

    Methods

    • Resets the stream position to the beginning (equivalent to seek(0, Position.Beginning)).

      Returns Promise<void>

      A promise that resolves when the operation is complete.

    • Returns the list of complex-property keys supported by the tag.

      Returns string[]

      An array of key strings (e.g. "PICTURE").

    • Returns the total length of the stream in bytes.

      Note: this is an async method rather than a getter because getters cannot be async.

      Returns Promise<number>

      A promise resolving to the stream length in bytes.

    • Searches the stream forward for pattern starting at fromOffset.

      The stream cursor is restored to its original position after the search. If before is provided, the search stops (returning -1) as soon as before is encountered.

      Parameters

      • pattern: ByteVector

        The byte sequence to search for.

      • fromOffset: number = 0

        Byte offset at which to start searching. Defaults to 0.

      • Optionalbefore: ByteVector

        Optional sentinel; if found before pattern, returns -1.

      Returns Promise<number>

      A promise resolving to the byte offset of the first match, or -1 if not found.

    • Inserts data into the stream at start, optionally replacing replace bytes.

      Parameters

      • data: ByteVector

        The bytes to insert.

      • start: number = 0

        Byte offset at which to insert. Defaults to 0.

      • replace: number = 0

        Number of bytes to overwrite. Defaults to 0.

      Returns Promise<void>

      A promise that resolves when the operation is complete.

    • Returns the header of the last OGG page in the stream. Used for computing total granule count and thus stream duration.

      Returns Promise<OggPageHeader | null>

      The last OggPageHeader, or null if the stream is empty or invalid.

    • Retrieve a logical packet by its zero-based index. Returns the dirty (in-memory) version if one exists, otherwise reads and reassembles from disk.

      Parameters

      • index: number

        Zero-based packet index.

      Returns Promise<ByteVector>

      The packet data as a ByteVector.

    • Reads up to length bytes from the current stream position.

      Parameters

      • length: number

        The maximum number of bytes to read.

      Returns Promise<ByteVector>

      A promise resolving to the bytes read as a ByteVector.

    • Removes length bytes from the stream starting at start.

      Parameters

      • start: number = 0

        Byte offset of the first byte to remove. Defaults to 0.

      • length: number = 0

        Number of bytes to remove. Defaults to 0.

      Returns Promise<void>

      A promise that resolves when the operation is complete.

    • Removes unsupported properties from the tag.

      Parameters

      • properties: string[]

        The list of property keys to remove.

      Returns void

    • Searches the stream backward for pattern, starting at fromOffset (default: end of file).

      The stream cursor is restored to its original position after the search. If before is provided, the search stops (returning -1) as soon as before is encountered while scanning backward.

      Parameters

      • pattern: ByteVector

        The byte sequence to search for.

      • fromOffset: number = 0

        Upper bound for the search. 0 means end of file. Defaults to 0.

      • Optionalbefore: ByteVector

        Optional sentinel; if found before pattern, returns -1.

      Returns Promise<number>

      A promise resolving to the byte offset of the match, or -1 if not found.

    • Persist all pending packet changes to the underlying stream.

      Matches C++ Ogg::File::writePacket behaviour: for each dirty packet, find the original pages that carry it, determine which other packets co-reside on those pages, and repaginate only that range. Unchanged pages are copied verbatim (with adjusted sequence numbers).

      Key invariant: packet 0 (BOS/identification) always occupies exactly one page by itself. Non-BOS packets are repaginated with SinglePagePerGroup when the combined segment count fits in one page (≤ 255) or with Repaginate per packet otherwise — exactly mirroring C++ Ogg::Page::paginate.

      Returns Promise<boolean>

      true on success, false if the file is read-only or has no pages.

    • Moves the stream's read/write cursor to offset relative to position.

      Parameters

      • offset: number

        The byte offset to seek to.

      • position: Position = Position.Beginning

        The seek origin. Defaults to Position.Beginning.

      Returns Promise<void>

      A promise that resolves when the seek is complete.

    • Sets complex property values for the given key.

      Parameters

      Returns boolean

      true if the property was set, false if not supported.

    • Mark a packet as dirty with new content to be written on the next save.

      Parameters

      • index: number

        Zero-based packet index.

      • data: ByteVector

        New packet data to store and use when saving.

      Returns void

    • Returns the format-specific tag, or null if unavailable.

      Returns Tag | null

      The tag object, or null.

    • Returns the current byte offset of the stream cursor.

      Returns Promise<number>

      A promise resolving to the cursor position.

    • Truncates (or extends) the stream to exactly length bytes.

      Parameters

      • length: number

        The desired stream length in bytes.

      Returns Promise<void>

      A promise that resolves when the truncation is complete.

    • Writes data at the current stream position.

      Parameters

      Returns Promise<void>

      A promise that resolves when the write is complete.

    • The size of the read buffer used by find and rfind, in bytes.

      Returns number

      The buffer size (1024).