opusfile  0.4
Stand-alone decoder library for .opus files.
 All Data Structures Functions Variables Typedefs Groups
Data Structures | Macros
Header Information

Data Structures

struct  OpusHead
 Ogg Opus bitstream information. More...
struct  OpusTags
 The metadata from an Ogg Opus stream. More...
struct  OpusPictureTag
 The contents of a METADATA_BLOCK_PICTURE tag. More...

Macros

#define OPUS_CHANNEL_COUNT_MAX   (255)
 The maximum number of channels in an Ogg Opus stream.

Picture tag image formats

#define OP_PIC_FORMAT_UNKNOWN   (-1)
 The MIME type was not recognized, or the image data did not match the declared MIME type.
#define OP_PIC_FORMAT_URL   (0)
 The MIME type indicates the image data is really a URL.
#define OP_PIC_FORMAT_JPEG   (1)
 The image is a JPEG.
#define OP_PIC_FORMAT_PNG   (2)
 The image is a PNG.
#define OP_PIC_FORMAT_GIF   (3)
 The image is a GIF.

Functions for manipulating header data

These functions manipulate the OpusHead and OpusTags structures, which describe the audio parameters and tag-value metadata, respectively.

These can be used to query the headers returned by libopusfile, or to parse Opus headers from sources other than an Ogg Opus stream, provided they use the same format.

OP_WARN_UNUSED_RESULT int opus_head_parse (OpusHead *_head, const unsigned char *_data, size_t _len) OP_ARG_NONNULL(2)
 Parses the contents of the ID header packet of an Ogg Opus stream.
ogg_int64_t opus_granule_sample (const OpusHead *_head, ogg_int64_t _gp) OP_ARG_NONNULL(1)
 Converts a granule position to a sample offset for a given Ogg Opus stream.
OP_WARN_UNUSED_RESULT int opus_tags_parse (OpusTags *_tags, const unsigned char *_data, size_t _len) OP_ARG_NONNULL(2)
 Parses the contents of the 'comment' header packet of an Ogg Opus stream.
void opus_tags_init (OpusTags *_tags) OP_ARG_NONNULL(1)
 Initializes an OpusTags structure.
int opus_tags_add (OpusTags *_tags, const char *_tag, const char *_value) OP_ARG_NONNULL(1) OP_ARG_NONNULL(2) OP_ARG_NONNULL(3)
 Add a (tag, value) pair to an initialized OpusTags structure.
int opus_tags_add_comment (OpusTags *_tags, const char *_comment) OP_ARG_NONNULL(1) OP_ARG_NONNULL(2)
 Add a comment to an initialized OpusTags structure.
const char * opus_tags_query (const OpusTags *_tags, const char *_tag, int _count) OP_ARG_NONNULL(1) OP_ARG_NONNULL(2)
 Look up a comment value by its tag.
int opus_tags_query_count (const OpusTags *_tags, const char *_tag) OP_ARG_NONNULL(1) OP_ARG_NONNULL(2)
 Look up the number of instances of a tag.
int opus_tags_get_track_gain (const OpusTags *_tags, int *_gain_q8) OP_ARG_NONNULL(1) OP_ARG_NONNULL(2)
 Get the track gain from an R128_TRACK_GAIN tag, if one was specified.
void opus_tags_clear (OpusTags *_tags) OP_ARG_NONNULL(1)
 Clears the OpusTags structure.
int opus_picture_tag_parse (OpusPictureTag *_pic, const char *_tag) OP_ARG_NONNULL(1) OP_ARG_NONNULL(2)
 Parse a single METADATA_BLOCK_PICTURE tag.
void opus_picture_tag_init (OpusPictureTag *_pic) OP_ARG_NONNULL(1)
 Initializes an OpusPictureTag structure.
void opus_picture_tag_clear (OpusPictureTag *_pic) OP_ARG_NONNULL(1)
 Clears the OpusPictureTag structure.

Detailed Description


Macro Definition Documentation

#define OPUS_CHANNEL_COUNT_MAX   (255)

The maximum number of channels in an Ogg Opus stream.

#define OP_PIC_FORMAT_UNKNOWN   (-1)

The MIME type was not recognized, or the image data did not match the declared MIME type.

#define OP_PIC_FORMAT_URL   (0)

The MIME type indicates the image data is really a URL.

