2014-12-13 14:05:46 +00:00
|
|
|
/*
|
|
|
|
LZ4 auto-framing library
|
|
|
|
Header File for static linking only
|
2016-11-21 23:51:39 +00:00
|
|
|
Copyright (C) 2011-2016, Yann Collet.
|
2014-12-13 14:05:46 +00:00
|
|
|
|
|
|
|
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 :
|
2016-11-03 14:12:57 +00:00
|
|
|
- LZ4 source repository : https://github.com/lz4/lz4
|
2014-12-13 14:05:46 +00:00
|
|
|
- LZ4 public forum : https://groups.google.com/forum/#!forum/lz4c
|
|
|
|
*/
|
|
|
|
|
2016-11-04 03:32:51 +00:00
|
|
|
#ifndef LZ4FRAME_STATIC_H_0398209384
|
|
|
|
#define LZ4FRAME_STATIC_H_0398209384
|
2014-12-13 14:05:46 +00:00
|
|
|
|
|
|
|
#if defined (__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* lz4frame_static.h should be used solely in the context of static linking.
|
2016-11-04 03:32:51 +00:00
|
|
|
* It contains definitions which are not stable and may change in the future.
|
2015-04-19 14:23:53 +00:00
|
|
|
* Never use it in the context of DLL linking.
|
2018-01-08 19:46:22 +00:00
|
|
|
*
|
|
|
|
* Defining LZ4F_PUBLISH_STATIC_FUNCTIONS allows one to override this. Use at
|
|
|
|
* your own risk.
|
2017-03-29 00:10:01 +00:00
|
|
|
*/
|
2018-01-08 19:46:22 +00:00
|
|
|
#ifdef LZ4F_PUBLISH_STATIC_FUNCTIONS
|
|
|
|
#define LZ4FLIB_STATIC_API LZ4FLIB_API
|
|
|
|
#else
|
|
|
|
#define LZ4FLIB_STATIC_API
|
|
|
|
#endif
|
2014-12-13 14:05:46 +00:00
|
|
|
|
|
|
|
|
2016-11-04 03:32:51 +00:00
|
|
|
/* --- Dependency --- */
|
2015-04-19 14:23:53 +00:00
|
|
|
#include "lz4frame.h"
|
|
|
|
|
|
|
|
|
2016-11-04 03:32:51 +00:00
|
|
|
/* --- Error List --- */
|
2014-12-13 14:05:46 +00:00
|
|
|
#define LZ4F_LIST_ERRORS(ITEM) \
|
2017-03-29 00:10:01 +00:00
|
|
|
ITEM(OK_NoError) \
|
|
|
|
ITEM(ERROR_GENERIC) \
|
|
|
|
ITEM(ERROR_maxBlockSize_invalid) \
|
|
|
|
ITEM(ERROR_blockMode_invalid) \
|
|
|
|
ITEM(ERROR_contentChecksumFlag_invalid) \
|
2014-12-13 14:05:46 +00:00
|
|
|
ITEM(ERROR_compressionLevel_invalid) \
|
2017-03-29 00:10:01 +00:00
|
|
|
ITEM(ERROR_headerVersion_wrong) \
|
2017-08-12 00:46:52 +00:00
|
|
|
ITEM(ERROR_blockChecksum_invalid) \
|
2017-03-29 00:10:01 +00:00
|
|
|
ITEM(ERROR_reservedFlag_set) \
|
2014-12-13 14:05:46 +00:00
|
|
|
ITEM(ERROR_allocation_failed) \
|
2017-03-29 00:10:01 +00:00
|
|
|
ITEM(ERROR_srcSize_tooLarge) \
|
|
|
|
ITEM(ERROR_dstMaxSize_tooSmall) \
|
|
|
|
ITEM(ERROR_frameHeader_incomplete) \
|
|
|
|
ITEM(ERROR_frameType_unknown) \
|
|
|
|
ITEM(ERROR_frameSize_wrong) \
|
2015-04-15 09:34:08 +00:00
|
|
|
ITEM(ERROR_srcPtr_wrong) \
|
2014-12-13 14:05:46 +00:00
|
|
|
ITEM(ERROR_decompressionFailed) \
|
2017-03-29 00:10:01 +00:00
|
|
|
ITEM(ERROR_headerChecksum_invalid) \
|
|
|
|
ITEM(ERROR_contentChecksum_invalid) \
|
|
|
|
ITEM(ERROR_frameDecoding_alreadyStarted) \
|
2014-12-13 14:05:46 +00:00
|
|
|
ITEM(ERROR_maxCode)
|
|
|
|
|
2017-03-29 00:10:01 +00:00
|
|
|
#define LZ4F_GENERATE_ENUM(ENUM) LZ4F_##ENUM,
|
|
|
|
|
|
|
|
/* enum list is exposed, to handle specific errors */
|
|
|
|
typedef enum { LZ4F_LIST_ERRORS(LZ4F_GENERATE_ENUM) } LZ4F_errorCodes;
|
2014-12-13 14:05:46 +00:00
|
|
|
|
2018-01-08 19:46:22 +00:00
|
|
|
LZ4FLIB_STATIC_API LZ4F_errorCodes LZ4F_getErrorCode(size_t functionResult);
|
2016-11-11 23:11:56 +00:00
|
|
|
|
2014-12-13 14:05:46 +00:00
|
|
|
|
2017-08-09 23:51:19 +00:00
|
|
|
|
|
|
|
/**********************************
|
|
|
|
* Bulk processing dictionary API
|
|
|
|
*********************************/
|
|
|
|
typedef struct LZ4F_CDict_s LZ4F_CDict;
|
|
|
|
|
|
|
|
/*! LZ4_createCDict() :
|
|
|
|
* When compressing multiple messages / blocks with the same dictionary, it's recommended to load it just once.
|
|
|
|
* LZ4_createCDict() will create a digested dictionary, ready to start future compression operations without startup delay.
|
|
|
|
* LZ4_CDict can be created once and shared by multiple threads concurrently, since its usage is read-only.
|
2017-08-10 23:53:57 +00:00
|
|
|
* `dictBuffer` can be released after LZ4_CDict creation, since its content is copied within CDict */
|
2018-01-08 19:46:22 +00:00
|
|
|
LZ4FLIB_STATIC_API LZ4F_CDict* LZ4F_createCDict(const void* dictBuffer, size_t dictSize);
|
|
|
|
LZ4FLIB_STATIC_API void LZ4F_freeCDict(LZ4F_CDict* CDict);
|
2017-08-09 23:51:19 +00:00
|
|
|
|
2017-08-10 23:53:57 +00:00
|
|
|
|
2017-08-09 23:51:19 +00:00
|
|
|
/*! LZ4_compressFrame_usingCDict() :
|
|
|
|
* Compress an entire srcBuffer into a valid LZ4 frame using a digested Dictionary.
|
2018-01-26 16:29:00 +00:00
|
|
|
* cctx must point to a context created by LZ4F_createCompressionContext().
|
2017-08-09 23:51:19 +00:00
|
|
|
* If cdict==NULL, compress without a dictionary.
|
|
|
|
* dstBuffer MUST be >= LZ4F_compressFrameBound(srcSize, preferencesPtr).
|
|
|
|
* If this condition is not respected, function will fail (@return an errorCode).
|
|
|
|
* The LZ4F_preferences_t structure is optional : you may provide NULL as argument,
|
|
|
|
* but it's not recommended, as it's the only way to provide dictID in the frame header.
|
|
|
|
* @return : number of bytes written into dstBuffer.
|
2017-08-10 23:53:57 +00:00
|
|
|
* or an error code if it fails (can be tested using LZ4F_isError()) */
|
2018-01-08 19:46:22 +00:00
|
|
|
LZ4FLIB_STATIC_API size_t LZ4F_compressFrame_usingCDict(
|
2018-01-26 16:29:00 +00:00
|
|
|
LZ4F_cctx* cctx,
|
2018-01-08 19:46:22 +00:00
|
|
|
void* dst, size_t dstCapacity,
|
|
|
|
const void* src, size_t srcSize,
|
|
|
|
const LZ4F_CDict* cdict,
|
|
|
|
const LZ4F_preferences_t* preferencesPtr);
|
2017-08-09 23:51:19 +00:00
|
|
|
|
|
|
|
|
|
|
|
/*! LZ4F_compressBegin_usingCDict() :
|
|
|
|
* Inits streaming dictionary compression, and writes the frame header into dstBuffer.
|
|
|
|
* dstCapacity must be >= LZ4F_HEADER_SIZE_MAX bytes.
|
|
|
|
* `prefsPtr` is optional : you may provide NULL as argument,
|
|
|
|
* however, it's the only way to provide dictID in the frame header.
|
|
|
|
* @return : number of bytes written into dstBuffer for the header,
|
2017-08-10 23:53:57 +00:00
|
|
|
* or an error code (which can be tested using LZ4F_isError()) */
|
2018-01-08 19:46:22 +00:00
|
|
|
LZ4FLIB_STATIC_API size_t LZ4F_compressBegin_usingCDict(
|
|
|
|
LZ4F_cctx* cctx,
|
|
|
|
void* dstBuffer, size_t dstCapacity,
|
|
|
|
const LZ4F_CDict* cdict,
|
|
|
|
const LZ4F_preferences_t* prefsPtr);
|
2017-08-09 23:51:19 +00:00
|
|
|
|
|
|
|
|
2017-08-10 23:53:57 +00:00
|
|
|
/*! LZ4F_decompress_usingDict() :
|
|
|
|
* Same as LZ4F_decompress(), using a predefined dictionary.
|
|
|
|
* Dictionary is used "in place", without any preprocessing.
|
|
|
|
* It must remain accessible throughout the entire frame decoding. */
|
2018-01-08 19:46:22 +00:00
|
|
|
LZ4FLIB_STATIC_API size_t LZ4F_decompress_usingDict(
|
|
|
|
LZ4F_dctx* dctxPtr,
|
|
|
|
void* dstBuffer, size_t* dstSizePtr,
|
|
|
|
const void* srcBuffer, size_t* srcSizePtr,
|
|
|
|
const void* dict, size_t dictSize,
|
|
|
|
const LZ4F_decompressOptions_t* decompressOptionsPtr);
|
2017-08-10 23:53:57 +00:00
|
|
|
|
|
|
|
|
2014-12-13 14:05:46 +00:00
|
|
|
#if defined (__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
2016-11-04 03:32:51 +00:00
|
|
|
|
|
|
|
#endif /* LZ4FRAME_STATIC_H_0398209384 */
|