-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcompress.h
27 lines (24 loc) · 944 Bytes
/
compress.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
int node_cmp_ll(const void *c1, const void *c2);// Leaf compare function (using probabilities)
hub * create_tree(leaf **); // Calculate tree using Huffmann algorithm
hub * create_hub(leaf *, leaf *); // Crete parent hub for two leafs
int calc_prob(); // Open streams, calculate trees
void fill_node(unsigned char); // Character frequency counter and leaf creater
void print_code(code *); // Code printing for verbose
int fbitout(code *, FILE *); // Bit-by-bit output writing
void calc_codes(); // Calculate all coding codes at once
//char pad(FILE *); // Write padding (to achieve full byte)
void compress(); // Put everything together
void recursive_write(hub *);
#ifndef COMPRESS_VAR
#define COMPRESS_VAR
hub * tip;
char outbuf;
int outbuf_len;
char * writebuf;
FILE * temp;
code * calc_code(leaf *);
code * codetable[CHAR];
int hubcount;
int leafcount;
long int tempsize;
#endif