Tremor documentation |
Tremor version 1.0 - 20020403 |
declared in "ivorbisfile.h";
This is an alternative function used to open and initialize an OggVorbis_File structure when using a data source other than a file. It allows you to specify custom file manipulation routines and sets up all the related decoding structure.
Once this has been called, the same OggVorbis_File struct should be passed to all the libvorbisidec functions.
It is often useful to call ov_open_callbacks() simply to determine whether a given file is a vorbis bitstream. If the ov_open_callbacks() call fails, then the file is not recognizable as such. When you use ov_open_callbacks() for this, you should fclose() the file pointer if, and only if, the ov_open_callbacks() call fails. If it succeeds, you must call ov_clear() to clear the decoder's buffers and close the file for you.
See also Callbacks and Non-stdio I/O for information on designing and specifying the required callback functions.
int ov_open_callbacks(void *datasource, OggVorbis_File *vf, char *initial, long ibytes, ov_callbacks callbacks); |
0 for success less than zero for failure:
- OV_EREAD - A read from media returned an error.
- OV_ENOTVORBIS - Bitstream is not Vorbis data.
- OV_EVERSION - Vorbis version mismatch.
- OV_EBADHEADER - Invalid Vorbis bitstream header.
- OV_EFAULT - Internal logic fault; indicates a bug or heap/stack corruption.
If your decoder is threaded, it is recommended that you NOT call
ov_open_callbacks()
in the main control thread--instead, call ov_open_callbacks() IN your decode/playback
thread. This is important because ov_open_callbacks() may be a fairly time-consuming
call, given that the full structure of the file is determined at this point,
which may require reading large parts of the file under certain circumstances
(determining all the logical bitstreams in one physical bitstream, for
example).
See Thread Safety for other information on using libvorbisidec with threads.
copyright © 2002 Xiph.org |
|
Tremor documentation |
Tremor version 1.0 - 20020403 |