forked from LeenkxTeam/LNXSDK
		
	
		
			
				
	
	
		
			229 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			229 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|    LZ4 HC - High Compression Mode of LZ4
 | |
|    Header File
 | |
|    Copyright (C) 2011-2016, Yann Collet.
 | |
|    BSD 2-Clause License (http://www.opensource.org/licenses/bsd-license.php)
 | |
| 
 | |
|    Redistribution and use in source and binary forms, with or without
 | |
|    modification, are permitted provided that the following conditions are
 | |
|    met:
 | |
| 
 | |
|        * Redistributions of source code must retain the above copyright
 | |
|    notice, this list of conditions and the following disclaimer.
 | |
|        * Redistributions in binary form must reproduce the above
 | |
|    copyright notice, this list of conditions and the following disclaimer
 | |
|    in the documentation and/or other materials provided with the
 | |
|    distribution.
 | |
| 
 | |
|    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 | |
|    "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 | |
|    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 | |
|    A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 | |
|    OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 | |
|    SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 | |
|    LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 | |
|    DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 | |
|    THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 | |
|    (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 | |
|    OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | |
| 
 | |
|    You can contact the author at :
 | |
|    - LZ4 source repository : https://github.com/lz4/lz4
 | |
|    - LZ4 public forum : https://groups.google.com/forum/#!forum/lz4c
 | |
| */
 | |
| #ifndef LZ4_HC_H_19834876238432
 | |
| #define LZ4_HC_H_19834876238432
 | |
| 
 | |
| #if defined (__cplusplus)
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /* --- Dependency --- */
 | |
| /* note : lz4hc is not an independent module, it requires lz4.h/lz4.c for proper compilation */
 | |
| #include "lz4.h"   /* stddef, LZ4LIB_API, LZ4_DEPRECATED */
 | |
| 
 | |
| 
 | |
| /* --- Useful constants --- */
 | |
| #define LZ4HC_CLEVEL_MIN         3
 | |
| #define LZ4HC_CLEVEL_DEFAULT     9
 | |
| #define LZ4HC_CLEVEL_OPT_MIN    11
 | |
| #define LZ4HC_CLEVEL_MAX        12
 | |
| 
 | |
| 
 | |
| /*-************************************
 | |
|  *  Block Compression
 | |
|  **************************************/
 | |
| /*! LZ4_compress_HC() :
 | |
|  * Compress data from `src` into `dst`, using the more powerful but slower "HC" algorithm.
 | |
|  * `dst` must be already allocated.
 | |
|  * Compression is guaranteed to succeed if `dstCapacity >= LZ4_compressBound(srcSize)` (see "lz4.h")
 | |
|  * Max supported `srcSize` value is LZ4_MAX_INPUT_SIZE (see "lz4.h")
 | |
|  * `compressionLevel` : Recommended values are between 4 and 9, although any value between 1 and LZ4HC_MAX_CLEVEL will work.
 | |
|  *                      Values >LZ4HC_MAX_CLEVEL behave the same as LZ4HC_MAX_CLEVEL.
 | |
|  * @return : the number of bytes written into 'dst'
 | |
|  *           or 0 if compression fails.
 | |
|  */
 | |
| LZ4LIB_API int LZ4_compress_HC (const char* src, char* dst, int srcSize, int dstCapacity, int compressionLevel);
 | |
| 
 | |
| 
 | |
| /* Note :
 | |
|  *   Decompression functions are provided within "lz4.h" (BSD license)
 | |
|  */
 | |
| 
 | |
| 
 | |
| /*! LZ4_compress_HC_extStateHC() :
 | |
|  * Same as LZ4_compress_HC(), but using an externally allocated memory segment for `state`.
 | |
|  * `state` size is provided by LZ4_sizeofStateHC().
 | |
|  * Memory segment must be aligned on 8-bytes boundaries (which a normal malloc() will do properly).
 | |
|  */
 | |
| LZ4LIB_API int LZ4_compress_HC_extStateHC(void* state, const char* src, char* dst, int srcSize, int maxDstSize, int compressionLevel);
 | |
| LZ4LIB_API int LZ4_sizeofStateHC(void);
 | |
| 
 | |
| 
 | |
| /*-************************************
 | |
|  *  Streaming Compression
 | |
|  *  Bufferless synchronous API
 | |
|  **************************************/
 | |
|  typedef union LZ4_streamHC_u LZ4_streamHC_t;   /* incomplete type (defined later) */
 | |
| 
 | |
| /*! LZ4_createStreamHC() and LZ4_freeStreamHC() :
 | |
|  * These functions create and release memory for LZ4 HC streaming state.
 | |
|  * Newly created states are automatically initialized.
 | |
|  * Existing states can be re-used several times, using LZ4_resetStreamHC().
 | |
|  * These methods are API and ABI stable, they can be used in combination with a DLL.
 | |
|  */
 | |
| LZ4LIB_API LZ4_streamHC_t* LZ4_createStreamHC(void);
 | |
| LZ4LIB_API int             LZ4_freeStreamHC (LZ4_streamHC_t* streamHCPtr);
 | |
| 
 | |
| LZ4LIB_API void LZ4_resetStreamHC (LZ4_streamHC_t* streamHCPtr, int compressionLevel);
 | |
| LZ4LIB_API int  LZ4_loadDictHC (LZ4_streamHC_t* streamHCPtr, const char* dictionary, int dictSize);
 | |
| 
 | |
| LZ4LIB_API int LZ4_compress_HC_continue (LZ4_streamHC_t* streamHCPtr, const char* src, char* dst, int srcSize, int maxDstSize);
 | |
| 
 | |
| LZ4LIB_API int LZ4_saveDictHC (LZ4_streamHC_t* streamHCPtr, char* safeBuffer, int maxDictSize);
 | |
| 
 | |
| /*
 | |
|   These functions compress data in successive blocks of any size, using previous blocks as dictionary.
 | |
|   One key assumption is that previous blocks (up to 64 KB) remain read-accessible while compressing next blocks.
 | |
|   There is an exception for ring buffers, which can be smaller than 64 KB.
 | |
|   Ring buffers scenario is automatically detected and handled by LZ4_compress_HC_continue().
 | |
| 
 | |
|   Before starting compression, state must be properly initialized, using LZ4_resetStreamHC().
 | |
|   A first "fictional block" can then be designated as initial dictionary, using LZ4_loadDictHC() (Optional).
 | |
| 
 | |
|   Then, use LZ4_compress_HC_continue() to compress each successive block.
 | |
|   Previous memory blocks (including initial dictionary when present) must remain accessible and unmodified during compression.
 | |
|   'dst' buffer should be sized to handle worst case scenarios, using LZ4_compressBound(), to ensure operation success.
 | |
| 
 | |
|   If, for any reason, previous data blocks can't be preserved unmodified in memory during next compression block,
 | |
|   you must save it to a safer memory space, using LZ4_saveDictHC().
 | |
|   Return value of LZ4_saveDictHC() is the size of dictionary effectively saved into 'safeBuffer'.
 | |
| */
 | |
| 
 | |
| 
 | |
| /*-******************************************
 | |
|  * !!!!!   STATIC LINKING ONLY   !!!!!
 | |
|  *******************************************/
 | |
| 
 | |
|  /*-*************************************
 | |
|  * PRIVATE DEFINITIONS :
 | |
|  * Do not use these definitions.
 | |
|  * They are exposed to allow static allocation of `LZ4_streamHC_t`.
 | |
|  * Using these definitions makes the code vulnerable to potential API break when upgrading LZ4
 | |
|  **************************************/
 | |
| #define LZ4HC_DICTIONARY_LOGSIZE 17
 | |
| #define LZ4HC_MAXD (1<<LZ4HC_DICTIONARY_LOGSIZE)
 | |
| #define LZ4HC_MAXD_MASK (LZ4HC_MAXD - 1)
 | |
| 
 | |
| #define LZ4HC_HASH_LOG 15
 | |
| #define LZ4HC_HASHTABLESIZE (1 << LZ4HC_HASH_LOG)
 | |
| #define LZ4HC_HASH_MASK (LZ4HC_HASHTABLESIZE - 1)
 | |
| 
 | |
| 
 | |
| #if defined(__cplusplus) || (defined (__STDC_VERSION__) && (__STDC_VERSION__ >= 199901L) /* C99 */)
 | |
| #include <stdint.h>
 | |
| 
 | |
| typedef struct
 | |
| {
 | |
|     uint32_t   hashTable[LZ4HC_HASHTABLESIZE];
 | |
|     uint16_t   chainTable[LZ4HC_MAXD];
 | |
|     const uint8_t* end;        /* next block here to continue on current prefix */
 | |
|     const uint8_t* base;       /* All index relative to this position */
 | |
|     const uint8_t* dictBase;   /* alternate base for extDict */
 | |
|     uint8_t* inputBuffer;      /* deprecated */
 | |
|     uint32_t   dictLimit;        /* below that point, need extDict */
 | |
|     uint32_t   lowLimit;         /* below that point, no more dict */
 | |
|     uint32_t   nextToUpdate;     /* index from which to continue dictionary update */
 | |
|     uint32_t   searchNum;        /* only for optimal parser */
 | |
|     uint32_t   compressionLevel;
 | |
| } LZ4HC_CCtx_internal;
 | |
| 
 | |
| #else
 | |
| 
 | |
| typedef struct
 | |
| {
 | |
|     unsigned int   hashTable[LZ4HC_HASHTABLESIZE];
 | |
|     unsigned short   chainTable[LZ4HC_MAXD];
 | |
|     const unsigned char* end;        /* next block here to continue on current prefix */
 | |
|     const unsigned char* base;       /* All index relative to this position */
 | |
|     const unsigned char* dictBase;   /* alternate base for extDict */
 | |
|     unsigned char* inputBuffer;      /* deprecated */
 | |
|     unsigned int   dictLimit;        /* below that point, need extDict */
 | |
|     unsigned int   lowLimit;         /* below that point, no more dict */
 | |
|     unsigned int   nextToUpdate;     /* index from which to continue dictionary update */
 | |
|     unsigned int   searchNum;        /* only for optimal parser */
 | |
|     unsigned int   compressionLevel;
 | |
| } LZ4HC_CCtx_internal;
 | |
| 
 | |
| #endif
 | |
| 
 | |
| #define LZ4_STREAMHCSIZE       (4*LZ4HC_HASHTABLESIZE + 2*LZ4HC_MAXD + 56) /* 393268 */
 | |
| #define LZ4_STREAMHCSIZE_SIZET (LZ4_STREAMHCSIZE / sizeof(size_t))
 | |
| union LZ4_streamHC_u {
 | |
|     size_t table[LZ4_STREAMHCSIZE_SIZET];
 | |
|     LZ4HC_CCtx_internal internal_donotuse;
 | |
| };   /* previously typedef'd to LZ4_streamHC_t */
 | |
| /*
 | |
|   LZ4_streamHC_t :
 | |
|   This structure allows static allocation of LZ4 HC streaming state.
 | |
|   State must be initialized using LZ4_resetStreamHC() before first use.
 | |
| 
 | |
|   Static allocation shall only be used in combination with static linking.
 | |
|   When invoking LZ4 from a DLL, use create/free functions instead, which are API and ABI stable.
 | |
| */
 | |
| 
 | |
| 
 | |
| /*-************************************
 | |
| *  Deprecated Functions
 | |
| **************************************/
 | |
| /* see lz4.h LZ4_DISABLE_DEPRECATE_WARNINGS to turn off deprecation warnings */
 | |
| 
 | |
| /* deprecated compression functions */
 | |
| /* these functions will trigger warning messages in future releases */
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC() instead") int LZ4_compressHC               (const char* source, char* dest, int inputSize);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC() instead") int LZ4_compressHC_limitedOutput (const char* source, char* dest, int inputSize, int maxOutputSize);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC() instead") int LZ4_compressHC2 (const char* source, char* dest, int inputSize, int compressionLevel);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC() instead") int LZ4_compressHC2_limitedOutput (const char* source, char* dest, int inputSize, int maxOutputSize, int compressionLevel);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_extStateHC() instead") int LZ4_compressHC_withStateHC               (void* state, const char* source, char* dest, int inputSize);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_extStateHC() instead") int LZ4_compressHC_limitedOutput_withStateHC (void* state, const char* source, char* dest, int inputSize, int maxOutputSize);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_extStateHC() instead") int LZ4_compressHC2_withStateHC (void* state, const char* source, char* dest, int inputSize, int compressionLevel);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_extStateHC() instead") int LZ4_compressHC2_limitedOutput_withStateHC(void* state, const char* source, char* dest, int inputSize, int maxOutputSize, int compressionLevel);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_continue() instead") int LZ4_compressHC_continue               (LZ4_streamHC_t* LZ4_streamHCPtr, const char* source, char* dest, int inputSize);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_continue() instead") int LZ4_compressHC_limitedOutput_continue (LZ4_streamHC_t* LZ4_streamHCPtr, const char* source, char* dest, int inputSize, int maxOutputSize);
 | |
