blob: 8c4fe7747b799bcbfc3267083f681d9943768aed [file] [log] [blame]
Gloria Wang37fe1582010-03-12 14:53:20 -08001/************************************************************************
Gloria Wang2da723a2010-03-18 15:56:16 -07002 * Copyright (C) 2002-2009, Xiph.org Foundation
3 * Copyright (C) 2010, Robin Watts for Pinknoise Productions Ltd
Gloria Wang37fe1582010-03-12 14:53:20 -08004 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
Gloria Wang2da723a2010-03-18 15:56:16 -07007 * modification, are permitted provided that the following conditions
8 * are met:
Gloria Wang37fe1582010-03-12 14:53:20 -08009 *
10 * * Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * * Redistributions in binary form must reproduce the above
13 * copyright notice, this list of conditions and the following disclaimer
14 * in the documentation and/or other materials provided with the
15 * distribution.
Gloria Wang2da723a2010-03-18 15:56:16 -070016 * * Neither the names of the Xiph.org Foundation nor Pinknoise
17 * Productions Ltd nor the names of its contributors may be used to
18 * endorse or promote products derived from this software without
19 * specific prior written permission.
Gloria Wang37fe1582010-03-12 14:53:20 -080020 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 ************************************************************************
Gloria Wang79130732010-02-08 14:41:04 -080033
34 function: stdio-based convenience library for opening/seeking/decoding
35
Gloria Wang37fe1582010-03-12 14:53:20 -080036 ************************************************************************/
Gloria Wang79130732010-02-08 14:41:04 -080037
38#ifndef _OV_FILE_H_
39#define _OV_FILE_H_
40
41#ifdef __cplusplus
42extern "C"
43{
44#endif /* __cplusplus */
45
46#include <stdio.h>
47#include "ivorbiscodec.h"
48
49/* The function prototypes for the callbacks are basically the same as for
50 * the stdio functions fread, fseek, fclose, ftell.
51 * The one difference is that the FILE * arguments have been replaced with
52 * a void * - this is to be used as a pointer to whatever internal data these
53 * functions might need. In the stdio case, it's just a FILE * cast to a void *
54 *
55 * If you use other functions, check the docs for these functions and return
56 * the right values. For seek_func(), you *MUST* return -1 if the stream is
57 * unseekable
58 */
59typedef struct {
60 size_t (*read_func) (void *ptr, size_t size, size_t nmemb, void *datasource);
61 int (*seek_func) (void *datasource, ogg_int64_t offset, int whence);
62 int (*close_func) (void *datasource);
63 long (*tell_func) (void *datasource);
64} ov_callbacks;
65
66typedef struct OggVorbis_File {
67 void *datasource; /* Pointer to a FILE *, etc. */
68 int seekable;
69 ogg_int64_t offset;
70 ogg_int64_t end;
71 ogg_sync_state *oy;
72
73 /* If the FILE handle isn't seekable (eg, a pipe), only the current
74 stream appears */
75 int links;
76 ogg_int64_t *offsets;
77 ogg_int64_t *dataoffsets;
78 ogg_uint32_t *serialnos;
79 ogg_int64_t *pcmlengths;
80 vorbis_info vi;
81 vorbis_comment vc;
82
83 /* Decoding working state local storage */
84 ogg_int64_t pcm_offset;
85 int ready_state;
86 ogg_uint32_t current_serialno;
87 int current_link;
88
89 ogg_int64_t bittrack;
90 ogg_int64_t samptrack;
91
92 ogg_stream_state *os; /* take physical pages, weld into a logical
93 stream of packets */
94 vorbis_dsp_state *vd; /* central working state for the packet->PCM decoder */
95
96 ov_callbacks callbacks;
97
98} OggVorbis_File;
99
100extern int ov_clear(OggVorbis_File *vf);
101extern int ov_open(FILE *f,OggVorbis_File *vf,char *initial,long ibytes);
102extern int ov_open_callbacks(void *datasource, OggVorbis_File *vf,
103 char *initial, long ibytes, ov_callbacks callbacks);
104
105extern int ov_test(FILE *f,OggVorbis_File *vf,char *initial,long ibytes);
106extern int ov_test_callbacks(void *datasource, OggVorbis_File *vf,
107 char *initial, long ibytes, ov_callbacks callbacks);
108extern int ov_test_open(OggVorbis_File *vf);
109
110extern long ov_bitrate(OggVorbis_File *vf,int i);
111extern long ov_bitrate_instant(OggVorbis_File *vf);
112extern long ov_streams(OggVorbis_File *vf);
113extern long ov_seekable(OggVorbis_File *vf);
114extern long ov_serialnumber(OggVorbis_File *vf,int i);
115
116extern ogg_int64_t ov_raw_total(OggVorbis_File *vf,int i);
117extern ogg_int64_t ov_pcm_total(OggVorbis_File *vf,int i);
118extern ogg_int64_t ov_time_total(OggVorbis_File *vf,int i);
119
120extern int ov_raw_seek(OggVorbis_File *vf,ogg_int64_t pos);
121extern int ov_pcm_seek(OggVorbis_File *vf,ogg_int64_t pos);
122extern int ov_pcm_seek_page(OggVorbis_File *vf,ogg_int64_t pos);
123extern int ov_time_seek(OggVorbis_File *vf,ogg_int64_t pos);
124extern int ov_time_seek_page(OggVorbis_File *vf,ogg_int64_t pos);
125
126extern ogg_int64_t ov_raw_tell(OggVorbis_File *vf);
127extern ogg_int64_t ov_pcm_tell(OggVorbis_File *vf);
128extern ogg_int64_t ov_time_tell(OggVorbis_File *vf);
129
130extern vorbis_info *ov_info(OggVorbis_File *vf,int link);
131extern vorbis_comment *ov_comment(OggVorbis_File *vf,int link);
132
133extern long ov_read(OggVorbis_File *vf,void *buffer,int length,
134 int *bitstream);
135
136#ifdef __cplusplus
137}
138#endif /* __cplusplus */
139
140#endif
141
142