/*
Data structures for an up-to-256ary tree to hold strings
*/
/* forward */
struct r_node;
/* A single character to a string, a node consists of a bunch of these */
struct r_letter {
unsigned char c; /* The letter itself */
struct r_node *child; /* The next node to look in after this character */
/* Additional data to be associated with a certain string */
/* starts here, it can be most anything. */
#ifdef COMPRESSOR
#define VALID_CODE(n) ((n) & 0x8000) ? 1 : 0)
unsigned short code; /* What the output code for the string up to */
/* this point is. */
#else
unsigned int count; /* How many times have we seen this string */
#endif
};
struct r_node {
short int count; /* How many letters do I have */
struct r_letter letter[1]; /* An array of 'count' letters */
};
extern int r_insert();
extern void r_dump();
#ifdef COMPRESSOR
extern int r_compress();
#endif
extern void init_string_compress();
extern int string_compress();
extern int string_decompress();