#define OP_PIC_FORMAT_JPEG   (1)

The image is a JPEG.

#define OP_PIC_FORMAT_PNG   (2)

The image is a PNG.

#define OP_PIC_FORMAT_GIF   (3)

The image is a GIF.


Function Documentation

OP_WARN_UNUSED_RESULT int opus_head_parse ( OpusHead _head,
const unsigned char *  _data,
size_t  _len 
)

Parses the contents of the ID header packet of an Ogg Opus stream.

Parameters:
[out]_headReturns the contents of the parsed packet. The contents of this structure are untouched on error. This may be NULL to merely test the header for validity.
[in]_dataThe contents of the ID header packet.
_lenThe number of bytes of data in the ID header packet.
Returns:
0 on success or a negative value on error.
Return values:
OP_ENOTFORMATIf the data does not start with the "OpusHead" string.
OP_EVERSIONIf the version field signaled a version this library does not know how to parse.
OP_EIMPLIf the channel mapping family was 255, which general purpose players should not attempt to play.
OP_EBADHEADERIf the contents of the packet otherwise violate the Ogg Opus specification:
  • Insufficient data,
  • Too much data for the known minor versions,
  • An unrecognized channel mapping family,
  • Zero channels or too many channels,
  • Zero coded streams,
  • Too many coupled streams, or
  • An invalid channel mapping index.
ogg_int64_t opus_granule_sample ( const OpusHead _head,
ogg_int64_t  _gp 
)

Converts a granule position to a sample offset for a given Ogg Opus stream.

The sample offset is simply _gp-_head->pre_skip. Granule position values smaller than OpusHead::pre_skip correspond to audio that should never be played, and thus have no associated sample offset. This function returns -1 for such values. This function also correctly handles extremely large granule positions, which may have wrapped around to a negative number when stored in a signed ogg_int64_t value.

Parameters:
_headThe OpusHead information from the ID header of the stream.
_gpThe granule position to convert.
Returns:
The sample offset associated with the given granule position (counting at a 48 kHz sampling rate), or the special value -1 on error (i.e., the granule position was smaller than the pre-skip amount).
OP_WARN_UNUSED_RESULT int opus_tags_parse ( OpusTags _tags,
const unsigned char *  _data,
size_t  _len 
)

Parses the contents of the 'comment' header packet of an Ogg Opus stream.

Parameters:
[out]_tagsAn uninitialized OpusTags structure. This returns the contents of the parsed packet. The contents of this structure are untouched on error. This may be NULL to merely test the header for validity.
[in]_dataThe contents of the 'comment' header packet.
_lenThe number of bytes of data in the 'info' header packet.
Return values:
0Success.
OP_ENOTFORMATIf the data does not start with the "OpusTags" string.
OP_EBADHEADERIf the contents of the packet otherwise violate the Ogg Opus specification.
OP_EFAULTIf there wasn't enough memory to store the tags.
void opus_tags_init ( OpusTags _tags)

Initializes an OpusTags structure.

This should be called on a freshly allocated OpusTags structure before attempting to use it.

Parameters:
_tagsThe OpusTags structure to initialize.
int opus_tags_add ( OpusTags _tags,
const char *  _tag,
const char *  _value 
)

Add a (tag, value) pair to an initialized OpusTags structure.

Note:
Neither opus_tags_add() nor opus_tags_add_comment() support values containing embedded NULs, although the bitstream format does support them. To add such tags, you will need to manipulate the OpusTags structure directly.
Parameters:
_tagsThe OpusTags structure to add the (tag, value) pair to.
_tagA NUL-terminated, case-insensitive, ASCII string containing the tag to add (without an '=' character).
_valueA NUL-terminated UTF-8 containing the corresponding value.
Returns:
0 on success, or a negative value on failure.
Return values:
OP_EFAULTAn internal memory allocation failed.
int opus_tags_add_comment ( OpusTags _tags,
const char *  _comment 
)

Add a comment to an initialized OpusTags structure.

Note:
Neither opus_tags_add_comment() nor opus_tags_add() support comments containing embedded NULs, although the bitstream format does support them. To add such tags, you will need to manipulate the OpusTags structure directly.
Parameters:
_tagsThe OpusTags structure to add the comment to.
_commentA NUL-terminated UTF-8 string containing the comment in "TAG=value" form.
Returns:
0 on success, or a negative value on failure.
Return values:
OP_EFAULTAn internal memory allocation failed.
const char* opus_tags_query ( const OpusTags _tags,
const char *  _tag,
int  _count 
)

