Bug 470455 - test_database_sync_embed_visits.js leaks, r=sdwilsh
[wine-gecko.git] / media / libtheora / lib / dec / huffdec.h
blob4d3ada3de43735c5a659b43c333908191cc50067
1 /********************************************************************
2 * *
3 * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE. *
4 * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
5 * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
6 * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
7 * *
8 * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2007 *
9 * by the Xiph.Org Foundation http://www.xiph.org/ *
10 * *
11 ********************************************************************
13 function:
14 last mod: $Id: huffdec.h 14359 2008-01-04 20:11:13Z tterribe $
16 ********************************************************************/
18 #if !defined(_huffdec_H)
19 # define _huffdec_H (1)
20 # include "huffman.h"
24 typedef struct oc_huff_node oc_huff_node;
26 /*A node in the Huffman tree.
27 Instead of storing every branching in the tree, subtrees can be collapsed
28 into one node, with a table of size 1<<nbits pointing directly to its
29 descedents nbits levels down.
30 This allows more than one bit to be read at a time, and avoids following all
31 the intermediate branches with next to no increased code complexity once
32 the collapsed tree has been built.
33 We do _not_ require that a subtree be complete to be collapsed, but instead
34 store duplicate pointers in the table, and record the actual depth of the
35 node below its parent.
36 This tells us the number of bits to advance the stream after reaching it.
38 This turns out to be equivalent to the method described in \cite{Hash95},
39 without the requirement that codewords be sorted by length.
40 If the codewords were sorted by length (so-called ``canonical-codes''), they
41 could be decoded much faster via either Lindell and Moffat's approach or
42 Hashemian's Condensed Huffman Code approach, the latter of which has an
43 extremely small memory footprint.
44 We can't use Choueka et al.'s finite state machine approach, which is
45 extremely fast, because we can't allow multiple symbols to be output at a
46 time; the codebook can and does change between symbols.
47 It also has very large memory requirements, which impairs cache coherency.
49 @ARTICLE{Hash95,
50 author="Reza Hashemian",
51 title="Memory Efficient and High-Speed Search {Huffman} Coding",
52 journal="{IEEE} Transactions on Communications",
53 volume=43,
54 number=10,
55 pages="2576--2581",
56 month=Oct,
57 year=1995
58 }*/
59 struct oc_huff_node{
60 /*The number of bits of the code needed to descend through this node.
61 0 indicates a leaf node.
62 Otherwise there are 1<<nbits nodes in the nodes table, which can be
63 indexed by reading nbits bits from the stream.*/
64 unsigned char nbits;
65 /*The value of a token stored in a leaf node.
66 The value in non-leaf nodes is undefined.*/
67 unsigned char token;
68 /*The depth of the current node, relative to its parent in the collapsed
69 tree.
70 This can be less than its parent's nbits value, in which case there are
71 1<<nbits-depth copies of this node in the table, and the bitstream should
72 only be advanced depth bits after reaching this node.*/
73 unsigned char depth;
74 /*The table of child nodes.
75 The ACTUAL size of this array is 1<<nbits, despite what the declaration
76 below claims.
77 The exception is that for leaf nodes the size is 0.*/
78 oc_huff_node *nodes[1];
83 int oc_huff_trees_unpack(oggpack_buffer *_opb,
84 oc_huff_node *_nodes[TH_NHUFFMAN_TABLES]);
85 void oc_huff_trees_copy(oc_huff_node *_dst[TH_NHUFFMAN_TABLES],
86 const oc_huff_node *const _src[TH_NHUFFMAN_TABLES]);
87 void oc_huff_trees_clear(oc_huff_node *_nodes[TH_NHUFFMAN_TABLES]);
88 int oc_huff_token_decode(oggpack_buffer *_opb,const oc_huff_node *_node);
91 #endif