zstdlib 0.8.0-x64-mingw32 → 0.9.0-x64-mingw32
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGES.md +10 -0
- data/README.md +7 -1
- data/Rakefile +38 -8
- data/ext/{zstdlib → zstdlib_c}/extconf.rb +10 -5
- data/ext/{zstdlib → zstdlib_c}/ruby/zlib-2.2/zstdlib.c +2 -2
- data/ext/{zstdlib → zstdlib_c}/ruby/zlib-2.3/zstdlib.c +2 -2
- data/ext/{zstdlib → zstdlib_c}/ruby/zlib-2.4/zstdlib.c +2 -2
- data/ext/{zstdlib → zstdlib_c}/ruby/zlib-2.5/zstdlib.c +2 -2
- data/ext/{zstdlib → zstdlib_c}/ruby/zlib-2.6/zstdlib.c +2 -2
- data/ext/{zstdlib → zstdlib_c}/ruby/zlib-2.7/zstdlib.c +2 -2
- data/ext/{zstdlib → zstdlib_c}/ruby/zlib-3.0/zstdlib.c +2 -2
- data/ext/zstdlib_c/ruby/zlib-3.1/zstdlib.c +5076 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/adler32.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/compress.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/crc32.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/crc32.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/deflate.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/deflate.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/gzclose.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/gzguts.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/gzlib.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/gzread.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/gzwrite.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/infback.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/inffast.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/inffast.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/inffixed.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/inflate.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/inflate.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/inftrees.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/inftrees.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/trees.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/trees.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/uncompr.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/zconf.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/zlib.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/zutil.c +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib-1.2.11/zutil.h +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlib.mk +0 -0
- data/ext/{zstdlib → zstdlib_c}/zlibwrapper/zlibwrapper.c +1 -5
- data/ext/{zstdlib → zstdlib_c}/zlibwrapper.mk +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/bitstream.h +24 -9
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/compiler.h +89 -43
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/cpu.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/debug.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/debug.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/entropy_common.c +11 -5
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/error_private.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/error_private.h +79 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/fse.h +2 -1
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/fse_decompress.c +1 -1
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/huf.h +24 -22
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/mem.h +18 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/pool.c +11 -6
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/pool.h +2 -2
- data/ext/zstdlib_c/zstd-1.5.2/lib/common/portability_macros.h +137 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/threading.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/threading.h +0 -0
- data/ext/zstdlib_c/zstd-1.5.2/lib/common/xxhash.c +24 -0
- data/ext/zstdlib_c/zstd-1.5.2/lib/common/xxhash.h +5686 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/zstd_common.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/zstd_deps.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/zstd_internal.h +95 -92
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/common/zstd_trace.h +12 -3
- data/ext/zstdlib_c/zstd-1.5.2/lib/compress/clevels.h +134 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/fse_compress.c +63 -27
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/hist.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/hist.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/huf_compress.c +537 -104
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress.c +307 -373
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress_internal.h +174 -83
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress_literals.c +4 -3
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress_literals.h +3 -1
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress_sequences.c +15 -14
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress_sequences.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress_superblock.c +4 -3
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_compress_superblock.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_cwksp.h +41 -27
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_double_fast.c +295 -120
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_double_fast.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_fast.c +309 -130
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_fast.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_lazy.c +482 -562
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_lazy.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_ldm.c +9 -7
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_ldm.h +1 -1
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_ldm_geartab.h +4 -1
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_opt.c +249 -148
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstd_opt.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstdmt_compress.c +76 -38
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/compress/zstdmt_compress.h +4 -1
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/decompress/huf_decompress.c +727 -189
- data/ext/zstdlib_c/zstd-1.5.2/lib/decompress/huf_decompress_amd64.S +585 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/decompress/zstd_ddict.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/decompress/zstd_ddict.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/decompress/zstd_decompress.c +85 -22
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/decompress/zstd_decompress_block.c +744 -220
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/decompress/zstd_decompress_block.h +8 -2
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/decompress/zstd_decompress_internal.h +34 -3
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/zdict.h +4 -4
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/zstd.h +179 -136
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/lib/zstd_errors.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/gzclose.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/gzcompatibility.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/gzguts.h +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/gzlib.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/gzread.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/gzwrite.c +0 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/zstd_zlibwrapper.c +7 -0
- data/ext/{zstdlib/zstd-1.5.0 → zstdlib_c/zstd-1.5.2}/zlibWrapper/zstd_zlibwrapper.h +0 -0
- data/ext/zstdlib_c/zstd.mk +15 -0
- data/lib/2.4/zstdlib_c.so +0 -0
- data/lib/2.5/zstdlib_c.so +0 -0
- data/lib/2.6/zstdlib_c.so +0 -0
- data/lib/2.7/zstdlib_c.so +0 -0
- data/lib/3.0/zstdlib_c.so +0 -0
- data/lib/zstdlib.rb +2 -2
- metadata +124 -121
- data/ext/zstdlib/zstd-1.5.0/lib/common/xxhash.c +0 -824
- data/ext/zstdlib/zstd-1.5.0/lib/common/xxhash.h +0 -285
- data/ext/zstdlib/zstd.mk +0 -14
- data/lib/2.2/zstdlib.so +0 -0
- data/lib/2.3/zstdlib.so +0 -0
- data/lib/2.4/zstdlib.so +0 -0
- data/lib/2.5/zstdlib.so +0 -0
- data/lib/2.6/zstdlib.so +0 -0
- data/lib/2.7/zstdlib.so +0 -0
@@ -20,19 +20,21 @@ extern "C" {
|
|
20
20
|
|
21
21
|
|
22
22
|
/* ===== ZSTDLIB_API : control library symbols visibility ===== */
|
23
|
-
#ifndef
|
24
|
-
# if defined(__GNUC__) && (__GNUC__ >= 4)
|
25
|
-
# define
|
23
|
+
#ifndef ZSTDLIB_VISIBLE
|
24
|
+
# if defined(__GNUC__) && (__GNUC__ >= 4) && !defined(__MINGW32__)
|
25
|
+
# define ZSTDLIB_VISIBLE __attribute__ ((visibility ("default")))
|
26
|
+
# define ZSTDLIB_HIDDEN __attribute__ ((visibility ("hidden")))
|
26
27
|
# else
|
27
|
-
# define
|
28
|
+
# define ZSTDLIB_VISIBLE
|
29
|
+
# define ZSTDLIB_HIDDEN
|
28
30
|
# endif
|
29
31
|
#endif
|
30
32
|
#if defined(ZSTD_DLL_EXPORT) && (ZSTD_DLL_EXPORT==1)
|
31
|
-
# define ZSTDLIB_API __declspec(dllexport)
|
33
|
+
# define ZSTDLIB_API __declspec(dllexport) ZSTDLIB_VISIBLE
|
32
34
|
#elif defined(ZSTD_DLL_IMPORT) && (ZSTD_DLL_IMPORT==1)
|
33
|
-
# define ZSTDLIB_API __declspec(dllimport)
|
35
|
+
# define ZSTDLIB_API __declspec(dllimport) ZSTDLIB_VISIBLE /* It isn't required but allows to generate better code, saving a function pointer load from the IAT and an indirect jump.*/
|
34
36
|
#else
|
35
|
-
# define ZSTDLIB_API
|
37
|
+
# define ZSTDLIB_API ZSTDLIB_VISIBLE
|
36
38
|
#endif
|
37
39
|
|
38
40
|
|
@@ -72,7 +74,7 @@ extern "C" {
|
|
72
74
|
/*------ Version ------*/
|
73
75
|
#define ZSTD_VERSION_MAJOR 1
|
74
76
|
#define ZSTD_VERSION_MINOR 5
|
75
|
-
#define ZSTD_VERSION_RELEASE
|
77
|
+
#define ZSTD_VERSION_RELEASE 2
|
76
78
|
#define ZSTD_VERSION_NUMBER (ZSTD_VERSION_MAJOR *100*100 + ZSTD_VERSION_MINOR *100 + ZSTD_VERSION_RELEASE)
|
77
79
|
|
78
80
|
/*! ZSTD_versionNumber() :
|
@@ -247,7 +249,7 @@ ZSTDLIB_API size_t ZSTD_decompressDCtx(ZSTD_DCtx* dctx,
|
|
247
249
|
*
|
248
250
|
* It's possible to reset all parameters to "default" using ZSTD_CCtx_reset().
|
249
251
|
*
|
250
|
-
* This API
|
252
|
+
* This API supersedes all other "advanced" API entry points in the experimental section.
|
251
253
|
* In the future, we expect to remove from experimental API entry points which are redundant with this API.
|
252
254
|
*/
|
253
255
|
|
@@ -417,7 +419,7 @@ typedef enum {
|
|
417
419
|
* ZSTD_c_stableOutBuffer
|
418
420
|
* ZSTD_c_blockDelimiters
|
419
421
|
* ZSTD_c_validateSequences
|
420
|
-
*
|
422
|
+
* ZSTD_c_useBlockSplitter
|
421
423
|
* ZSTD_c_useRowMatchFinder
|
422
424
|
* Because they are not stable, it's necessary to define ZSTD_STATIC_LINKING_ONLY to access them.
|
423
425
|
* note : never ever use experimentalParam? names directly;
|
@@ -932,7 +934,7 @@ ZSTDLIB_API unsigned ZSTD_getDictID_fromFrame(const void* src, size_t srcSize);
|
|
932
934
|
* Advanced dictionary and prefix API (Requires v1.4.0+)
|
933
935
|
*
|
934
936
|
* This API allows dictionaries to be used with ZSTD_compress2(),
|
935
|
-
* ZSTD_compressStream2(), and
|
937
|
+
* ZSTD_compressStream2(), and ZSTD_decompressDCtx(). Dictionaries are sticky, and
|
936
938
|
* only reset with the context is reset with ZSTD_reset_parameters or
|
937
939
|
* ZSTD_reset_session_and_parameters. Prefixes are single-use.
|
938
940
|
******************************************************************************/
|
@@ -1073,25 +1075,36 @@ ZSTDLIB_API size_t ZSTD_sizeof_DDict(const ZSTD_DDict* ddict);
|
|
1073
1075
|
#if defined(ZSTD_STATIC_LINKING_ONLY) && !defined(ZSTD_H_ZSTD_STATIC_LINKING_ONLY)
|
1074
1076
|
#define ZSTD_H_ZSTD_STATIC_LINKING_ONLY
|
1075
1077
|
|
1078
|
+
/* This can be overridden externally to hide static symbols. */
|
1079
|
+
#ifndef ZSTDLIB_STATIC_API
|
1080
|
+
# if defined(ZSTD_DLL_EXPORT) && (ZSTD_DLL_EXPORT==1)
|
1081
|
+
# define ZSTDLIB_STATIC_API __declspec(dllexport) ZSTDLIB_VISIBLE
|
1082
|
+
# elif defined(ZSTD_DLL_IMPORT) && (ZSTD_DLL_IMPORT==1)
|
1083
|
+
# define ZSTDLIB_STATIC_API __declspec(dllimport) ZSTDLIB_VISIBLE
|
1084
|
+
# else
|
1085
|
+
# define ZSTDLIB_STATIC_API ZSTDLIB_VISIBLE
|
1086
|
+
# endif
|
1087
|
+
#endif
|
1088
|
+
|
1076
1089
|
/* Deprecation warnings :
|
1077
1090
|
* Should these warnings be a problem, it is generally possible to disable them,
|
1078
1091
|
* typically with -Wno-deprecated-declarations for gcc or _CRT_SECURE_NO_WARNINGS in Visual.
|
1079
1092
|
* Otherwise, it's also possible to define ZSTD_DISABLE_DEPRECATE_WARNINGS.
|
1080
1093
|
*/
|
1081
1094
|
#ifdef ZSTD_DISABLE_DEPRECATE_WARNINGS
|
1082
|
-
# define ZSTD_DEPRECATED(message)
|
1095
|
+
# define ZSTD_DEPRECATED(message) ZSTDLIB_STATIC_API /* disable deprecation warnings */
|
1083
1096
|
#else
|
1084
1097
|
# if defined (__cplusplus) && (__cplusplus >= 201402) /* C++14 or greater */
|
1085
|
-
# define ZSTD_DEPRECATED(message) [[deprecated(message)]]
|
1098
|
+
# define ZSTD_DEPRECATED(message) [[deprecated(message)]] ZSTDLIB_STATIC_API
|
1086
1099
|
# elif (defined(GNUC) && (GNUC > 4 || (GNUC == 4 && GNUC_MINOR >= 5))) || defined(__clang__)
|
1087
|
-
# define ZSTD_DEPRECATED(message)
|
1100
|
+
# define ZSTD_DEPRECATED(message) ZSTDLIB_STATIC_API __attribute__((deprecated(message)))
|
1088
1101
|
# elif defined(__GNUC__) && (__GNUC__ >= 3)
|
1089
|
-
# define ZSTD_DEPRECATED(message)
|
1102
|
+
# define ZSTD_DEPRECATED(message) ZSTDLIB_STATIC_API __attribute__((deprecated))
|
1090
1103
|
# elif defined(_MSC_VER)
|
1091
|
-
# define ZSTD_DEPRECATED(message)
|
1104
|
+
# define ZSTD_DEPRECATED(message) ZSTDLIB_STATIC_API __declspec(deprecated(message))
|
1092
1105
|
# else
|
1093
1106
|
# pragma message("WARNING: You need to implement ZSTD_DEPRECATED for this compiler")
|
1094
|
-
# define ZSTD_DEPRECATED(message)
|
1107
|
+
# define ZSTD_DEPRECATED(message) ZSTDLIB_STATIC_API
|
1095
1108
|
# endif
|
1096
1109
|
#endif /* ZSTD_DISABLE_DEPRECATE_WARNINGS */
|
1097
1110
|
|
@@ -1157,9 +1170,6 @@ ZSTDLIB_API size_t ZSTD_sizeof_DDict(const ZSTD_DDict* ddict);
|
|
1157
1170
|
#define ZSTD_SRCSIZEHINT_MIN 0
|
1158
1171
|
#define ZSTD_SRCSIZEHINT_MAX INT_MAX
|
1159
1172
|
|
1160
|
-
/* internal */
|
1161
|
-
#define ZSTD_HASHLOG3_MAX 17
|
1162
|
-
|
1163
1173
|
|
1164
1174
|
/* --- Advanced types --- */
|
1165
1175
|
|
@@ -1302,10 +1312,14 @@ typedef enum {
|
|
1302
1312
|
} ZSTD_literalCompressionMode_e;
|
1303
1313
|
|
1304
1314
|
typedef enum {
|
1305
|
-
|
1306
|
-
|
1307
|
-
|
1308
|
-
|
1315
|
+
/* Note: This enum controls features which are conditionally beneficial. Zstd typically will make a final
|
1316
|
+
* decision on whether or not to enable the feature (ZSTD_ps_auto), but setting the switch to ZSTD_ps_enable
|
1317
|
+
* or ZSTD_ps_disable allow for a force enable/disable the feature.
|
1318
|
+
*/
|
1319
|
+
ZSTD_ps_auto = 0, /* Let the library automatically determine whether the feature shall be enabled */
|
1320
|
+
ZSTD_ps_enable = 1, /* Force-enable the feature */
|
1321
|
+
ZSTD_ps_disable = 2 /* Do not use the feature */
|
1322
|
+
} ZSTD_paramSwitch_e;
|
1309
1323
|
|
1310
1324
|
/***************************************
|
1311
1325
|
* Frame size functions
|
@@ -1332,7 +1346,7 @@ typedef enum {
|
|
1332
1346
|
* note 5 : ZSTD_findDecompressedSize handles multiple frames, and so it must traverse the input to
|
1333
1347
|
* read each contained frame header. This is fast as most of the data is skipped,
|
1334
1348
|
* however it does mean that all frame data must be present and valid. */
|
1335
|
-
|
1349
|
+
ZSTDLIB_STATIC_API unsigned long long ZSTD_findDecompressedSize(const void* src, size_t srcSize);
|
1336
1350
|
|
1337
1351
|
/*! ZSTD_decompressBound() :
|
1338
1352
|
* `src` should point to the start of a series of ZSTD encoded and/or skippable frames
|
@@ -1347,13 +1361,13 @@ ZSTDLIB_API unsigned long long ZSTD_findDecompressedSize(const void* src, size_t
|
|
1347
1361
|
* note 3 : when the decompressed size field isn't available, the upper-bound for that frame is calculated by:
|
1348
1362
|
* upper-bound = # blocks * min(128 KB, Window_Size)
|
1349
1363
|
*/
|
1350
|
-
|
1364
|
+
ZSTDLIB_STATIC_API unsigned long long ZSTD_decompressBound(const void* src, size_t srcSize);
|
1351
1365
|
|
1352
1366
|
/*! ZSTD_frameHeaderSize() :
|
1353
1367
|
* srcSize must be >= ZSTD_FRAMEHEADERSIZE_PREFIX.
|
1354
1368
|
* @return : size of the Frame Header,
|
1355
1369
|
* or an error code (if srcSize is too small) */
|
1356
|
-
|
1370
|
+
ZSTDLIB_STATIC_API size_t ZSTD_frameHeaderSize(const void* src, size_t srcSize);
|
1357
1371
|
|
1358
1372
|
typedef enum {
|
1359
1373
|
ZSTD_sf_noBlockDelimiters = 0, /* Representation of ZSTD_Sequence has no block delimiters, sequences only */
|
@@ -1376,7 +1390,7 @@ typedef enum {
|
|
1376
1390
|
* @return : number of sequences generated
|
1377
1391
|
*/
|
1378
1392
|
|
1379
|
-
|
1393
|
+
ZSTDLIB_STATIC_API size_t ZSTD_generateSequences(ZSTD_CCtx* zc, ZSTD_Sequence* outSeqs,
|
1380
1394
|
size_t outSeqsSize, const void* src, size_t srcSize);
|
1381
1395
|
|
1382
1396
|
/*! ZSTD_mergeBlockDelimiters() :
|
@@ -1390,7 +1404,7 @@ ZSTDLIB_API size_t ZSTD_generateSequences(ZSTD_CCtx* zc, ZSTD_Sequence* outSeqs,
|
|
1390
1404
|
* setting of ZSTD_c_blockDelimiters as ZSTD_sf_noBlockDelimiters
|
1391
1405
|
* @return : number of sequences left after merging
|
1392
1406
|
*/
|
1393
|
-
|
1407
|
+
ZSTDLIB_STATIC_API size_t ZSTD_mergeBlockDelimiters(ZSTD_Sequence* sequences, size_t seqsSize);
|
1394
1408
|
|
1395
1409
|
/*! ZSTD_compressSequences() :
|
1396
1410
|
* Compress an array of ZSTD_Sequence, generated from the original source buffer, into dst.
|
@@ -1420,7 +1434,7 @@ ZSTDLIB_API size_t ZSTD_mergeBlockDelimiters(ZSTD_Sequence* sequences, size_t se
|
|
1420
1434
|
* and cannot emit an RLE block that disagrees with the repcode history
|
1421
1435
|
* @return : final compressed size or a ZSTD error.
|
1422
1436
|
*/
|
1423
|
-
|
1437
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressSequences(ZSTD_CCtx* const cctx, void* dst, size_t dstSize,
|
1424
1438
|
const ZSTD_Sequence* inSeqs, size_t inSeqsSize,
|
1425
1439
|
const void* src, size_t srcSize);
|
1426
1440
|
|
@@ -1438,9 +1452,29 @@ ZSTDLIB_API size_t ZSTD_compressSequences(ZSTD_CCtx* const cctx, void* dst, size
|
|
1438
1452
|
*
|
1439
1453
|
* @return : number of bytes written or a ZSTD error.
|
1440
1454
|
*/
|
1441
|
-
|
1455
|
+
ZSTDLIB_STATIC_API size_t ZSTD_writeSkippableFrame(void* dst, size_t dstCapacity,
|
1442
1456
|
const void* src, size_t srcSize, unsigned magicVariant);
|
1443
1457
|
|
1458
|
+
/*! ZSTD_readSkippableFrame() :
|
1459
|
+
* Retrieves a zstd skippable frame containing data given by src, and writes it to dst buffer.
|
1460
|
+
*
|
1461
|
+
* The parameter magicVariant will receive the magicVariant that was supplied when the frame was written,
|
1462
|
+
* i.e. magicNumber - ZSTD_MAGIC_SKIPPABLE_START. This can be NULL if the caller is not interested
|
1463
|
+
* in the magicVariant.
|
1464
|
+
*
|
1465
|
+
* Returns an error if destination buffer is not large enough, or if the frame is not skippable.
|
1466
|
+
*
|
1467
|
+
* @return : number of bytes written or a ZSTD error.
|
1468
|
+
*/
|
1469
|
+
ZSTDLIB_API size_t ZSTD_readSkippableFrame(void* dst, size_t dstCapacity, unsigned* magicVariant,
|
1470
|
+
const void* src, size_t srcSize);
|
1471
|
+
|
1472
|
+
/*! ZSTD_isSkippableFrame() :
|
1473
|
+
* Tells if the content of `buffer` starts with a valid Frame Identifier for a skippable frame.
|
1474
|
+
*/
|
1475
|
+
ZSTDLIB_API unsigned ZSTD_isSkippableFrame(const void* buffer, size_t size);
|
1476
|
+
|
1477
|
+
|
1444
1478
|
|
1445
1479
|
/***************************************
|
1446
1480
|
* Memory management
|
@@ -1469,10 +1503,10 @@ ZSTDLIB_API size_t ZSTD_writeSkippableFrame(void* dst, size_t dstCapacity,
|
|
1469
1503
|
* Note 2 : only single-threaded compression is supported.
|
1470
1504
|
* ZSTD_estimateCCtxSize_usingCCtxParams() will return an error code if ZSTD_c_nbWorkers is >= 1.
|
1471
1505
|
*/
|
1472
|
-
|
1473
|
-
|
1474
|
-
|
1475
|
-
|
1506
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCCtxSize(int compressionLevel);
|
1507
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCCtxSize_usingCParams(ZSTD_compressionParameters cParams);
|
1508
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCCtxSize_usingCCtxParams(const ZSTD_CCtx_params* params);
|
1509
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateDCtxSize(void);
|
1476
1510
|
|
1477
1511
|
/*! ZSTD_estimateCStreamSize() :
|
1478
1512
|
* ZSTD_estimateCStreamSize() will provide a budget large enough for any compression level up to selected one.
|
@@ -1487,20 +1521,20 @@ ZSTDLIB_API size_t ZSTD_estimateDCtxSize(void);
|
|
1487
1521
|
* Note : if streaming is init with function ZSTD_init?Stream_usingDict(),
|
1488
1522
|
* an internal ?Dict will be created, which additional size is not estimated here.
|
1489
1523
|
* In this case, get total size by adding ZSTD_estimate?DictSize */
|
1490
|
-
|
1491
|
-
|
1492
|
-
|
1493
|
-
|
1494
|
-
|
1524
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCStreamSize(int compressionLevel);
|
1525
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCStreamSize_usingCParams(ZSTD_compressionParameters cParams);
|
1526
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCStreamSize_usingCCtxParams(const ZSTD_CCtx_params* params);
|
1527
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateDStreamSize(size_t windowSize);
|
1528
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateDStreamSize_fromFrame(const void* src, size_t srcSize);
|
1495
1529
|
|
1496
1530
|
/*! ZSTD_estimate?DictSize() :
|
1497
1531
|
* ZSTD_estimateCDictSize() will bet that src size is relatively "small", and content is copied, like ZSTD_createCDict().
|
1498
1532
|
* ZSTD_estimateCDictSize_advanced() makes it possible to control compression parameters precisely, like ZSTD_createCDict_advanced().
|
1499
1533
|
* Note : dictionaries created by reference (`ZSTD_dlm_byRef`) are logically smaller.
|
1500
1534
|
*/
|
1501
|
-
|
1502
|
-
|
1503
|
-
|
1535
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCDictSize(size_t dictSize, int compressionLevel);
|
1536
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateCDictSize_advanced(size_t dictSize, ZSTD_compressionParameters cParams, ZSTD_dictLoadMethod_e dictLoadMethod);
|
1537
|
+
ZSTDLIB_STATIC_API size_t ZSTD_estimateDDictSize(size_t dictSize, ZSTD_dictLoadMethod_e dictLoadMethod);
|
1504
1538
|
|
1505
1539
|
/*! ZSTD_initStatic*() :
|
1506
1540
|
* Initialize an object using a pre-allocated fixed-size buffer.
|
@@ -1523,20 +1557,20 @@ ZSTDLIB_API size_t ZSTD_estimateDDictSize(size_t dictSize, ZSTD_dictLoadMethod_e
|
|
1523
1557
|
* Limitation 2 : static cctx currently not compatible with multi-threading.
|
1524
1558
|
* Limitation 3 : static dctx is incompatible with legacy support.
|
1525
1559
|
*/
|
1526
|
-
|
1527
|
-
|
1560
|
+
ZSTDLIB_STATIC_API ZSTD_CCtx* ZSTD_initStaticCCtx(void* workspace, size_t workspaceSize);
|
1561
|
+
ZSTDLIB_STATIC_API ZSTD_CStream* ZSTD_initStaticCStream(void* workspace, size_t workspaceSize); /**< same as ZSTD_initStaticCCtx() */
|
1528
1562
|
|
1529
|
-
|
1530
|
-
|
1563
|
+
ZSTDLIB_STATIC_API ZSTD_DCtx* ZSTD_initStaticDCtx(void* workspace, size_t workspaceSize);
|
1564
|
+
ZSTDLIB_STATIC_API ZSTD_DStream* ZSTD_initStaticDStream(void* workspace, size_t workspaceSize); /**< same as ZSTD_initStaticDCtx() */
|
1531
1565
|
|
1532
|
-
|
1566
|
+
ZSTDLIB_STATIC_API const ZSTD_CDict* ZSTD_initStaticCDict(
|
1533
1567
|
void* workspace, size_t workspaceSize,
|
1534
1568
|
const void* dict, size_t dictSize,
|
1535
1569
|
ZSTD_dictLoadMethod_e dictLoadMethod,
|
1536
1570
|
ZSTD_dictContentType_e dictContentType,
|
1537
1571
|
ZSTD_compressionParameters cParams);
|
1538
1572
|
|
1539
|
-
|
1573
|
+
ZSTDLIB_STATIC_API const ZSTD_DDict* ZSTD_initStaticDDict(
|
1540
1574
|
void* workspace, size_t workspaceSize,
|
1541
1575
|
const void* dict, size_t dictSize,
|
1542
1576
|
ZSTD_dictLoadMethod_e dictLoadMethod,
|
@@ -1557,44 +1591,44 @@ __attribute__((__unused__))
|
|
1557
1591
|
#endif
|
1558
1592
|
ZSTD_customMem const ZSTD_defaultCMem = { NULL, NULL, NULL }; /**< this constant defers to stdlib's functions */
|
1559
1593
|
|
1560
|
-
|
1561
|
-
|
1562
|
-
|
1563
|
-
|
1594
|
+
ZSTDLIB_STATIC_API ZSTD_CCtx* ZSTD_createCCtx_advanced(ZSTD_customMem customMem);
|
1595
|
+
ZSTDLIB_STATIC_API ZSTD_CStream* ZSTD_createCStream_advanced(ZSTD_customMem customMem);
|
1596
|
+
ZSTDLIB_STATIC_API ZSTD_DCtx* ZSTD_createDCtx_advanced(ZSTD_customMem customMem);
|
1597
|
+
ZSTDLIB_STATIC_API ZSTD_DStream* ZSTD_createDStream_advanced(ZSTD_customMem customMem);
|
1564
1598
|
|
1565
|
-
|
1599
|
+
ZSTDLIB_STATIC_API ZSTD_CDict* ZSTD_createCDict_advanced(const void* dict, size_t dictSize,
|
1566
1600
|
ZSTD_dictLoadMethod_e dictLoadMethod,
|
1567
1601
|
ZSTD_dictContentType_e dictContentType,
|
1568
1602
|
ZSTD_compressionParameters cParams,
|
1569
1603
|
ZSTD_customMem customMem);
|
1570
1604
|
|
1571
|
-
|
1572
|
-
*
|
1573
|
-
*
|
1574
|
-
*
|
1575
|
-
*
|
1576
|
-
*
|
1577
|
-
*
|
1578
|
-
*
|
1579
|
-
*
|
1605
|
+
/*! Thread pool :
|
1606
|
+
* These prototypes make it possible to share a thread pool among multiple compression contexts.
|
1607
|
+
* This can limit resources for applications with multiple threads where each one uses
|
1608
|
+
* a threaded compression mode (via ZSTD_c_nbWorkers parameter).
|
1609
|
+
* ZSTD_createThreadPool creates a new thread pool with a given number of threads.
|
1610
|
+
* Note that the lifetime of such pool must exist while being used.
|
1611
|
+
* ZSTD_CCtx_refThreadPool assigns a thread pool to a context (use NULL argument value
|
1612
|
+
* to use an internal thread pool).
|
1613
|
+
* ZSTD_freeThreadPool frees a thread pool, accepts NULL pointer.
|
1580
1614
|
*/
|
1581
1615
|
typedef struct POOL_ctx_s ZSTD_threadPool;
|
1582
|
-
|
1583
|
-
|
1584
|
-
|
1616
|
+
ZSTDLIB_STATIC_API ZSTD_threadPool* ZSTD_createThreadPool(size_t numThreads);
|
1617
|
+
ZSTDLIB_STATIC_API void ZSTD_freeThreadPool (ZSTD_threadPool* pool); /* accept NULL pointer */
|
1618
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtx_refThreadPool(ZSTD_CCtx* cctx, ZSTD_threadPool* pool);
|
1585
1619
|
|
1586
1620
|
|
1587
1621
|
/*
|
1588
1622
|
* This API is temporary and is expected to change or disappear in the future!
|
1589
1623
|
*/
|
1590
|
-
|
1624
|
+
ZSTDLIB_STATIC_API ZSTD_CDict* ZSTD_createCDict_advanced2(
|
1591
1625
|
const void* dict, size_t dictSize,
|
1592
1626
|
ZSTD_dictLoadMethod_e dictLoadMethod,
|
1593
1627
|
ZSTD_dictContentType_e dictContentType,
|
1594
1628
|
const ZSTD_CCtx_params* cctxParams,
|
1595
1629
|
ZSTD_customMem customMem);
|
1596
1630
|
|
1597
|
-
|
1631
|
+
ZSTDLIB_STATIC_API ZSTD_DDict* ZSTD_createDDict_advanced(
|
1598
1632
|
const void* dict, size_t dictSize,
|
1599
1633
|
ZSTD_dictLoadMethod_e dictLoadMethod,
|
1600
1634
|
ZSTD_dictContentType_e dictContentType,
|
@@ -1611,22 +1645,22 @@ ZSTDLIB_API ZSTD_DDict* ZSTD_createDDict_advanced(
|
|
1611
1645
|
* As a consequence, `dictBuffer` **must** outlive CDict,
|
1612
1646
|
* and its content must remain unmodified throughout the lifetime of CDict.
|
1613
1647
|
* note: equivalent to ZSTD_createCDict_advanced(), with dictLoadMethod==ZSTD_dlm_byRef */
|
1614
|
-
|
1648
|
+
ZSTDLIB_STATIC_API ZSTD_CDict* ZSTD_createCDict_byReference(const void* dictBuffer, size_t dictSize, int compressionLevel);
|
1615
1649
|
|
1616
1650
|
/*! ZSTD_getCParams() :
|
1617
1651
|
* @return ZSTD_compressionParameters structure for a selected compression level and estimated srcSize.
|
1618
1652
|
* `estimatedSrcSize` value is optional, select 0 if not known */
|
1619
|
-
|
1653
|
+
ZSTDLIB_STATIC_API ZSTD_compressionParameters ZSTD_getCParams(int compressionLevel, unsigned long long estimatedSrcSize, size_t dictSize);
|
1620
1654
|
|
1621
1655
|
/*! ZSTD_getParams() :
|
1622
1656
|
* same as ZSTD_getCParams(), but @return a full `ZSTD_parameters` object instead of sub-component `ZSTD_compressionParameters`.
|
1623
1657
|
* All fields of `ZSTD_frameParameters` are set to default : contentSize=1, checksum=0, noDictID=0 */
|
1624
|
-
|
1658
|
+
ZSTDLIB_STATIC_API ZSTD_parameters ZSTD_getParams(int compressionLevel, unsigned long long estimatedSrcSize, size_t dictSize);
|
1625
1659
|
|
1626
1660
|
/*! ZSTD_checkCParams() :
|
1627
1661
|
* Ensure param values remain within authorized range.
|
1628
1662
|
* @return 0 on success, or an error code (can be checked with ZSTD_isError()) */
|
1629
|
-
|
1663
|
+
ZSTDLIB_STATIC_API size_t ZSTD_checkCParams(ZSTD_compressionParameters params);
|
1630
1664
|
|
1631
1665
|
/*! ZSTD_adjustCParams() :
|
1632
1666
|
* optimize params for a given `srcSize` and `dictSize`.
|
@@ -1634,7 +1668,7 @@ ZSTDLIB_API size_t ZSTD_checkCParams(ZSTD_compressionParameters params);
|
|
1634
1668
|
* `dictSize` must be `0` when there is no dictionary.
|
1635
1669
|
* cPar can be invalid : all parameters will be clamped within valid range in the @return struct.
|
1636
1670
|
* This function never fails (wide contract) */
|
1637
|
-
|
1671
|
+
ZSTDLIB_STATIC_API ZSTD_compressionParameters ZSTD_adjustCParams(ZSTD_compressionParameters cPar, unsigned long long srcSize, size_t dictSize);
|
1638
1672
|
|
1639
1673
|
/*! ZSTD_compress_advanced() :
|
1640
1674
|
* Note : this function is now DEPRECATED.
|
@@ -1662,18 +1696,18 @@ size_t ZSTD_compress_usingCDict_advanced(ZSTD_CCtx* cctx,
|
|
1662
1696
|
/*! ZSTD_CCtx_loadDictionary_byReference() :
|
1663
1697
|
* Same as ZSTD_CCtx_loadDictionary(), but dictionary content is referenced, instead of being copied into CCtx.
|
1664
1698
|
* It saves some memory, but also requires that `dict` outlives its usage within `cctx` */
|
1665
|
-
|
1699
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtx_loadDictionary_byReference(ZSTD_CCtx* cctx, const void* dict, size_t dictSize);
|
1666
1700
|
|
1667
1701
|
/*! ZSTD_CCtx_loadDictionary_advanced() :
|
1668
1702
|
* Same as ZSTD_CCtx_loadDictionary(), but gives finer control over
|
1669
1703
|
* how to load the dictionary (by copy ? by reference ?)
|
1670
1704
|
* and how to interpret it (automatic ? force raw mode ? full mode only ?) */
|
1671
|
-
|
1705
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtx_loadDictionary_advanced(ZSTD_CCtx* cctx, const void* dict, size_t dictSize, ZSTD_dictLoadMethod_e dictLoadMethod, ZSTD_dictContentType_e dictContentType);
|
1672
1706
|
|
1673
1707
|
/*! ZSTD_CCtx_refPrefix_advanced() :
|
1674
1708
|
* Same as ZSTD_CCtx_refPrefix(), but gives finer control over
|
1675
1709
|
* how to interpret prefix content (automatic ? force raw mode (default) ? full mode only ?) */
|
1676
|
-
|
1710
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtx_refPrefix_advanced(ZSTD_CCtx* cctx, const void* prefix, size_t prefixSize, ZSTD_dictContentType_e dictContentType);
|
1677
1711
|
|
1678
1712
|
/* === experimental parameters === */
|
1679
1713
|
/* these parameters can be used with ZSTD_setParameter()
|
@@ -1712,9 +1746,15 @@ ZSTDLIB_API size_t ZSTD_CCtx_refPrefix_advanced(ZSTD_CCtx* cctx, const void* pre
|
|
1712
1746
|
* See the comments on that enum for an explanation of the feature. */
|
1713
1747
|
#define ZSTD_c_forceAttachDict ZSTD_c_experimentalParam4
|
1714
1748
|
|
1715
|
-
/*
|
1716
|
-
*
|
1717
|
-
*
|
1749
|
+
/* Controlled with ZSTD_paramSwitch_e enum.
|
1750
|
+
* Default is ZSTD_ps_auto.
|
1751
|
+
* Set to ZSTD_ps_disable to never compress literals.
|
1752
|
+
* Set to ZSTD_ps_enable to always compress literals. (Note: uncompressed literals
|
1753
|
+
* may still be emitted if huffman is not beneficial to use.)
|
1754
|
+
*
|
1755
|
+
* By default, in ZSTD_ps_auto, the library will decide at runtime whether to use
|
1756
|
+
* literals compression based on the compression parameters - specifically,
|
1757
|
+
* negative compression levels do not use literal compression.
|
1718
1758
|
*/
|
1719
1759
|
#define ZSTD_c_literalCompressionMode ZSTD_c_experimentalParam5
|
1720
1760
|
|
@@ -1777,7 +1817,7 @@ ZSTDLIB_API size_t ZSTD_CCtx_refPrefix_advanced(ZSTD_CCtx* cctx, const void* pre
|
|
1777
1817
|
*
|
1778
1818
|
* Note that this means that the CDict tables can no longer be copied into the
|
1779
1819
|
* CCtx, so the dict attachment mode ZSTD_dictForceCopy will no longer be
|
1780
|
-
*
|
1820
|
+
* usable. The dictionary can only be attached or reloaded.
|
1781
1821
|
*
|
1782
1822
|
* In general, you should expect compression to be faster--sometimes very much
|
1783
1823
|
* so--and CDict creation to be slightly slower. Eventually, we will probably
|
@@ -1866,23 +1906,26 @@ ZSTDLIB_API size_t ZSTD_CCtx_refPrefix_advanced(ZSTD_CCtx* cctx, const void* pre
|
|
1866
1906
|
*/
|
1867
1907
|
#define ZSTD_c_validateSequences ZSTD_c_experimentalParam12
|
1868
1908
|
|
1869
|
-
/*
|
1870
|
-
*
|
1909
|
+
/* ZSTD_c_useBlockSplitter
|
1910
|
+
* Controlled with ZSTD_paramSwitch_e enum.
|
1911
|
+
* Default is ZSTD_ps_auto.
|
1912
|
+
* Set to ZSTD_ps_disable to never use block splitter.
|
1913
|
+
* Set to ZSTD_ps_enable to always use block splitter.
|
1871
1914
|
*
|
1872
|
-
*
|
1915
|
+
* By default, in ZSTD_ps_auto, the library will decide at runtime whether to use
|
1916
|
+
* block splitting based on the compression parameters.
|
1873
1917
|
*/
|
1874
|
-
#define
|
1918
|
+
#define ZSTD_c_useBlockSplitter ZSTD_c_experimentalParam13
|
1875
1919
|
|
1876
1920
|
/* ZSTD_c_useRowMatchFinder
|
1877
|
-
*
|
1878
|
-
*
|
1921
|
+
* Controlled with ZSTD_paramSwitch_e enum.
|
1922
|
+
* Default is ZSTD_ps_auto.
|
1923
|
+
* Set to ZSTD_ps_disable to never use row-based matchfinder.
|
1924
|
+
* Set to ZSTD_ps_enable to force usage of row-based matchfinder.
|
1879
1925
|
*
|
1880
|
-
* By default, in
|
1881
|
-
*
|
1882
|
-
*
|
1883
|
-
*
|
1884
|
-
* Set to ZSTD_urm_disableRowMatchFinder to never use row-based matchfinder.
|
1885
|
-
* Set to ZSTD_urm_enableRowMatchFinder to force usage of row-based matchfinder.
|
1926
|
+
* By default, in ZSTD_ps_auto, the library will decide at runtime whether to use
|
1927
|
+
* the row-based matchfinder based on support for SIMD instructions and the window log.
|
1928
|
+
* Note that this only pertains to compression strategies: greedy, lazy, and lazy2
|
1886
1929
|
*/
|
1887
1930
|
#define ZSTD_c_useRowMatchFinder ZSTD_c_experimentalParam14
|
1888
1931
|
|
@@ -1911,7 +1954,7 @@ ZSTDLIB_API size_t ZSTD_CCtx_refPrefix_advanced(ZSTD_CCtx* cctx, const void* pre
|
|
1911
1954
|
* and store it into int* value.
|
1912
1955
|
* @return : 0, or an error code (which can be tested with ZSTD_isError()).
|
1913
1956
|
*/
|
1914
|
-
|
1957
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtx_getParameter(const ZSTD_CCtx* cctx, ZSTD_cParameter param, int* value);
|
1915
1958
|
|
1916
1959
|
|
1917
1960
|
/*! ZSTD_CCtx_params :
|
@@ -1931,25 +1974,25 @@ ZSTDLIB_API size_t ZSTD_CCtx_getParameter(const ZSTD_CCtx* cctx, ZSTD_cParameter
|
|
1931
1974
|
* This can be used with ZSTD_estimateCCtxSize_advanced_usingCCtxParams()
|
1932
1975
|
* for static allocation of CCtx for single-threaded compression.
|
1933
1976
|
*/
|
1934
|
-
|
1935
|
-
|
1977
|
+
ZSTDLIB_STATIC_API ZSTD_CCtx_params* ZSTD_createCCtxParams(void);
|
1978
|
+
ZSTDLIB_STATIC_API size_t ZSTD_freeCCtxParams(ZSTD_CCtx_params* params); /* accept NULL pointer */
|
1936
1979
|
|
1937
1980
|
/*! ZSTD_CCtxParams_reset() :
|
1938
1981
|
* Reset params to default values.
|
1939
1982
|
*/
|
1940
|
-
|
1983
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtxParams_reset(ZSTD_CCtx_params* params);
|
1941
1984
|
|
1942
1985
|
/*! ZSTD_CCtxParams_init() :
|
1943
1986
|
* Initializes the compression parameters of cctxParams according to
|
1944
1987
|
* compression level. All other parameters are reset to their default values.
|
1945
1988
|
*/
|
1946
|
-
|
1989
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtxParams_init(ZSTD_CCtx_params* cctxParams, int compressionLevel);
|
1947
1990
|
|
1948
1991
|
/*! ZSTD_CCtxParams_init_advanced() :
|
1949
1992
|
* Initializes the compression and frame parameters of cctxParams according to
|
1950
1993
|
* params. All other parameters are reset to their default values.
|
1951
1994
|
*/
|
1952
|
-
|
1995
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtxParams_init_advanced(ZSTD_CCtx_params* cctxParams, ZSTD_parameters params);
|
1953
1996
|
|
1954
1997
|
/*! ZSTD_CCtxParams_setParameter() : Requires v1.4.0+
|
1955
1998
|
* Similar to ZSTD_CCtx_setParameter.
|
@@ -1959,14 +2002,14 @@ ZSTDLIB_API size_t ZSTD_CCtxParams_init_advanced(ZSTD_CCtx_params* cctxParams, Z
|
|
1959
2002
|
* @result : a code representing success or failure (which can be tested with
|
1960
2003
|
* ZSTD_isError()).
|
1961
2004
|
*/
|
1962
|
-
|
2005
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtxParams_setParameter(ZSTD_CCtx_params* params, ZSTD_cParameter param, int value);
|
1963
2006
|
|
1964
2007
|
/*! ZSTD_CCtxParams_getParameter() :
|
1965
2008
|
* Similar to ZSTD_CCtx_getParameter.
|
1966
2009
|
* Get the requested value of one compression parameter, selected by enum ZSTD_cParameter.
|
1967
2010
|
* @result : 0, or an error code (which can be tested with ZSTD_isError()).
|
1968
2011
|
*/
|
1969
|
-
|
2012
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtxParams_getParameter(const ZSTD_CCtx_params* params, ZSTD_cParameter param, int* value);
|
1970
2013
|
|
1971
2014
|
/*! ZSTD_CCtx_setParametersUsingCCtxParams() :
|
1972
2015
|
* Apply a set of ZSTD_CCtx_params to the compression context.
|
@@ -1975,7 +2018,7 @@ ZSTDLIB_API size_t ZSTD_CCtxParams_getParameter(const ZSTD_CCtx_params* params,
|
|
1975
2018
|
* if nbWorkers>=1, new parameters will be picked up at next job,
|
1976
2019
|
* with a few restrictions (windowLog, pledgedSrcSize, nbWorkers, jobSize, and overlapLog are not updated).
|
1977
2020
|
*/
|
1978
|
-
|
2021
|
+
ZSTDLIB_STATIC_API size_t ZSTD_CCtx_setParametersUsingCCtxParams(
|
1979
2022
|
ZSTD_CCtx* cctx, const ZSTD_CCtx_params* params);
|
1980
2023
|
|
1981
2024
|
/*! ZSTD_compressStream2_simpleArgs() :
|
@@ -1984,7 +2027,7 @@ ZSTDLIB_API size_t ZSTD_CCtx_setParametersUsingCCtxParams(
|
|
1984
2027
|
* This variant might be helpful for binders from dynamic languages
|
1985
2028
|
* which have troubles handling structures containing memory pointers.
|
1986
2029
|
*/
|
1987
|
-
|
2030
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressStream2_simpleArgs (
|
1988
2031
|
ZSTD_CCtx* cctx,
|
1989
2032
|
void* dst, size_t dstCapacity, size_t* dstPos,
|
1990
2033
|
const void* src, size_t srcSize, size_t* srcPos,
|
@@ -2000,33 +2043,33 @@ ZSTDLIB_API size_t ZSTD_compressStream2_simpleArgs (
|
|
2000
2043
|
* Note : Frame Identifier is 4 bytes. If `size < 4`, @return will always be 0.
|
2001
2044
|
* Note 2 : Legacy Frame Identifiers are considered valid only if Legacy Support is enabled.
|
2002
2045
|
* Note 3 : Skippable Frame Identifiers are considered valid. */
|
2003
|
-
|
2046
|
+
ZSTDLIB_STATIC_API unsigned ZSTD_isFrame(const void* buffer, size_t size);
|
2004
2047
|
|
2005
2048
|
/*! ZSTD_createDDict_byReference() :
|
2006
2049
|
* Create a digested dictionary, ready to start decompression operation without startup delay.
|
2007
2050
|
* Dictionary content is referenced, and therefore stays in dictBuffer.
|
2008
2051
|
* It is important that dictBuffer outlives DDict,
|
2009
2052
|
* it must remain read accessible throughout the lifetime of DDict */
|
2010
|
-
|
2053
|
+
ZSTDLIB_STATIC_API ZSTD_DDict* ZSTD_createDDict_byReference(const void* dictBuffer, size_t dictSize);
|
2011
2054
|
|
2012
2055
|
/*! ZSTD_DCtx_loadDictionary_byReference() :
|
2013
2056
|
* Same as ZSTD_DCtx_loadDictionary(),
|
2014
2057
|
* but references `dict` content instead of copying it into `dctx`.
|
2015
2058
|
* This saves memory if `dict` remains around.,
|
2016
2059
|
* However, it's imperative that `dict` remains accessible (and unmodified) while being used, so it must outlive decompression. */
|
2017
|
-
|
2060
|
+
ZSTDLIB_STATIC_API size_t ZSTD_DCtx_loadDictionary_byReference(ZSTD_DCtx* dctx, const void* dict, size_t dictSize);
|
2018
2061
|
|
2019
2062
|
/*! ZSTD_DCtx_loadDictionary_advanced() :
|
2020
2063
|
* Same as ZSTD_DCtx_loadDictionary(),
|
2021
2064
|
* but gives direct control over
|
2022
2065
|
* how to load the dictionary (by copy ? by reference ?)
|
2023
2066
|
* and how to interpret it (automatic ? force raw mode ? full mode only ?). */
|
2024
|
-
|
2067
|
+
ZSTDLIB_STATIC_API size_t ZSTD_DCtx_loadDictionary_advanced(ZSTD_DCtx* dctx, const void* dict, size_t dictSize, ZSTD_dictLoadMethod_e dictLoadMethod, ZSTD_dictContentType_e dictContentType);
|
2025
2068
|
|
2026
2069
|
/*! ZSTD_DCtx_refPrefix_advanced() :
|
2027
2070
|
* Same as ZSTD_DCtx_refPrefix(), but gives finer control over
|
2028
2071
|
* how to interpret prefix content (automatic ? force raw mode (default) ? full mode only ?) */
|
2029
|
-
|
2072
|
+
ZSTDLIB_STATIC_API size_t ZSTD_DCtx_refPrefix_advanced(ZSTD_DCtx* dctx, const void* prefix, size_t prefixSize, ZSTD_dictContentType_e dictContentType);
|
2030
2073
|
|
2031
2074
|
/*! ZSTD_DCtx_setMaxWindowSize() :
|
2032
2075
|
* Refuses allocating internal buffers for frames requiring a window size larger than provided limit.
|
@@ -2035,14 +2078,14 @@ ZSTDLIB_API size_t ZSTD_DCtx_refPrefix_advanced(ZSTD_DCtx* dctx, const void* pre
|
|
2035
2078
|
* By default, a decompression context accepts all window sizes <= (1 << ZSTD_WINDOWLOG_LIMIT_DEFAULT)
|
2036
2079
|
* @return : 0, or an error code (which can be tested using ZSTD_isError()).
|
2037
2080
|
*/
|
2038
|
-
|
2081
|
+
ZSTDLIB_STATIC_API size_t ZSTD_DCtx_setMaxWindowSize(ZSTD_DCtx* dctx, size_t maxWindowSize);
|
2039
2082
|
|
2040
2083
|
/*! ZSTD_DCtx_getParameter() :
|
2041
2084
|
* Get the requested decompression parameter value, selected by enum ZSTD_dParameter,
|
2042
2085
|
* and store it into int* value.
|
2043
2086
|
* @return : 0, or an error code (which can be tested with ZSTD_isError()).
|
2044
2087
|
*/
|
2045
|
-
|
2088
|
+
ZSTDLIB_STATIC_API size_t ZSTD_DCtx_getParameter(ZSTD_DCtx* dctx, ZSTD_dParameter param, int* value);
|
2046
2089
|
|
2047
2090
|
/* ZSTD_d_format
|
2048
2091
|
* experimental parameter,
|
@@ -2131,7 +2174,7 @@ size_t ZSTD_DCtx_setFormat(ZSTD_DCtx* dctx, ZSTD_format_e format);
|
|
2131
2174
|
* This can be helpful for binders from dynamic languages
|
2132
2175
|
* which have troubles handling structures containing memory pointers.
|
2133
2176
|
*/
|
2134
|
-
|
2177
|
+
ZSTDLIB_STATIC_API size_t ZSTD_decompressStream_simpleArgs (
|
2135
2178
|
ZSTD_DCtx* dctx,
|
2136
2179
|
void* dst, size_t dstCapacity, size_t* dstPos,
|
2137
2180
|
const void* src, size_t srcSize, size_t* srcPos);
|
@@ -2205,7 +2248,7 @@ size_t ZSTD_initCStream_advanced(ZSTD_CStream* zcs,
|
|
2205
2248
|
* This function is DEPRECATED, and equivalent to:
|
2206
2249
|
* ZSTD_CCtx_reset(zcs, ZSTD_reset_session_only);
|
2207
2250
|
* ZSTD_CCtx_refCDict(zcs, cdict);
|
2208
|
-
*
|
2251
|
+
*
|
2209
2252
|
* note : cdict will just be referenced, and must outlive compression session
|
2210
2253
|
* This prototype will generate compilation warnings.
|
2211
2254
|
*/
|
@@ -2270,7 +2313,7 @@ typedef struct {
|
|
2270
2313
|
* Note : (ingested - consumed) is amount of input data buffered internally, not yet compressed.
|
2271
2314
|
* Aggregates progression inside active worker threads.
|
2272
2315
|
*/
|
2273
|
-
|
2316
|
+
ZSTDLIB_STATIC_API ZSTD_frameProgression ZSTD_getFrameProgression(const ZSTD_CCtx* cctx);
|
2274
2317
|
|
2275
2318
|
/*! ZSTD_toFlushNow() :
|
2276
2319
|
* Tell how many bytes are ready to be flushed immediately.
|
@@ -2285,7 +2328,7 @@ ZSTDLIB_API ZSTD_frameProgression ZSTD_getFrameProgression(const ZSTD_CCtx* cctx
|
|
2285
2328
|
* therefore flush speed is limited by production speed of oldest job
|
2286
2329
|
* irrespective of the speed of concurrent (and newer) jobs.
|
2287
2330
|
*/
|
2288
|
-
|
2331
|
+
ZSTDLIB_STATIC_API size_t ZSTD_toFlushNow(ZSTD_CCtx* cctx);
|
2289
2332
|
|
2290
2333
|
|
2291
2334
|
/*===== Advanced Streaming decompression functions =====*/
|
@@ -2299,7 +2342,7 @@ ZSTDLIB_API size_t ZSTD_toFlushNow(ZSTD_CCtx* cctx);
|
|
2299
2342
|
* note: no dictionary will be used if dict == NULL or dictSize < 8
|
2300
2343
|
* Note : this prototype will be marked as deprecated and generate compilation warnings on reaching v1.5.x
|
2301
2344
|
*/
|
2302
|
-
|
2345
|
+
ZSTDLIB_STATIC_API size_t ZSTD_initDStream_usingDict(ZSTD_DStream* zds, const void* dict, size_t dictSize);
|
2303
2346
|
|
2304
2347
|
/*!
|
2305
2348
|
* This function is deprecated, and is equivalent to:
|
@@ -2310,7 +2353,7 @@ ZSTDLIB_API size_t ZSTD_initDStream_usingDict(ZSTD_DStream* zds, const void* dic
|
|
2310
2353
|
* note : ddict is referenced, it must outlive decompression session
|
2311
2354
|
* Note : this prototype will be marked as deprecated and generate compilation warnings on reaching v1.5.x
|
2312
2355
|
*/
|
2313
|
-
|
2356
|
+
ZSTDLIB_STATIC_API size_t ZSTD_initDStream_usingDDict(ZSTD_DStream* zds, const ZSTD_DDict* ddict);
|
2314
2357
|
|
2315
2358
|
/*!
|
2316
2359
|
* This function is deprecated, and is equivalent to:
|
@@ -2320,7 +2363,7 @@ ZSTDLIB_API size_t ZSTD_initDStream_usingDDict(ZSTD_DStream* zds, const ZSTD_DDi
|
|
2320
2363
|
* re-use decompression parameters from previous init; saves dictionary loading
|
2321
2364
|
* Note : this prototype will be marked as deprecated and generate compilation warnings on reaching v1.5.x
|
2322
2365
|
*/
|
2323
|
-
|
2366
|
+
ZSTDLIB_STATIC_API size_t ZSTD_resetDStream(ZSTD_DStream* zds);
|
2324
2367
|
|
2325
2368
|
|
2326
2369
|
/*********************************************************************
|
@@ -2362,13 +2405,13 @@ ZSTDLIB_API size_t ZSTD_resetDStream(ZSTD_DStream* zds);
|
|
2362
2405
|
*/
|
2363
2406
|
|
2364
2407
|
/*===== Buffer-less streaming compression functions =====*/
|
2365
|
-
|
2366
|
-
|
2367
|
-
|
2368
|
-
|
2408
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressBegin(ZSTD_CCtx* cctx, int compressionLevel);
|
2409
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressBegin_usingDict(ZSTD_CCtx* cctx, const void* dict, size_t dictSize, int compressionLevel);
|
2410
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressBegin_usingCDict(ZSTD_CCtx* cctx, const ZSTD_CDict* cdict); /**< note: fails if cdict==NULL */
|
2411
|
+
ZSTDLIB_STATIC_API size_t ZSTD_copyCCtx(ZSTD_CCtx* cctx, const ZSTD_CCtx* preparedCCtx, unsigned long long pledgedSrcSize); /**< note: if pledgedSrcSize is not known, use ZSTD_CONTENTSIZE_UNKNOWN */
|
2369
2412
|
|
2370
|
-
|
2371
|
-
|
2413
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressContinue(ZSTD_CCtx* cctx, void* dst, size_t dstCapacity, const void* src, size_t srcSize);
|
2414
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressEnd(ZSTD_CCtx* cctx, void* dst, size_t dstCapacity, const void* src, size_t srcSize);
|
2372
2415
|
|
2373
2416
|
/* The ZSTD_compressBegin_advanced() and ZSTD_compressBegin_usingCDict_advanced() are now DEPRECATED and will generate a compiler warning */
|
2374
2417
|
ZSTD_DEPRECATED("use advanced API to access custom parameters")
|
@@ -2465,24 +2508,24 @@ typedef struct {
|
|
2465
2508
|
* @return : 0, `zfhPtr` is correctly filled,
|
2466
2509
|
* >0, `srcSize` is too small, value is wanted `srcSize` amount,
|
2467
2510
|
* or an error code, which can be tested using ZSTD_isError() */
|
2468
|
-
|
2511
|
+
ZSTDLIB_STATIC_API size_t ZSTD_getFrameHeader(ZSTD_frameHeader* zfhPtr, const void* src, size_t srcSize); /**< doesn't consume input */
|
2469
2512
|
/*! ZSTD_getFrameHeader_advanced() :
|
2470
2513
|
* same as ZSTD_getFrameHeader(),
|
2471
2514
|
* with added capability to select a format (like ZSTD_f_zstd1_magicless) */
|
2472
|
-
|
2473
|
-
|
2515
|
+
ZSTDLIB_STATIC_API size_t ZSTD_getFrameHeader_advanced(ZSTD_frameHeader* zfhPtr, const void* src, size_t srcSize, ZSTD_format_e format);
|
2516
|
+
ZSTDLIB_STATIC_API size_t ZSTD_decodingBufferSize_min(unsigned long long windowSize, unsigned long long frameContentSize); /**< when frame content size is not known, pass in frameContentSize == ZSTD_CONTENTSIZE_UNKNOWN */
|
2474
2517
|
|
2475
|
-
|
2476
|
-
|
2477
|
-
|
2518
|
+
ZSTDLIB_STATIC_API size_t ZSTD_decompressBegin(ZSTD_DCtx* dctx);
|
2519
|
+
ZSTDLIB_STATIC_API size_t ZSTD_decompressBegin_usingDict(ZSTD_DCtx* dctx, const void* dict, size_t dictSize);
|
2520
|
+
ZSTDLIB_STATIC_API size_t ZSTD_decompressBegin_usingDDict(ZSTD_DCtx* dctx, const ZSTD_DDict* ddict);
|
2478
2521
|
|
2479
|
-
|
2480
|
-
|
2522
|
+
ZSTDLIB_STATIC_API size_t ZSTD_nextSrcSizeToDecompress(ZSTD_DCtx* dctx);
|
2523
|
+
ZSTDLIB_STATIC_API size_t ZSTD_decompressContinue(ZSTD_DCtx* dctx, void* dst, size_t dstCapacity, const void* src, size_t srcSize);
|
2481
2524
|
|
2482
2525
|
/* misc */
|
2483
|
-
|
2526
|
+
ZSTDLIB_STATIC_API void ZSTD_copyDCtx(ZSTD_DCtx* dctx, const ZSTD_DCtx* preparedDCtx);
|
2484
2527
|
typedef enum { ZSTDnit_frameHeader, ZSTDnit_blockHeader, ZSTDnit_block, ZSTDnit_lastBlock, ZSTDnit_checksum, ZSTDnit_skippableFrame } ZSTD_nextInputType_e;
|
2485
|
-
|
2528
|
+
ZSTDLIB_STATIC_API ZSTD_nextInputType_e ZSTD_nextInputType(ZSTD_DCtx* dctx);
|
2486
2529
|
|
2487
2530
|
|
2488
2531
|
|
@@ -2519,10 +2562,10 @@ ZSTDLIB_API ZSTD_nextInputType_e ZSTD_nextInputType(ZSTD_DCtx* dctx);
|
|
2519
2562
|
*/
|
2520
2563
|
|
2521
2564
|
/*===== Raw zstd block functions =====*/
|
2522
|
-
|
2523
|
-
|
2524
|
-
|
2525
|
-
|
2565
|
+
ZSTDLIB_STATIC_API size_t ZSTD_getBlockSize (const ZSTD_CCtx* cctx);
|
2566
|
+
ZSTDLIB_STATIC_API size_t ZSTD_compressBlock (ZSTD_CCtx* cctx, void* dst, size_t dstCapacity, const void* src, size_t srcSize);
|
2567
|
+
ZSTDLIB_STATIC_API size_t ZSTD_decompressBlock(ZSTD_DCtx* dctx, void* dst, size_t dstCapacity, const void* src, size_t srcSize);
|
2568
|
+
ZSTDLIB_STATIC_API size_t ZSTD_insertBlock (ZSTD_DCtx* dctx, const void* blockStart, size_t blockSize); /**< insert uncompressed block into `dctx` history. Useful for multi-blocks decompression. */
|
2526
2569
|
|
2527
2570
|
|
2528
2571
|
#endif /* ZSTD_H_ZSTD_STATIC_LINKING_ONLY */
|