Build doom on clipv2 and clip+
[kugel-rb.git] / apps / codecs / libtremor / codec_internal.h
blob3cbd7cde8936d91797b187529f080402ffef27b5
1 /********************************************************************
2 * *
3 * THIS FILE IS PART OF THE OggVorbis 'TREMOR' CODEC SOURCE CODE. *
4 * *
5 * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
6 * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
7 * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
8 * *
9 * THE OggVorbis 'TREMOR' SOURCE CODE IS (C) COPYRIGHT 1994-2002 *
10 * BY THE Xiph.Org FOUNDATION http://www.xiph.org/ *
11 * *
12 ********************************************************************
14 function: libvorbis codec headers
16 ********************************************************************/
18 #ifndef _V_CODECI_H_
19 #define _V_CODECI_H_
21 #include "codebook.h"
23 typedef void vorbis_look_mapping;
24 typedef void vorbis_look_floor;
25 typedef void vorbis_look_residue;
26 typedef void vorbis_look_transform;
28 /* mode ************************************************************/
29 typedef struct {
30 int blockflag;
31 int windowtype;
32 int transformtype;
33 int mapping;
34 } vorbis_info_mode;
36 typedef void vorbis_info_floor;
37 typedef void vorbis_info_residue;
38 typedef void vorbis_info_mapping;
40 typedef struct private_state {
41 /* local lookup storage */
42 const void *window[2];
44 /* backend lookups are tied to the mode, not the backend or naked mapping */
45 int modebits;
46 vorbis_look_mapping **mode;
48 ogg_int64_t sample_count;
50 } private_state;
52 /* codec_setup_info contains all the setup information specific to the
53 specific compression/decompression mode in progress (eg,
54 psychoacoustic settings, channel setup, options, codebook
55 etc).
56 *********************************************************************/
58 typedef struct codec_setup_info {
60 /* Vorbis supports only short and long blocks, but allows the
61 encoder to choose the sizes */
63 int blocksizes_nbits[2];
64 long blocksizes[2]; /* = 1<<nbits */
66 /* modes are the primary means of supporting on-the-fly different
67 blocksizes, different channel mappings (LR or M/A),
68 different residue backends, etc. Each mode consists of a
69 blocksize flag and a mapping (along with the mapping setup */
71 int modes;
72 int maps;
73 int times;
74 int floors;
75 int residues;
76 int books;
78 vorbis_info_mode *mode_param[64];
79 int map_type[64];
80 vorbis_info_mapping *map_param[64];
81 int time_type[64];
82 int floor_type[64];
83 vorbis_info_floor *floor_param[64];
84 int residue_type[64];
85 vorbis_info_residue *residue_param[64];
86 static_codebook *book_param[256];
87 codebook *fullbooks;
89 int passlimit[32]; /* iteration limit per couple/quant pass */
90 int coupling_passes;
91 } codec_setup_info;
93 #endif