| 
 | |
| /* Deprecated Streaming functions using older model; should no longer be used */
 | |
| LZ4_DEPRECATED("use LZ4_createStreamHC() instead") void* LZ4_createHC (char* inputBuffer);
 | |
| LZ4_DEPRECATED("use LZ4_saveDictHC() instead")     char* LZ4_slideInputBufferHC (void* LZ4HC_Data);
 | |
| LZ4_DEPRECATED("use LZ4_freeStreamHC() instead")   int   LZ4_freeHC (void* LZ4HC_Data);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_continue() instead") int LZ4_compressHC2_continue (void* LZ4HC_Data, const char* source, char* dest, int inputSize, int compressionLevel);
 | |
| LZ4_DEPRECATED("use LZ4_compress_HC_continue() instead") int LZ4_compressHC2_limitedOutput_continue (void* LZ4HC_Data, const char* source, char* dest, int inputSize, int maxOutputSize, int compressionLevel);
 | |
| LZ4_DEPRECATED("use LZ4_createStreamHC() instead") int   LZ4_sizeofStreamStateHC(void);
 | |
| LZ4_DEPRECATED("use LZ4_resetStreamHC() instead")  int   LZ4_resetStreamStateHC(void* state, char* inputBuffer);
 | |
| 
 | |
| 
 | |
| #if defined (__cplusplus)
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* LZ4_HC_H_19834876238432 */
 |