|  | #ifndef DECOMPRESS_GENERIC_H | 
|  | #define DECOMPRESS_GENERIC_H | 
|  |  | 
|  | typedef int (*decompress_fn) (unsigned char *inbuf, int len, | 
|  | int(*fill)(void*, unsigned int), | 
|  | int(*flush)(void*, unsigned int), | 
|  | unsigned char *outbuf, | 
|  | int *posp, | 
|  | void(*error)(char *x)); | 
|  |  | 
|  | /* inbuf   - input buffer | 
|  | *len     - len of pre-read data in inbuf | 
|  | *fill    - function to fill inbuf when empty | 
|  | *flush   - function to write out outbuf | 
|  | *outbuf  - output buffer | 
|  | *posp    - if non-null, input position (number of bytes read) will be | 
|  | *	  returned here | 
|  | * | 
|  | *If len != 0, inbuf should contain all the necessary input data, and fill | 
|  | *should be NULL | 
|  | *If len = 0, inbuf can be NULL, in which case the decompressor will allocate | 
|  | *the input buffer.  If inbuf != NULL it must be at least XXX_IOBUF_SIZE bytes. | 
|  | *fill will be called (repeatedly...) to read data, at most XXX_IOBUF_SIZE | 
|  | *bytes should be read per call.  Replace XXX with the appropriate decompressor | 
|  | *name, i.e. LZMA_IOBUF_SIZE. | 
|  | * | 
|  | *If flush = NULL, outbuf must be large enough to buffer all the expected | 
|  | *output.  If flush != NULL, the output buffer will be allocated by the | 
|  | *decompressor (outbuf = NULL), and the flush function will be called to | 
|  | *flush the output buffer at the appropriate time (decompressor and stream | 
|  | *dependent). | 
|  | */ | 
|  |  | 
|  |  | 
|  | /* Utility routine to detect the decompression method */ | 
|  | decompress_fn decompress_method(const unsigned char *inbuf, int len, | 
|  | const char **name); | 
|  |  | 
|  | #endif |