Look up a comment value by its tag.

Parameters:
_tagsAn initialized OpusTags structure.
_tagThe tag to look up.
_countThe instance of the tag. The same tag can appear multiple times, each with a distinct value, so an index is required to retrieve them all. The order in which these values appear is significant and should be preserved. Use opus_tags_query_count() to get the legal range for the _count parameter.
Returns:
A pointer to the queried tag's value. This points directly to data in the OpusTags structure. It should not be modified or freed by the application, and modifications to the structure may invalidate the pointer.
Return values:
NULLIf no matching tag is found.
int opus_tags_query_count ( const OpusTags _tags,
const char *  _tag 
)

Look up the number of instances of a tag.

Call this first when querying for a specific tag and then iterate over the number of instances with separate calls to opus_tags_query() to retrieve all the values for that tag in order.

Parameters:
_tagsAn initialized OpusTags structure.
_tagThe tag to look up.
Returns:
The number of instances of this particular tag.
int opus_tags_get_track_gain ( const OpusTags _tags,
int *  _gain_q8 
)

Get the track gain from an R128_TRACK_GAIN tag, if one was specified.

This searches for the first R128_TRACK_GAIN tag with a valid signed, 16-bit decimal integer value and returns the value. This routine is exposed merely for convenience for applications which wish to do something special with the track gain (i.e., display it). If you simply wish to apply the track gain instead of the header gain, you can use op_set_gain_offset() with an OP_TRACK_GAIN type and no offset.

Parameters:
_tagsAn initialized OpusTags structure.
[out]_gain_q8The track gain, in 1/256ths of a dB. This will lie in the range [-32768,32767], and should be applied in addition to the header gain. On error, no value is returned, and the previous contents remain unchanged.
Returns:
0 on success, or a negative value on error.
Return values:
OP_EFALSEThere was no track gain available in the given tags.
void opus_tags_clear ( OpusTags _tags)

Clears the OpusTags structure.

This should be called on an OpusTags structure after it is no longer needed. It will free all memory used by the structure members.

Parameters:
_tagsThe OpusTags structure to clear.
int opus_picture_tag_parse ( OpusPictureTag _pic,
const char *  _tag 
)

Parse a single METADATA_BLOCK_PICTURE tag.

This decodes the BASE64-encoded content of the tag and returns a structure with the MIME type, description, image parameters (if known), and the compressed image data. If the MIME type indicates the presence of an image format we recognize (JPEG, PNG, or GIF) and the actual image data contains the magic signature associated with that format, then the OpusPictureTag::format field will be set to the corresponding format. This is provided as a convenience to avoid requiring applications to parse the MIME type and/or do their own format detection for the commonly used formats. In this case, we also attempt to extract the image parameters directly from the image data (overriding any that were present in the tag, which the specification says applications are not meant to rely on). The application must still provide its own support for actually decoding the image data and, if applicable, retrieving that data from URLs.

Parameters:
[out]_picReturns the parsed picture data. No sanitation is done on the type, MIME type, or description fields, so these might return invalid values. The contents of this structure are left unmodified on failure.
_tagThe METADATA_BLOCK_PICTURE tag contents. The leading "METADATA_BLOCK_PICTURE=" portion is optional, to allow the function to be used on either directly on the values in OpusTags::user_comments or on the return value of opus_tags_query().
Returns:
0 on success or a negative value on error.
Return values:
OP_ENOTFORMATThe METADATA_BLOCK_PICTURE contents were not valid.
OP_EFAULTA memory allocation failed.
void opus_picture_tag_init ( OpusPictureTag _pic)

Initializes an OpusPictureTag structure.

This should be called on a freshly allocated OpusPictureTag structure before attempting to use it.

Parameters:
_picThe OpusPictureTag structure to initialize.
void opus_picture_tag_clear ( OpusPictureTag _pic)

Clears the OpusPictureTag structure.

This should be called on an OpusPictureTag structure after it is no longer needed. It will free all memory used by the structure members.

Parameters:
_picThe OpusPictureTag structure to clear.