spacedrive/libmineziper/include/libmineziper_huffman_tree.h
2024-02-20 12:30:50 +01:00

29 lines
No EOL
540 B
C

#ifndef LIBMINEZIPER_HUFFMAN_TREE_H
#define LIBMINEZIPER_HUFFMAN_TREE_H
#include "libmineziper_bitstream.h"
#define DEFAULT_TREE_SIZE 288
#define DEFAULT_DIST_TREE_SIZE 32
typedef struct leaf
{
int code;
short litteral;
char length;
} leaf;
typedef struct tree
{
leaf* leaves;
unsigned int size;
unsigned int min, max;
} tree;
unsigned int* sort(unsigned char* ints, int size);
void print_huffman_tree(tree t);
tree build_tree(char* bit_lengths, int size);
tree build_default_tree();
tree build_default_dist_tree();
#endif