| #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 |