org.lwjgl.util.zstd.Zstd Maven / Gradle / Ivy
Show all versions of lwjgl-zstd Show documentation
/*
* Copyright LWJGL. All rights reserved.
* License terms: https://www.lwjgl.org/license
* MACHINE GENERATED FILE, DO NOT EDIT
*/
package org.lwjgl.util.zstd;
import javax.annotation.*;
import java.nio.*;
import org.lwjgl.system.*;
import static org.lwjgl.system.Checks.*;
import static org.lwjgl.system.MemoryUtil.*;
/**
* Native bindings to Zstandard (zstd), a fast lossless compression algorithm, targeting real-time
* compression scenarios at zlib-level and better compression ratios.
*
* Introduction
*
* zstd, short for Zstandard, is a fast lossless compression algorithm, targeting real-time compression scenarios at zlib-level and better compression
* ratios. The zstd compression library provides in-memory compression and decompression functions.
*
* The library supports regular compression levels from 1 up to {@link #ZSTD_maxCLevel maxCLevel}, which is currently 22. Levels ≥ 20, labeled {@code --ultra}, should be
* used with caution, as they require more memory. The library also offers negative compression levels, which extend the range of speed vs. ratio
* preferences. The lower the level, the faster the speed (at the cost of compression).
*
* Compression can be done in:
*
*
* - a single step (described as Simple API)
* - a single step, reusing a context (described as Explicit context)
* - unbounded multiple steps (described as Streaming compression)
*
*
* The compression ratio achievable on small data can be highly improved using a dictionary. Dictionary compression can be performed in:
*
*
* - a single step (described as Simple dictionary API)
* - a single step, reusing a dictionary (described as Bulk-processing dictionary API)
*
*
* Advanced experimental functions can be accessed using {@code #define ZSTD_STATIC_LINKING_ONLY} before including {@code zstd.h}. Advanced experimental
* APIs should never be used with a dynamically-linked library. They are not "stable", their definitions or signatures may change in the future. Only
* static linking is allowed.
*
* Streaming compression - HowTo
*
* A {@code ZSTD_CStream} object is required to track streaming operation.
*
* Use {@link #ZSTD_createCStream createCStream} and {@link #ZSTD_freeCStream freeCStream} to create/release resources. {@code ZSTD_CStream} objects can be reused multiple times on consecutive
* compression operations. It is recommended to re-use {@code ZSTD_CStream} since it will play nicer with system's memory, by re-using already allocated
* memory.
*
* For parallel execution, use one separate {@code ZSTD_CStream}.
*
* Since v1.3.0, {@code ZSTD_CStream} and {@code ZSTD_CCtx} are the same thing.
*
* Parameters are sticky: when starting a new compression on the same context, it will re-use the same sticky parameters as previous compression session.
* When in doubt, it's recommended to fully initialize the context before usage. Use {@link #ZSTD_CCtx_reset CCtx_reset} to reset the context and {@link #ZSTD_CCtx_setParameter CCtx_setParameter},
* {@link #ZSTD_CCtx_setPledgedSrcSize CCtx_setPledgedSrcSize}, or {@link #ZSTD_CCtx_loadDictionary CCtx_loadDictionary} and friends to set more specific parameters, the pledged source size, or load a dictionary.
*
* Use {@link #ZSTD_compressStream2 compressStream2} with {@link #ZSTD_e_continue e_continue} as many times as necessary to consume input stream. The function will automatically update both {@code pos}
* fields within {@code input} and {@code output}. Note that the function may not consume the entire input, for example, because the output buffer is
* already full, in which case {@code input.pos < input.size}. The caller must check if input has been entirely consumed. If not, the caller must make
* some room to receive more compressed data, and then present again remaining input data.
*
* Note: {@code ZSTD_e_continue} is guaranteed to make some forward progress when called, but doesn't guarantee maximal forward progress. This is
* especially relevant when compressing with multiple threads. The call won't block if it can consume some input, but if it can't it will wait for some,
* but not all, output to be flushed.
*
* At any moment, it's possible to flush whatever data might remain stuck within internal buffer, using {@code ZSTD_compressStream2()} with {@link #ZSTD_e_flush e_flush}.
* {@code output->pos} will be updated. Note that, if {@code output->size} is too small, a single invocation with {@code ZSTD_e_flush} might not be enough
* (return code > 0). In which case, make some room to receive more compressed data, and call again {@code ZSTD_compressStream2()} with
* {@code ZSTD_e_flush}. You must continue calling {@code ZSTD_compressStream2()} with {@code ZSTD_e_flush} until it returns 0, at which point you can
* change the operation.
*
* Note: {@code ZSTD_e_flush} will flush as much output as possible, meaning when compressing with multiple threads, it will block until the flush is
* complete or the output buffer is full.
*
* Calling {@code ZSTD_compressStream2()} with {@link #ZSTD_e_end e_end} instructs to finish a frame. It will perform a flush and write frame epilogue. The epilogue is
* required for decoders to consider a frame completed. Flush operation is the same, and follows same rules as calling {@code ZSTD_compressStream2()} with
* {@code ZSTD_e_flush}. You must continue calling {@code ZSTD_compressStream2()} with {@code ZSTD_e_end} until it returns 0, at which point you are free
* to start a new frame.
*
* Note: {@code ZSTD_e_end} will flush as much output as possible, meaning when compressing with multiple threads, it will block until the flush is
* complete or the output buffer is full.
*
* Streaming decompression - HowTo
*
* A {@code ZSTD_DStream} object is required to track streaming operations.
*
* Use {@link #ZSTD_createDStream createDStream} and {@link #ZSTD_freeDStream freeDStream} to create/release resources. {@code ZSTD_DStream} objects can be re-used multiple times.
*
* Use {@link #ZSTD_DCtx_reset DCtx_reset} and {@link #ZSTD_DCtx_refDDict DCtx_refDDict} to start a new decompression operation. Alternatively, use advanced API to set specific properties.
*
* Use {@link #ZSTD_decompressStream decompressStream} repetitively to consume your input. The function will update both {@code pos} fields. If {@code input.pos < input.size}, some
* input has not been consumed. It's up to the caller to present again remaining data. The function tries to flush all data decoded immediately,
* respecting output buffer size. If {@code output.pos < output.size}, decoder has flushed everything it could. But if {@code output.pos == output.size},
* there might be some data left within internal buffers. In which case, call {@code ZSTD_decompressStream()} again to flush whatever remains in the
* buffer.
*
* Note: with no additional input provided, amount of data flushed is necessarily ≤ {@link #ZSTD_BLOCKSIZE_MAX BLOCKSIZE_MAX}.
*/
public class Zstd {
/** Version number part. */
public static final int
ZSTD_VERSION_MAJOR = 1,
ZSTD_VERSION_MINOR = 4,
ZSTD_VERSION_RELEASE = 0;
/** Version number. */
public static final int ZSTD_VERSION_NUMBER = (ZSTD_VERSION_MAJOR *100*100 + ZSTD_VERSION_MINOR *100 + ZSTD_VERSION_RELEASE);
/** Version string. */
public static final String ZSTD_VERSION_STRING = ZSTD_VERSION_MAJOR + "." + ZSTD_VERSION_MINOR + "." + ZSTD_VERSION_RELEASE;
/** Default compression level. */
public static final int ZSTD_CLEVEL_DEFAULT = 3;
public static final int ZSTD_MAGICNUMBER = 0xFD2FB528;
public static final int ZSTD_MAGIC_DICTIONARY = 0xEC30A437;
public static final int ZSTD_MAGIC_SKIPPABLE_START = 0x184D2A50;
public static final int ZSTD_MAGIC_SKIPPABLE_MASK = 0xFFFFFFF0;
public static final int ZSTD_BLOCKSIZELOG_MAX = 17;
public static final int ZSTD_BLOCKSIZE_MAX = (1<Enum values:
*
*
* - {@link #ZSTD_fast fast}
* - {@link #ZSTD_dfast dfast}
* - {@link #ZSTD_greedy greedy}
* - {@link #ZSTD_lazy lazy}
* - {@link #ZSTD_lazy2 lazy2}
* - {@link #ZSTD_btlazy2 btlazy2}
* - {@link #ZSTD_btopt btopt}
* - {@link #ZSTD_btultra btultra}
* - {@link #ZSTD_btultra2 btultra2}
*
*/
public static final int
ZSTD_fast = 1,
ZSTD_dfast = 2,
ZSTD_greedy = 3,
ZSTD_lazy = 4,
ZSTD_lazy2 = 5,
ZSTD_btlazy2 = 6,
ZSTD_btopt = 7,
ZSTD_btultra = 8,
ZSTD_btultra2 = 9;
/**
* Compression parameters. ({@code ZSTD_cParameter})
*
* Note: When compressing with a {@code ZSTD_CDict} these parameters are superseded by the parameters used to construct the {@code ZSTD_CDict}. See
* {@link #ZSTD_CCtx_refCDict CCtx_refCDict} for more info.
*
* Enum values:
*
*
* - {@link #ZSTD_c_compressionLevel c_compressionLevel} -
* Update all compression parameters according to pre-defined cLevel table Default level is {@link #ZSTD_CLEVEL_DEFAULT CLEVEL_DEFAULT}{@code ==3}. Special: value 0 means
* default, which is controlled by {@code ZSTD_CLEVEL_DEFAULT}.
*
*
Note 1: it's possible to pass a negative compression level.
*
* Note 2 : setting a level sets all default values of other compression parameters
*
* - {@link #ZSTD_c_windowLog c_windowLog} -
* Maximum allowed back-reference distance, expressed as power of 2. Must be clamped between {@link ZstdX#ZSTD_WINDOWLOG_MIN WINDOWLOG_MIN} and {@link ZstdX#ZSTD_WINDOWLOG_MAX WINDOWLOG_MAX}. Special: value
* 0 means "use default {@code windowLog}".
*
*
Note: Using a {@code windowLog} greater than {@link ZstdX#ZSTD_WINDOWLOG_LIMIT_DEFAULT WINDOWLOG_LIMIT_DEFAULT} requires explicitly allowing such window size at decompression stage if using
* streaming.
*
* - {@link #ZSTD_c_hashLog c_hashLog} -
* Size of the initial probe table, as a power of 2. Resulting memory usage is (1 << {@code (hashLog+2)}). Must be clamped between {@link ZstdX#ZSTD_HASHLOG_MIN HASHLOG_MIN} and
* HASHLOG_MAX. Larger tables improve compression ratio of strategies ≤ dFast, and improve speed of strategies > dFast. Special: value 0
* means "use default {@code hashLog}".
*
* - {@link #ZSTD_c_chainLog c_chainLog} -
* Size of the multi-probe search table, as a power of 2. Resulting memory usage is (1 << {@code (chainLog+2)}). Must be clamped between
* {@link ZstdX#ZSTD_CHAINLOG_MIN CHAINLOG_MIN} and {@link ZstdX#ZSTD_CHAINLOG_MAX CHAINLOG_MAX}. Larger tables result in better and slower compression. This parameter is useless when using "fast"
* strategy. It's still useful when using "dfast" strategy, in which case it defines a secondary probe table. Special: value 0 means "use default
* {@code chainLog}".
*
* - {@link #ZSTD_c_searchLog c_searchLog} -
* Number of search attempts, as a power of 2. More attempts result in better and slower compression. This parameter is useless when using "fast" and
* "dFast" strategies. Special: value 0 means "use default {@code searchLog}".
*
* - {@link #ZSTD_c_minMatch c_minMatch} -
* Minimum size of searched matches. Note that Zstandard can still find matches of smaller size, it just tweaks its search algorithm to look for this
* size and larger. Larger values increase compression and decompression speed, but decrease ratio. Must be clamped between {@link ZstdX#ZSTD_MINMATCH_MIN MINMATCH_MIN} and
* {@link ZstdX#ZSTD_MINMATCH_MAX MINMATCH_MAX}. Note that currently, for all strategies <btopt, effective minimum is 4. , for all strategies > fast, effective maximum is 6.
* Special: value 0 means "use default {@code minMatchLength}".
*
* - {@link #ZSTD_c_targetLength c_targetLength} -
* Impact of this field depends on strategy. For strategies btopt, btultra & btultra2: Length of Match considered "good enough" to stop search.
* Larger values make compression stronger, and slower. For strategy fast: Distance between match sampling. Larger values make compression faster, and
* weaker. Special: value 0 means "use default targetLength".
*
* - {@link #ZSTD_c_strategy c_strategy} -
* See {@code ZSTD_strategy} enum definition. The higher the value of selected strategy, the more complex it is, resulting in stronger and slower
* compression. Special: value 0 means "use default strategy".
*
* - {@link #ZSTD_c_enableLongDistanceMatching c_enableLongDistanceMatching} -
* Enable long distance matching. This parameter is designed to improve compression ratio for large inputs, by finding large matches at long distance.
* It increases memory usage and window size. Note: enabling this parameter increases default {@link #ZSTD_c_windowLog c_windowLog} to 128 MB except when expressly set to a
* different value.
*
* - {@link #ZSTD_c_ldmHashLog c_ldmHashLog} -
* Size of the table for long distance matching, as a power of 2. Larger values increase memory usage and compression ratio, but decrease compression
* speed. Must be clamped between {@link ZstdX#ZSTD_HASHLOG_MIN HASHLOG_MIN} and {@link ZstdX#ZSTD_HASHLOG_MAX HASHLOG_MAX} default: windowlog - 7. Special: value 0 means "automatically determine hashlog".
*
* - {@link #ZSTD_c_ldmMinMatch c_ldmMinMatch} -
* Minimum match size for long distance matcher. Larger/too small values usually decrease compression ratio. Must be clamped between {@link ZstdX#ZSTD_LDM_MINMATCH_MIN LDM_MINMATCH_MIN}
* and {@link ZstdX#ZSTD_LDM_MINMATCH_MAX LDM_MINMATCH_MAX}. Special: value 0 means "use default value" (default: 64).
*
* - {@link #ZSTD_c_ldmBucketSizeLog c_ldmBucketSizeLog} -
* Log size of each bucket in the LDM hash table for collision resolution. Larger values improve collision resolution but decrease compression speed.
* The maximum value is {@link ZstdX#ZSTD_LDM_BUCKETSIZELOG_MAX LDM_BUCKETSIZELOG_MAX}. Special: value 0 means "use default value" (default: 3).
*
* - {@link #ZSTD_c_ldmHashRateLog c_ldmHashRateLog} -
* Frequency of inserting/looking up entries into the LDM hash table. Must be clamped between 0 and ({@link ZstdX#ZSTD_WINDOWLOG_MAX WINDOWLOG_MAX} - {@link ZstdX#ZSTD_HASHLOG_MIN HASHLOG_MIN}). Default
* is {@code MAX(0, (windowLog - ldmHashLog))}, optimizing hash table usage. Larger values improve compression speed. Deviating far from default value
* will likely result in a compression ratio decrease. Special: value 0 means "automatically determine {@code hashRateLog}".
*
* - {@link #ZSTD_c_contentSizeFlag c_contentSizeFlag} -
* Content size will be written into frame header _whenever known_ (default:1) Content size must be known at the beginning of compression. This is
* automatically the case when using {@link #ZSTD_compress2 compress2}, For streaming variants, content size must be provided with {@link #ZSTD_CCtx_setPledgedSrcSize CCtx_setPledgedSrcSize}.
*
* - {@link #ZSTD_c_checksumFlag c_checksumFlag} - A 32-bits checksum of content is written at end of frame (default:0)
* - {@link #ZSTD_c_dictIDFlag c_dictIDFlag} - When applicable, dictionary's ID is written into frame header (default:1)
* - {@link #ZSTD_c_nbWorkers c_nbWorkers} -
* Select how many threads will be spawned to compress in parallel. When {@code nbWorkers ≥ 1}, triggers asynchronous mode when used with
* {@code ZSTD_compressStream*()}: {@code ZSTD_compressStream*()} consumes input and flush output if possible, but immediately gives back control to
* caller, while compression work is performed in parallel, within worker threads. (note: a strong exception to this rule is when first invocation of
* {@link #ZSTD_compressStream2 compressStream2} sets {@link #ZSTD_e_end e_end}: in which case, {@code ZSTD_compressStream2()} delegates to {@link #ZSTD_compress2 compress2}, which is always a blocking call). More
* workers improve speed, but also increase memory usage. Default value is {@code 0}, aka "single-threaded mode": no worker is spawned, compression is
* performed inside Caller's thread, all invocations are blocking.
*
* - {@link #ZSTD_c_jobSize c_jobSize} -
* Size of a compression job. This value is enforced only when {@code nbWorkers ≥ 1}. Each compression job is completed in parallel, so this value
* can indirectly impact the nb of active threads. 0 means default, which is dynamically determined based on compression parameters. Job size must be
* a minimum of overlap size, or 1 MB, whichever is largest. The minimum size is automatically and transparently enforced.
*
* - {@link #ZSTD_c_overlapLog c_overlapLog} -
* Control the overlap size, as a fraction of window size. The overlap size is an amount of data reloaded from previous job at the beginning of a new
* job. It helps preserve compression ratio, while each job is compressed in parallel. This value is enforced only when {@code nbWorkers ≥ 1}.
* Larger values increase compression ratio, but decrease speed. Possible values range from 0 to 9:
*
*
* - 0 means "default" : value will be determined by the library, depending on strategy
* - 1 means "no overlap"
* - 9 means "full overlap", using a full window size. Each intermediate rank increases/decreases load size by a factor 2: 9: full window; 8: w/2;
* 7: w/4; 6: w/8; 5:w/16; 4: w/32; 3:w/64; 2:w/128; 1:no overlap; 0:default default value varies between 6 and 9, depending on strategy
*
*
* - {@link #ZSTD_c_experimentalParam1 c_experimentalParam1}
* - {@link #ZSTD_c_experimentalParam2 c_experimentalParam2}
* - {@link #ZSTD_c_experimentalParam3 c_experimentalParam3}
* - {@link #ZSTD_c_experimentalParam4 c_experimentalParam4}
* - {@link #ZSTD_c_experimentalParam5 c_experimentalParam5}
*
*/
public static final int
ZSTD_c_compressionLevel = 100,
ZSTD_c_windowLog = 101,
ZSTD_c_hashLog = 102,
ZSTD_c_chainLog = 103,
ZSTD_c_searchLog = 104,
ZSTD_c_minMatch = 105,
ZSTD_c_targetLength = 106,
ZSTD_c_strategy = 107,
ZSTD_c_enableLongDistanceMatching = 160,
ZSTD_c_ldmHashLog = 161,
ZSTD_c_ldmMinMatch = 162,
ZSTD_c_ldmBucketSizeLog = 163,
ZSTD_c_ldmHashRateLog = 164,
ZSTD_c_contentSizeFlag = 200,
ZSTD_c_checksumFlag = 201,
ZSTD_c_dictIDFlag = 202,
ZSTD_c_nbWorkers = 400,
ZSTD_c_jobSize = 401,
ZSTD_c_overlapLog = 402,
ZSTD_c_experimentalParam1 = 500,
ZSTD_c_experimentalParam2 = 10,
ZSTD_c_experimentalParam3 = 1000,
ZSTD_c_experimentalParam4 = 1001,
ZSTD_c_experimentalParam5 = 1002;
/**
* {@code ZSTD_ResetDirective}
*
* Enum values:
*
*
* - {@link #ZSTD_reset_session_only reset_session_only}
* - {@link #ZSTD_reset_parameters reset_parameters}
* - {@link #ZSTD_reset_session_and_parameters reset_session_and_parameters}
*
*/
public static final int
ZSTD_reset_session_only = 1,
ZSTD_reset_parameters = 2,
ZSTD_reset_session_and_parameters = 3;
/**
* The advanced API pushes parameters one by one into an existing {@code DCtx} context. Parameters are sticky, and remain valid for all following frames
* using the same {@code DCtx} context. It's possible to reset parameters to default values using {@link #ZSTD_DCtx_reset DCtx_reset}.
*
* Note: This API is compatible with existing {@link #ZSTD_decompressDCtx decompressDCtx} and {@link #ZSTD_decompressStream decompressStream}. Therefore, no new decompression function is necessary.
*
* ({@code ZSTD_dParameter})
*
* Enum values:
*
*
* - {@link #ZSTD_d_windowLogMax d_windowLogMax} -
* Select a size limit (in power of 2) beyond which the streaming API will refuse to allocate memory buffer in order to protect the host from
* unreasonable memory requirements.
*
*
This parameter is only useful in streaming mode, since no internal buffer is allocated in single-pass mode. By default, a decompression context
* accepts window sizes ≤ (1 << {@link ZstdX#ZSTD_WINDOWLOG_LIMIT_DEFAULT WINDOWLOG_LIMIT_DEFAULT})
*
* Special: value 0 means "use default maximum windowLog".
*
* - {@link #ZSTD_d_experimentalParam1 d_experimentalParam1} -
* Note: additional experimental parameters are also available within the experimental section of the API. At the time of this writing, they include:
* {@link ZstdX#ZSTD_c_format c_format}
*
*
Note: never ever use {@code experimentalParam}? names directly
*
*
*/
public static final int
ZSTD_d_windowLogMax = 100,
ZSTD_d_experimentalParam1 = 1000;
/**
* {@code ZSTD_EndDirective}
*
* Enum values:
*
*
* - {@link #ZSTD_e_continue e_continue} - collect more data, encoder decides when to output compressed result, for optimal compression ratio
* - {@link #ZSTD_e_flush e_flush} -
* flush any data provided so far, it creates (at least) one new block, that can be decoded immediately on reception; frame will continue: any future
* data can still reference previously compressed data, improving compression.
*
* - {@link #ZSTD_e_end e_end} -
* flush any remaining data and close current frame. note that frame is only closed after compressed data is fully flushed (return
* {@code value == 0}). After that point, any additional data starts a new frame.
*
*
Note: each frame is independent (does not reference any content from previous frame).
*
*
*/
public static final int
ZSTD_e_continue = 0,
ZSTD_e_flush = 1,
ZSTD_e_end = 2;
static { LibZstd.initialize(); }
protected Zstd() {
throw new UnsupportedOperationException();
}
// --- [ ZSTD_versionNumber ] ---
/** Returns the version number. */
@NativeType("unsigned")
public static native int ZSTD_versionNumber();
// --- [ ZSTD_versionString ] ---
/** Unsafe version of: {@link #ZSTD_versionString versionString} */
public static native long nZSTD_versionString();
/** Returns the version string. */
@NativeType("char const *")
public static String ZSTD_versionString() {
long __result = nZSTD_versionString();
return memASCII(__result);
}
// --- [ ZSTD_compress ] ---
/** Unsafe version of: {@link #ZSTD_compress compress} */
public static native long nZSTD_compress(long dst, long dstCapacity, long src, long srcSize, int compressionLevel);
/**
* Compresses {@code src} content as a single zstd compressed frame into already allocated {@code dst}.
*
* Hint: compression runs faster if {@code dstCapacity} ≥ {@link #ZSTD_compressBound compressBound}{@code (srcSize)}
*
* @return compressed size written into {@code dst} (≤ {@code dstCapacity}), or an error code if it fails (which can be tested using {@link #ZSTD_isError isError}).
*/
@NativeType("size_t")
public static long ZSTD_compress(@NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src, int compressionLevel) {
return nZSTD_compress(memAddress(dst), dst.remaining(), memAddress(src), src.remaining(), compressionLevel);
}
// --- [ ZSTD_decompress ] ---
/**
* Unsafe version of: {@link #ZSTD_decompress decompress}
*
* @param dstCapacity is an upper bound of {@code originalSize} to regenerate. If user cannot imply a maximum upper bound, it's better to use streaming mode to
* decompress data.
* @param compressedSize must be the exact size of some number of compressed and/or skippable frames
*/
public static native long nZSTD_decompress(long dst, long dstCapacity, long src, long compressedSize);
/**
* @return the number of bytes decompressed into {@code dst} (≤ {@code dstCapacity}), or an {@code errorCode} if it fails (which can be tested using
* {@link #ZSTD_isError isError}).
*/
@NativeType("size_t")
public static long ZSTD_decompress(@NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src) {
return nZSTD_decompress(memAddress(dst), dst.remaining(), memAddress(src), src.remaining());
}
// --- [ ZSTD_getFrameContentSize ] ---
/**
* Unsafe version of: {@link #ZSTD_getFrameContentSize getFrameContentSize}
*
* @param srcSize must be at least as large as the frame header. Hint: any size ≥ {@link ZstdX#ZSTD_FRAMEHEADERSIZE_MAX FRAMEHEADERSIZE_MAX} is large enough.
*/
public static native long nZSTD_getFrameContentSize(long src, long srcSize);
/**
* Notes:
*
*
* - a 0 return value means the frame is valid but "empty"
* - decompressed size is an optional field, it may not be present, typically in streaming mode. When {@code return==ZSTD_CONTENTSIZE_UNKNOWN}, data to
* decompress could be any size. In which case, it's necessary to use streaming mode to decompress data. Optionally, application can rely on some
* implicit limit, as {@link #ZSTD_decompress decompress} only needs an upper bound of decompressed size. (For example, data could be necessarily cut into blocks ≤ 16
* KB).
* - decompressed size is always present when compression is completed using single-pass functions, such as {@link #ZSTD_compress compress}, {@link #ZSTD_compressCCtx compressCCtx},
* {@link #ZSTD_compress_usingDict compress_usingDict} or {@link #ZSTD_compress_usingCDict compress_usingCDict}.
* - decompressed size can be very large (64-bits value), potentially larger than what local system can handle as a single memory segment. In which
* case, it's necessary to use streaming mode to decompress data.
* - If source is untrusted, decompressed size could be wrong or intentionally modified. Always ensure return value fits within application's authorized
* limits. Each application can set its own limits.
*
*
* @param src should point to the start of a ZSTD encoded frame
*
* @return decompressed size of {@code src} frame content, if known
*
*
* - {@link #ZSTD_CONTENTSIZE_UNKNOWN CONTENTSIZE_UNKNOWN} if the size cannot be determined
* - {@link #ZSTD_CONTENTSIZE_ERROR CONTENTSIZE_ERROR} if an error occurred (e.g. invalid magic number, {@code srcSize} too small)
*
*/
@NativeType("unsigned long long")
public static long ZSTD_getFrameContentSize(@NativeType("void const *") ByteBuffer src) {
return nZSTD_getFrameContentSize(memAddress(src), src.remaining());
}
// --- [ ZSTD_findFrameCompressedSize ] ---
/**
* Unsafe version of: {@link #ZSTD_findFrameCompressedSize findFrameCompressedSize}
*
* @param srcSize must be ≥ first frame size
*/
public static native long nZSTD_findFrameCompressedSize(long src, long srcSize);
/**
* @param src should point to the start of a ZSTD frame or skippable frame
*
* @return the compressed size of the first frame starting at {@code src}, suitable to pass as {@code srcSize} to {@link #ZSTD_decompress decompress} or similar, or an error code if
* input is invalid
*/
@NativeType("size_t")
public static long ZSTD_findFrameCompressedSize(@NativeType("void const *") ByteBuffer src) {
return nZSTD_findFrameCompressedSize(memAddress(src), src.remaining());
}
// --- [ ZSTD_compressBound ] ---
/** Returns the maximum compressed size in worst case single-pass scenario. */
@NativeType("size_t")
public static native long ZSTD_compressBound(@NativeType("size_t") long srcSize);
// --- [ ZSTD_isError ] ---
/** Unsafe version of: {@link #ZSTD_isError isError} */
public static native int nZSTD_isError(long code);
/** Tells if a {@code size_t} function result is an error code. */
@NativeType("unsigned int")
public static boolean ZSTD_isError(@NativeType("size_t") long code) {
return nZSTD_isError(code) != 0;
}
// --- [ ZSTD_getErrorName ] ---
/** Unsafe version of: {@link #ZSTD_getErrorName getErrorName} */
public static native long nZSTD_getErrorName(long code);
/** Provides readable string from an error code. */
@NativeType("char const *")
public static String ZSTD_getErrorName(@NativeType("size_t") long code) {
long __result = nZSTD_getErrorName(code);
return memASCII(__result);
}
// --- [ ZSTD_minCLevel ] ---
/** Returns the minimum compression level available. */
public static native int ZSTD_minCLevel();
// --- [ ZSTD_maxCLevel ] ---
/** Returns the maximum compression level available. */
public static native int ZSTD_maxCLevel();
// --- [ ZSTD_createCCtx ] ---
/**
* Creates a compression context.
*
* When compressing many times, it is recommended to allocate a context just once, and re-use it for each successive compression operation. This will make
* workload friendlier for system's memory. Use one context per thread for parallel execution in multi-threaded environments.
*/
@NativeType("ZSTD_CCtx *")
public static native long ZSTD_createCCtx();
// --- [ ZSTD_freeCCtx ] ---
/** Unsafe version of: {@link #ZSTD_freeCCtx freeCCtx} */
public static native long nZSTD_freeCCtx(long cctx);
/** Frees memory allocated by {@link #ZSTD_createCCtx createCCtx}. */
@NativeType("size_t")
public static long ZSTD_freeCCtx(@NativeType("ZSTD_CCtx *") long cctx) {
if (CHECKS) {
check(cctx);
}
return nZSTD_freeCCtx(cctx);
}
// --- [ ZSTD_compressCCtx ] ---
/** Unsafe version of: {@link #ZSTD_compressCCtx compressCCtx} */
public static native long nZSTD_compressCCtx(long ctx, long dst, long dstCapacity, long src, long srcSize, int compressionLevel);
/** Same as {@link #ZSTD_compress compress}, using an explicit {@code ZSTD_CCtx}. The function will compress at requested compression level, ignoring any other parameter. */
@NativeType("size_t")
public static long ZSTD_compressCCtx(@NativeType("ZSTD_CCtx *") long ctx, @NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src, int compressionLevel) {
if (CHECKS) {
check(ctx);
}
return nZSTD_compressCCtx(ctx, memAddress(dst), dst.remaining(), memAddress(src), src.remaining(), compressionLevel);
}
// --- [ ZSTD_createDCtx ] ---
/**
* Creates a decompression context.
*
* When decompressing many times, it is recommended to allocate a context only once, and re-use it for each successive compression operation. This will
* make workload friendlier for system's memory. Use one context per thread for parallel execution.
*/
@NativeType("ZSTD_DCtx *")
public static native long ZSTD_createDCtx();
// --- [ ZSTD_freeDCtx ] ---
/** Unsafe version of: {@link #ZSTD_freeDCtx freeDCtx} */
public static native long nZSTD_freeDCtx(long dctx);
/** Frees memory allocated by {@link #ZSTD_createDCtx createDCtx}. */
@NativeType("size_t")
public static long ZSTD_freeDCtx(@NativeType("ZSTD_DCtx *") long dctx) {
if (CHECKS) {
check(dctx);
}
return nZSTD_freeDCtx(dctx);
}
// --- [ ZSTD_decompressDCtx ] ---
/** Unsafe version of: {@link #ZSTD_decompressDCtx decompressDCtx} */
public static native long nZSTD_decompressDCtx(long ctx, long dst, long dstCapacity, long src, long srcSize);
/** Same as {@link #ZSTD_decompress decompress}, requires an allocated {@code ZSTD_DCtx}. Compatible with sticky parameters. */
@NativeType("size_t")
public static long ZSTD_decompressDCtx(@NativeType("ZSTD_DCtx *") long ctx, @NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src) {
if (CHECKS) {
check(ctx);
}
return nZSTD_decompressDCtx(ctx, memAddress(dst), dst.remaining(), memAddress(src), src.remaining());
}
// --- [ ZSTD_cParam_getBounds ] ---
/** Unsafe version of: {@link #ZSTD_cParam_getBounds cParam_getBounds} */
public static native void nZSTD_cParam_getBounds(int cParam, long __result);
/**
* All parameters must belong to an interval with lower and upper bounds, otherwise they will either trigger an error or be automatically clamped.
*
* @param cParam one of:
{@link #ZSTD_c_compressionLevel c_compressionLevel} {@link #ZSTD_c_windowLog c_windowLog} {@link #ZSTD_c_hashLog c_hashLog} {@link #ZSTD_c_chainLog c_chainLog} {@link #ZSTD_c_searchLog c_searchLog} {@link #ZSTD_c_minMatch c_minMatch} {@link #ZSTD_c_targetLength c_targetLength} {@link #ZSTD_c_strategy c_strategy} {@link #ZSTD_c_enableLongDistanceMatching c_enableLongDistanceMatching} {@link #ZSTD_c_ldmHashLog c_ldmHashLog} {@link #ZSTD_c_ldmMinMatch c_ldmMinMatch} {@link #ZSTD_c_ldmBucketSizeLog c_ldmBucketSizeLog} {@link #ZSTD_c_ldmHashRateLog c_ldmHashRateLog} {@link #ZSTD_c_contentSizeFlag c_contentSizeFlag} {@link #ZSTD_c_checksumFlag c_checksumFlag} {@link #ZSTD_c_dictIDFlag c_dictIDFlag} {@link #ZSTD_c_nbWorkers c_nbWorkers} {@link #ZSTD_c_jobSize c_jobSize} {@link #ZSTD_c_overlapLog c_overlapLog} {@link #ZSTD_c_experimentalParam1 c_experimentalParam1} {@link #ZSTD_c_experimentalParam2 c_experimentalParam2} {@link #ZSTD_c_experimentalParam3 c_experimentalParam3} {@link #ZSTD_c_experimentalParam4 c_experimentalParam4} {@link #ZSTD_c_experimentalParam5 c_experimentalParam5}
* @param __result a structure, {@code ZSTD_bounds}, which contains
*
*
* - an error status field, which must be tested using {@link #ZSTD_isError isError}
* - lower and upper bounds, both inclusive
*
*/
@NativeType("ZSTD_bounds")
public static ZSTDBounds ZSTD_cParam_getBounds(@NativeType("ZSTD_cParameter") int cParam, @NativeType("ZSTD_bounds") ZSTDBounds __result) {
nZSTD_cParam_getBounds(cParam, __result.address());
return __result;
}
// --- [ ZSTD_CCtx_setParameter ] ---
/** Unsafe version of: {@link #ZSTD_CCtx_setParameter CCtx_setParameter} */
public static native long nZSTD_CCtx_setParameter(long cctx, int param, int value);
/**
* Set one compression parameter, selected by enum {@code ZSTD_cParameter}.
*
* All parameters have valid bounds. Bounds can be queried using {@link #ZSTD_cParam_getBounds cParam_getBounds}. Providing a value beyond bound will either clamp it, or trigger an
* error (depending on parameter). Setting a parameter is generally only possible during frame initialization (before starting compression). Exception:
* when using multi-threading mode (nbWorkers ≥ 1), the following parameters can be updated during compression (within same frame): =<
* compressionLevel, hashLog, chainLog, searchLog, minMatch, targetLength and strategy. new parameters will be active for next job only (after a
* {@code flush()}).
*
* @param param one of:
{@link #ZSTD_c_compressionLevel c_compressionLevel} {@link #ZSTD_c_windowLog c_windowLog} {@link #ZSTD_c_hashLog c_hashLog} {@link #ZSTD_c_chainLog c_chainLog} {@link #ZSTD_c_searchLog c_searchLog} {@link #ZSTD_c_minMatch c_minMatch} {@link #ZSTD_c_targetLength c_targetLength} {@link #ZSTD_c_strategy c_strategy} {@link #ZSTD_c_enableLongDistanceMatching c_enableLongDistanceMatching} {@link #ZSTD_c_ldmHashLog c_ldmHashLog} {@link #ZSTD_c_ldmMinMatch c_ldmMinMatch} {@link #ZSTD_c_ldmBucketSizeLog c_ldmBucketSizeLog} {@link #ZSTD_c_ldmHashRateLog c_ldmHashRateLog} {@link #ZSTD_c_contentSizeFlag c_contentSizeFlag} {@link #ZSTD_c_checksumFlag c_checksumFlag} {@link #ZSTD_c_dictIDFlag c_dictIDFlag} {@link #ZSTD_c_nbWorkers c_nbWorkers} {@link #ZSTD_c_jobSize c_jobSize} {@link #ZSTD_c_overlapLog c_overlapLog} {@link #ZSTD_c_experimentalParam1 c_experimentalParam1} {@link #ZSTD_c_experimentalParam2 c_experimentalParam2} {@link #ZSTD_c_experimentalParam3 c_experimentalParam3} {@link #ZSTD_c_experimentalParam4 c_experimentalParam4} {@link #ZSTD_c_experimentalParam5 c_experimentalParam5}
*
* @return an error code (which can be tested using {@link #ZSTD_isError isError})
*/
@NativeType("size_t")
public static long ZSTD_CCtx_setParameter(@NativeType("ZSTD_CCtx *") long cctx, @NativeType("ZSTD_cParameter") int param, int value) {
if (CHECKS) {
check(cctx);
}
return nZSTD_CCtx_setParameter(cctx, param, value);
}
// --- [ ZSTD_CCtx_setPledgedSrcSize ] ---
/** Unsafe version of: {@link #ZSTD_CCtx_setPledgedSrcSize CCtx_setPledgedSrcSize} */
public static native long nZSTD_CCtx_setPledgedSrcSize(long cctx, long pledgedSrcSize);
/**
* Total input data size to be compressed as a single frame.
*
* Value will be written in frame header, unless if explicitly forbidden using {@link #ZSTD_c_contentSizeFlag c_contentSizeFlag}. This value will also be controlled at end of frame, and
* trigger an error if not respected.
*
* Note 1: {@code pledgedSrcSize==0} actually means zero, aka an empty frame. In order to mean "unknown content size", pass constant {@link #ZSTD_CONTENTSIZE_UNKNOWN CONTENTSIZE_UNKNOWN}.
* {@code ZSTD_CONTENTSIZE_UNKNOWN} is default value for any new frame.
*
* Note 2: {@code pledgedSrcSize} is only valid once, for the next frame. It's discarded at the end of the frame, and replaced by
* {@code ZSTD_CONTENTSIZE_UNKNOWN}.
*
* Note 3 : Whenever all input data is provided and consumed in a single round, for example with {@link #ZSTD_compress2 compress2}, or invoking immediately
* {@code ZSTD_compressStream2(,,,ZSTD_e_end)}, this value is automatically overridden by {@code srcSize} instead.
*
* @return 0, or an error code (which can be tested with {@link #ZSTD_isError isError}).
*/
@NativeType("size_t")
public static long ZSTD_CCtx_setPledgedSrcSize(@NativeType("ZSTD_CCtx *") long cctx, @NativeType("unsigned long long") long pledgedSrcSize) {
if (CHECKS) {
check(cctx);
}
return nZSTD_CCtx_setPledgedSrcSize(cctx, pledgedSrcSize);
}
// --- [ ZSTD_CCtx_reset ] ---
/** Unsafe version of: {@link #ZSTD_CCtx_reset CCtx_reset} */
public static native long nZSTD_CCtx_reset(long cctx, int reset);
/**
* There are 2 different things that can be reset, independently or jointly :
*
*
* - The session: will stop compressing current frame, and make {@code CCtx} ready to start a new one. Useful after an error, or to interrupt any
* ongoing compression. Any internal data not yet flushed is cancelled. Compression parameters and dictionary remain unchanged. They will be used to
* compress next frame. Resetting session never fails.
* - The parameters: changes all parameters back to "default". This removes any reference to any dictionary too. Parameters can only be changed between
* 2 sessions (i.e. no compression is currently ongoing) otherwise the reset fails, and function returns an error value (which can be tested using
* {@link #ZSTD_isError isError})
* - Both: similar to resetting the session, followed by resetting parameters.
*
*
* @param reset one of:
{@link #ZSTD_reset_session_only reset_session_only} {@link #ZSTD_reset_parameters reset_parameters} {@link #ZSTD_reset_session_and_parameters reset_session_and_parameters}
*/
@NativeType("size_t")
public static long ZSTD_CCtx_reset(@NativeType("ZSTD_CCtx *") long cctx, @NativeType("ZSTD_ResetDirective") int reset) {
if (CHECKS) {
check(cctx);
}
return nZSTD_CCtx_reset(cctx, reset);
}
// --- [ ZSTD_compress2 ] ---
/** Unsafe version of: {@link #ZSTD_compress2 compress2} */
public static native long nZSTD_compress2(long cctx, long dst, long dstCapacity, long src, long srcSize);
/**
* Behaves the same as {@link #ZSTD_compressCCtx compressCCtx}, but compression parameters are set using the advanced API.
*
* {@code ZSTD_compress2()} always starts a new frame. Should cctx hold data from a previously unfinished frame, everything about it is forgotten.
*
* - Compression parameters are pushed into {@code CCtx} before starting compression, using {@code ZSTD_CCtx_set*()}
* - The function is always blocking, returns when compression is completed. Hint: compression runs faster if {@code dstCapacity} ≥
* {@code ZSTD_compressBound(srcSize)}.
*
* @return compressed size written into {@code dst} (≤ {@code dstCapacity}), or an error code if it fails (which can be tested using {@link #ZSTD_isError isError})
*/
@NativeType("size_t")
public static long ZSTD_compress2(@NativeType("ZSTD_CCtx *") long cctx, @NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src) {
if (CHECKS) {
check(cctx);
}
return nZSTD_compress2(cctx, memAddress(dst), dst.remaining(), memAddress(src), src.remaining());
}
// --- [ ZSTD_dParam_getBounds ] ---
/** Unsafe version of: {@link #ZSTD_dParam_getBounds dParam_getBounds} */
public static native void nZSTD_dParam_getBounds(int dParam, long __result);
/**
* All parameters must belong to an interval with lower and upper bounds, otherwise they will either trigger an error or be automatically clamped.
*
* @param __result returns a structure, {@code ZSTD_bounds}, which contains - an error status field, which must be tested using {@link #ZSTD_isError isError} - both lower and upper bounds,
* inclusive
*/
@NativeType("ZSTD_bounds")
public static ZSTDBounds ZSTD_dParam_getBounds(@NativeType("ZSTD_dParameter") int dParam, @NativeType("ZSTD_bounds") ZSTDBounds __result) {
nZSTD_dParam_getBounds(dParam, __result.address());
return __result;
}
// --- [ ZSTD_DCtx_setParameter ] ---
/** Unsafe version of: {@link #ZSTD_DCtx_setParameter DCtx_setParameter} */
public static native long nZSTD_DCtx_setParameter(long dctx, int param, int value);
/**
* Set one compression parameter, selected by {@code enum ZSTD_dParameter}.
*
* All parameters have valid bounds. Bounds can be queried using {@link #ZSTD_dParam_getBounds dParam_getBounds}. Providing a value beyond bound will either clamp it, or trigger an
* error (depending on parameter). Setting a parameter is only possible during frame initialization (before starting decompression).
*
* @param param one of:
{@link #ZSTD_d_windowLogMax d_windowLogMax} {@link #ZSTD_d_experimentalParam1 d_experimentalParam1}
*
* @return 0, or an error code (which can be tested using {@link #ZSTD_isError isError})
*/
@NativeType("size_t")
public static long ZSTD_DCtx_setParameter(@NativeType("ZSTD_DCtx *") long dctx, @NativeType("ZSTD_dParameter") int param, int value) {
if (CHECKS) {
check(dctx);
}
return nZSTD_DCtx_setParameter(dctx, param, value);
}
// --- [ ZSTD_DCtx_reset ] ---
/** Unsafe version of: {@link #ZSTD_DCtx_reset DCtx_reset} */
public static native long nZSTD_DCtx_reset(long dctx, int reset);
/**
* Returns a {@code DCtx} to clean state.
*
* Session and parameters can be reset jointly or separately. Parameters can only be reset when no active frame is being decompressed.
*
* @param reset one of:
{@link #ZSTD_reset_session_only reset_session_only} {@link #ZSTD_reset_parameters reset_parameters} {@link #ZSTD_reset_session_and_parameters reset_session_and_parameters}
*
* @return 0, or an error code, which can be tested with {@link #ZSTD_isError isError}
*/
@NativeType("size_t")
public static long ZSTD_DCtx_reset(@NativeType("ZSTD_DCtx *") long dctx, @NativeType("ZSTD_ResetDirective") int reset) {
if (CHECKS) {
check(dctx);
}
return nZSTD_DCtx_reset(dctx, reset);
}
// --- [ ZSTD_createCStream ] ---
/**
* A {@code ZSTD_CStream} object is required to track streaming operation.
*
* Use {@code ZSTD_createCStream()} and {@link #ZSTD_freeCStream freeCStream} to create/release resources.
*
* {@code ZSTD_CStream} objects can be reused multiple times on consecutive compression operations. It is recommended to re-use {@code ZSTD_CStream} in
* situations where many streaming operations will be achieved consecutively, since it will play nicer with system's memory, by re-using already allocated
* memory. Use one separate {@code ZSTD_CStream} per thread for parallel execution.
*/
@NativeType("ZSTD_CStream *")
public static native long ZSTD_createCStream();
// --- [ ZSTD_freeCStream ] ---
/** Unsafe version of: {@link #ZSTD_freeCStream freeCStream} */
public static native long nZSTD_freeCStream(long zcs);
/** Frees memory allocated by {@link #ZSTD_createCStream createCStream}. */
@NativeType("size_t")
public static long ZSTD_freeCStream(@NativeType("ZSTD_CStream *") long zcs) {
if (CHECKS) {
check(zcs);
}
return nZSTD_freeCStream(zcs);
}
// --- [ ZSTD_compressStream2 ] ---
/** Unsafe version of: {@link #ZSTD_compressStream2 compressStream2} */
public static native long nZSTD_compressStream2(long cctx, long output, long input, int endOp);
/**
* Behaves about the same as {@code ZSTD_compressStream()}, with additional control on end directive.
*
*
* - Compression parameters are pushed into {@code CCtx} before starting compression, using {@code ZSTD_CCtx_set*()}.
* - Compression parameters cannot be changed once compression is started (save a list of exceptions in multi-threading mode).
* - {@code outpot->pos} must be ≤ {@code dstCapacity}, {@code input->pos} must be ≤ {@code srcSize}.
* - {@code outpot->pos} and {@code input->pos} will be updated. They are guaranteed to remain below their respective limit.
* - When {@code nbWorkers==0} (default), function is blocking: it completes its job before returning to caller.
* - When {@code nbWorkers≥1}, function is non-blocking: it just acquires a copy of input, and distributes jobs to internal worker threads, flush
* whatever is available, and then immediately returns, just indicating that there is some data remaining to be flushed. The function nonetheless
* guarantees forward progress: it will return only after it reads or write at least 1+ byte.
* - Exception: if the first call requests a {@link #ZSTD_e_end e_end} directive and provides enough {@code dstCapacity}, the function delegates to {@link #ZSTD_compress2 compress2} which is
* always blocking.
*
*
* @param endOp one of:
{@link #ZSTD_e_continue e_continue} {@link #ZSTD_e_flush e_flush} {@link #ZSTD_e_end e_end}
*
* @return provides a minimum amount of data remaining to be flushed from internal buffers or an error code, which can be tested using {@link #ZSTD_isError isError}.
*
* If {@code != 0}, flush is not fully completed, there is still some data left within internal buffers. This is useful for {@link #ZSTD_e_flush e_flush}, since in this case
* more flushes are necessary to empty all buffers. For {@link #ZSTD_e_end e_end}, {@code == 0} when internal buffers are fully flushed and frame is completed.
*
* - after a {@code ZSTD_e_end} directive, if internal buffer is not fully flushed ({@code != 0}), only {@code ZSTD_e_end} or {@code ZSTD_e_flush}
* operations are allowed. Before starting a new compression job, or changing compression parameters, it is required to fully flush internal buffers.
*/
@NativeType("size_t")
public static long ZSTD_compressStream2(@NativeType("ZSTD_CCtx *") long cctx, @NativeType("ZSTD_outBuffer *") ZSTDOutBuffer output, @NativeType("ZSTD_inBuffer *") ZSTDInBuffer input, @NativeType("ZSTD_EndDirective") int endOp) {
if (CHECKS) {
check(cctx);
ZSTDOutBuffer.validate(output.address());
ZSTDInBuffer.validate(input.address());
}
return nZSTD_compressStream2(cctx, output.address(), input.address(), endOp);
}
// --- [ ZSTD_CStreamInSize ] ---
/** Returns the recommended size for input buffer. */
@NativeType("size_t")
public static native long ZSTD_CStreamInSize();
// --- [ ZSTD_CStreamOutSize ] ---
/** Returns the recommended size for output buffer. Guarantee to successfully flush at least one complete compressed block in all circumstances. */
@NativeType("size_t")
public static native long ZSTD_CStreamOutSize();
// --- [ ZSTD_createDStream ] ---
/**
* A {@code ZSTD_DStream} object is required to track streaming operations.
*
* Use {@code ZSTD_createDStream()} and {@link #ZSTD_freeDStream freeDStream} to create/release resources. {@code ZSTD_DStream} objects can be re-used multiple times.
*/
@NativeType("ZSTD_DStream *")
public static native long ZSTD_createDStream();
// --- [ ZSTD_freeDStream ] ---
/** Unsafe version of: {@link #ZSTD_freeDStream freeDStream} */
public static native long nZSTD_freeDStream(long zds);
/** Frees memory allocated by {@link #ZSTD_createDStream createDStream}. */
@NativeType("size_t")
public static long ZSTD_freeDStream(@NativeType("ZSTD_DStream *") long zds) {
if (CHECKS) {
check(zds);
}
return nZSTD_freeDStream(zds);
}
// --- [ ZSTD_decompressStream ] ---
/** Unsafe version of: {@link #ZSTD_decompressStream decompressStream} */
public static native long nZSTD_decompressStream(long zds, long output, long input);
/**
* Use {@code ZSTD_decompressStream()} repetitively to consume your input.
*
* The function will update both {@code pos} fields. If {@code input.pos < input.size}, some input has not been consumed. It's up to the caller to present
* again remaining data. The function tries to flush all data decoded immediately, respecting output buffer size. If {@code output.pos < output.size},
* decoder has flushed everything it could. But if {@code output.pos == output.size}, there might be some data left within internal buffers. In which
* case, call {@code ZSTD_decompressStream()} again to flush whatever remains in the buffer. With no additional input provided, amount of data flushed is
* necessarily ≤ {@link #ZSTD_BLOCKSIZE_MAX BLOCKSIZE_MAX}.
*
* @return 0 when a frame is completely decoded and fully flushed, an error code, which can be tested using {@link #ZSTD_isError isError}, any other value > 0, which means there
* is still some decoding to do to complete current frame. The return value is a suggested next input size (just a hint to improve latency) that will
* never request more than the remaining frame size.
*/
@NativeType("size_t")
public static long ZSTD_decompressStream(@NativeType("ZSTD_DStream *") long zds, @NativeType("ZSTD_outBuffer *") ZSTDOutBuffer output, @NativeType("ZSTD_inBuffer *") ZSTDInBuffer input) {
if (CHECKS) {
check(zds);
ZSTDOutBuffer.validate(output.address());
ZSTDInBuffer.validate(input.address());
}
return nZSTD_decompressStream(zds, output.address(), input.address());
}
// --- [ ZSTD_DStreamInSize ] ---
/** Returns the recommended size for input buffer. */
@NativeType("size_t")
public static native long ZSTD_DStreamInSize();
// --- [ ZSTD_DStreamOutSize ] ---
/** Returns the recommended size for output buffer. Guarantee to successfully flush at least one complete compressed block in all circumstances. */
@NativeType("size_t")
public static native long ZSTD_DStreamOutSize();
// --- [ ZSTD_compress_usingDict ] ---
/** Unsafe version of: {@link #ZSTD_compress_usingDict compress_usingDict} */
public static native long nZSTD_compress_usingDict(long ctx, long dst, long dstCapacity, long src, long srcSize, long dict, long dictSize, int compressionLevel);
/**
* Compression at an explicit compression level using a Dictionary.
*
* A dictionary can be any arbitrary data segment (also called a prefix), or a buffer with specified information (see {@code dictBuilder/zdict.h}).
*
* This function loads the dictionary, resulting in significant startup delay. It's intended for a dictionary used only once.
*
* When {@code dict == NULL || dictSize < 8} no dictionary is used.
*/
@NativeType("size_t")
public static long ZSTD_compress_usingDict(@NativeType("ZSTD_CCtx *") long ctx, @NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src, @Nullable @NativeType("void const *") ByteBuffer dict, int compressionLevel) {
if (CHECKS) {
check(ctx);
}
return nZSTD_compress_usingDict(ctx, memAddress(dst), dst.remaining(), memAddress(src), src.remaining(), memAddressSafe(dict), remainingSafe(dict), compressionLevel);
}
// --- [ ZSTD_decompress_usingDict ] ---
/** Unsafe version of: {@link #ZSTD_decompress_usingDict decompress_usingDict} */
public static native long nZSTD_decompress_usingDict(long dctx, long dst, long dstCapacity, long src, long srcSize, long dict, long dictSize);
/**
* Decompression using a known Dictionary. Dictionary must be identical to the one used during compression.
*
* This function loads the dictionary, resulting in significant startup delay. It's intended for a dictionary used only once.
*
* When {@code dict == NULL || dictSize < 8} no dictionary is used.
*/
@NativeType("size_t")
public static long ZSTD_decompress_usingDict(@NativeType("ZSTD_DCtx *") long dctx, @NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src, @Nullable @NativeType("void const *") ByteBuffer dict) {
if (CHECKS) {
check(dctx);
}
return nZSTD_decompress_usingDict(dctx, memAddress(dst), dst.remaining(), memAddress(src), src.remaining(), memAddressSafe(dict), remainingSafe(dict));
}
// --- [ ZSTD_createCDict ] ---
/** Unsafe version of: {@link #ZSTD_createCDict createCDict} */
public static native long nZSTD_createCDict(long dictBuffer, long dictSize, int compressionLevel);
/**
* When compressing multiple messages / blocks using the same dictionary, it's recommended to load it only once.
*
* {@code ZSTD_createCDict()} will create a digested dictionary, ready to start future compression operations without startup cost. {@code ZSTD_CDict}
* can be created once and shared by multiple threads concurrently, since its usage is read-only.
*
* {@code dictBuffer} can be released after {@code ZSTD_CDict} creation, because its content is copied within CDict. Consider experimental function
* {@link ZstdX#ZSTD_createCDict_byReference createCDict_byReference} if you prefer to not duplicate {@code dictBuffer} content.
*
* Note: A {@code ZSTD_CDict} can be created from an empty {@code dictBuffer}, but it is inefficient when used to compress small data.
*/
@NativeType("ZSTD_CDict *")
public static long ZSTD_createCDict(@NativeType("void const *") ByteBuffer dictBuffer, int compressionLevel) {
return nZSTD_createCDict(memAddress(dictBuffer), dictBuffer.remaining(), compressionLevel);
}
// --- [ ZSTD_freeCDict ] ---
/** Unsafe version of: {@link #ZSTD_freeCDict freeCDict} */
public static native long nZSTD_freeCDict(long CDict);
/** Frees memory allocated by {@link #ZSTD_createCDict createCDict}. */
@NativeType("size_t")
public static long ZSTD_freeCDict(@NativeType("ZSTD_CDict *") long CDict) {
if (CHECKS) {
check(CDict);
}
return nZSTD_freeCDict(CDict);
}
// --- [ ZSTD_compress_usingCDict ] ---
/** Unsafe version of: {@link #ZSTD_compress_usingCDict compress_usingCDict} */
public static native long nZSTD_compress_usingCDict(long cctx, long dst, long dstCapacity, long src, long srcSize, long cdict);
/**
* Compression using a digested Dictionary. Recommended when same dictionary is used multiple times.
*
* Compression level is decided at dictionary creation time, and frame parameters are hardcoded ({@code dictID=yes, contentSize=yes, checksum=no})
*/
@NativeType("size_t")
public static long ZSTD_compress_usingCDict(@NativeType("ZSTD_CCtx *") long cctx, @NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src, @NativeType("ZSTD_CDict const *") long cdict) {
if (CHECKS) {
check(cctx);
check(cdict);
}
return nZSTD_compress_usingCDict(cctx, memAddress(dst), dst.remaining(), memAddress(src), src.remaining(), cdict);
}
// --- [ ZSTD_createDDict ] ---
/** Unsafe version of: {@link #ZSTD_createDDict createDDict} */
public static native long nZSTD_createDDict(long dictBuffer, long dictSize);
/**
* Creates a digested dictionary, ready to start decompression operation without startup delay.
*
* {@code dictBuffer} can be released after {@code DDict} creation, as its content is copied inside {@code DDict}.
*/
@NativeType("ZSTD_DDict *")
public static long ZSTD_createDDict(@NativeType("void const *") ByteBuffer dictBuffer) {
return nZSTD_createDDict(memAddress(dictBuffer), dictBuffer.remaining());
}
// --- [ ZSTD_freeDDict ] ---
/** Unsafe version of: {@link #ZSTD_freeDDict freeDDict} */
public static native long nZSTD_freeDDict(long ddict);
/** Frees memory allocated with {@link #ZSTD_createDDict createDDict}. */
@NativeType("size_t")
public static long ZSTD_freeDDict(@NativeType("ZSTD_DDict *") long ddict) {
if (CHECKS) {
check(ddict);
}
return nZSTD_freeDDict(ddict);
}
// --- [ ZSTD_decompress_usingDDict ] ---
/** Unsafe version of: {@link #ZSTD_decompress_usingDDict decompress_usingDDict} */
public static native long nZSTD_decompress_usingDDict(long dctx, long dst, long dstCapacity, long src, long srcSize, long ddict);
/**
* Decompression using a digested Dictionary.
*
* Recommended when same dictionary is used multiple times.
*/
@NativeType("size_t")
public static long ZSTD_decompress_usingDDict(@NativeType("ZSTD_DCtx *") long dctx, @NativeType("void *") ByteBuffer dst, @NativeType("void const *") ByteBuffer src, @NativeType("ZSTD_DDict const *") long ddict) {
if (CHECKS) {
check(dctx);
check(ddict);
}
return nZSTD_decompress_usingDDict(dctx, memAddress(dst), dst.remaining(), memAddress(src), src.remaining(), ddict);
}
// --- [ ZSTD_getDictID_fromDict ] ---
/** Unsafe version of: {@link #ZSTD_getDictID_fromDict getDictID_fromDict} */
public static native int nZSTD_getDictID_fromDict(long dict, long dictSize);
/**
* Provides the {@code dictID} stored within dictionary.
*
* @return if {@code == 0}, the dictionary is not conformant with Zstandard specification. It can still be loaded, but as a content-only dictionary.
*/
@NativeType("unsigned int")
public static int ZSTD_getDictID_fromDict(@NativeType("void const *") ByteBuffer dict) {
return nZSTD_getDictID_fromDict(memAddress(dict), dict.remaining());
}
// --- [ ZSTD_getDictID_fromDDict ] ---
/** Unsafe version of: {@link #ZSTD_getDictID_fromDDict getDictID_fromDDict} */
public static native int nZSTD_getDictID_fromDDict(long ddict);
/**
* Provides the {@code dictID} of the dictionary loaded into {@code ddict}.
*
* @return if {@code == 0}, the dictionary is not conformant to Zstandard specification, or empty.
*
* Non-conformant dictionaries can still be loaded, but as content-only dictionaries.
*/
@NativeType("unsigned int")
public static int ZSTD_getDictID_fromDDict(@NativeType("ZSTD_DDict const *") long ddict) {
if (CHECKS) {
check(ddict);
}
return nZSTD_getDictID_fromDDict(ddict);
}
// --- [ ZSTD_getDictID_fromFrame ] ---
/** Unsafe version of: {@link #ZSTD_getDictID_fromFrame getDictID_fromFrame} */
public static native int nZSTD_getDictID_fromFrame(long src, long srcSize);
/**
* Provides the dictID required to decompressed the frame stored within {@code src}.
*
* @return if {@code == 0}, the {@code dictID} could not be decoded. This could for one of the following reasons :
*
*
* - The frame does not require a dictionary to be decoded (most common case).
* - The frame was built with {@code dictID} intentionally removed. Whatever dictionary is necessary is a hidden information.
*
*
Note: this use case also happens when using a non-conformant dictionary.
* - {@code srcSize} is too small, and as a result, the frame header could not be decoded (only possible if {@code srcSize} < {@link ZstdX#ZSTD_FRAMEHEADERSIZE_MAX FRAMEHEADERSIZE_MAX}).
* - This is not a Zstandard frame. When identifying the exact failure cause, it's possible to use {@link ZstdX#ZSTD_getFrameHeader getFrameHeader}, which will provide a more precise
* error code.
*
*/
@NativeType("unsigned int")
public static int ZSTD_getDictID_fromFrame(@NativeType("void const *") ByteBuffer src) {
return nZSTD_getDictID_fromFrame(memAddress(src), src.remaining());
}
// --- [ ZSTD_CCtx_loadDictionary ] ---
/** Unsafe version of: {@link #ZSTD_CCtx_loadDictionary CCtx_loadDictionary} */
public static native long nZSTD_CCtx_loadDictionary(long cctx, long dict, long dictSize);
/**
* Creates an internal {@code CDict} from {@code dict} buffer. Decompression will have to use same dictionary.
*
* Special: Loading a {@code NULL} (or 0-size) dictionary invalidates previous dictionary, meaning "return to no-dictionary mode".
*
* Note 1: Dictionary is sticky, it will be used for all future compressed frames. To return to "no-dictionary" situation, load a {@code NULL} dictionary (or
* reset parameters).
*
* Note 2: Loading a dictionary involves building tables. It's also a CPU consuming operation, with non-negligible impact on latency. Tables are dependent
* on compression parameters, and for this reason, compression parameters can no longer be changed after loading a dictionary.
*
* Note 3: {@code dict} content will be copied internally. Use experimental {@link ZstdX#ZSTD_CCtx_loadDictionary_byReference CCtx_loadDictionary_byReference} to reference content instead. In such a
* case, dictionary buffer must outlive its users.
*
* Note 4: Use {@link ZstdX#ZSTD_CCtx_loadDictionary_advanced CCtx_loadDictionary_advanced} to precisely select how dictionary content must be interpreted.
*
* @return 0, or an error code (which can be tested with {@link #ZSTD_isError isError}).
*/
@NativeType("size_t")
public static long ZSTD_CCtx_loadDictionary(@NativeType("ZSTD_CCtx *") long cctx, @Nullable @NativeType("void const *") ByteBuffer dict) {
if (CHECKS) {
check(cctx);
}
return nZSTD_CCtx_loadDictionary(cctx, memAddressSafe(dict), remainingSafe(dict));
}
// --- [ ZSTD_CCtx_refCDict ] ---
/** Unsafe version of: {@link #ZSTD_CCtx_refCDict CCtx_refCDict} */
public static native long nZSTD_CCtx_refCDict(long cctx, long cdict);
/**
* References a prepared dictionary, to be used for all next compressed frames.
*
* Note that compression parameters are enforced from within CDict, and supercede any compression parameter previously set within {@code CCtx}. The
* dictionary will remain valid for future compressed frames using same {@code CCtx}.
*
* Special: Referencing a {@code NULL} {@code CDict} means "return to no-dictionary mode".
*
* Note 1: Currently, only one dictionary can be managed. Referencing a new dictionary effectively "discards" any previous one.
*
* Note 2: {@code CDict} is just referenced, its lifetime must outlive its usage within {@code CCtx}.
*
* @return 0, or an error code (which can be tested with {@link #ZSTD_isError isError}).
*/
@NativeType("size_t")
public static long ZSTD_CCtx_refCDict(@NativeType("ZSTD_CCtx *") long cctx, @NativeType("ZSTD_CDict const *") long cdict) {
if (CHECKS) {
check(cctx);
}
return nZSTD_CCtx_refCDict(cctx, cdict);
}
// --- [ ZSTD_CCtx_refPrefix ] ---
/** Unsafe version of: {@link #ZSTD_CCtx_refPrefix CCtx_refPrefix} */
public static native long nZSTD_CCtx_refPrefix(long cctx, long prefix, long prefixSize);
/**
* References a prefix (single-usage dictionary) for next compressed frame.
*
* A prefix is only used once. Tables are discarded at end of frame ({@link #ZSTD_e_end e_end}). Decompression will need same prefix to properly regenerate data.
* Compressing with a prefix is similar in outcome as performing a diff and compressing it, but performs much faster, especially during decompression
* (compression speed is tunable with compression level).
*
* Special: Adding any prefix (including {@code NULL}) invalidates any previous prefix or dictionary
*
* Note 1: Prefix buffer is referenced. It must outlive compression. Its content must remain unmodified during compression.
*
* Note 2: If the intention is to diff some large {@code src} data blob with some prior version of itself, ensure that the window size is large enough to
* contain the entire source. See {@link #ZSTD_c_windowLog c_windowLog}.
*
* Note 3: Referencing a prefix involves building tables, which are dependent on compression parameters. It's a CPU consuming operation, with
* non-negligible impact on latency. If there is a need to use the same prefix multiple times, consider {@code loadDictionary} instead.
*
* Note 4: By default, the prefix is interpreted as raw content ({@link ZstdX#ZSTD_dct_rawContent dct_rawContent}). Use experimental {@link ZstdX#ZSTD_CCtx_refPrefix_advanced CCtx_refPrefix_advanced} to alter dictionary
* interpretation.
*
* @return 0, or an error code (which can be tested with {@link #ZSTD_isError isError}).
*/
@NativeType("size_t")
public static long ZSTD_CCtx_refPrefix(@NativeType("ZSTD_CCtx *") long cctx, @Nullable @NativeType("void const *") ByteBuffer prefix) {
if (CHECKS) {
check(cctx);
}
return nZSTD_CCtx_refPrefix(cctx, memAddressSafe(prefix), remainingSafe(prefix));
}
// --- [ ZSTD_DCtx_loadDictionary ] ---
/** Unsafe version of: {@link #ZSTD_DCtx_loadDictionary DCtx_loadDictionary} */
public static native long nZSTD_DCtx_loadDictionary(long dctx, long dict, long dictSize);
/**
* Create an internal {@code DDict} from {@code dict} buffer, to be used to decompress next frames. The dictionary remains valid for all future frames,
* until explicitly invalidated.
*
* Special: Adding a {@code NULL} (or 0-size) dictionary invalidates any previous dictionary, meaning "return to no-dictionary mode".
*
* Note 1: Loading a dictionary involves building tables, which has a non-negligible impact on CPU usage and latency. It's recommended to "load once, use
* many times", to amortize the cost.
*
* Note 2: {@code dict} content will be copied internally, so {@code dict} can be released after loading. Use {@link ZstdX#ZSTD_DCtx_loadDictionary_byReference DCtx_loadDictionary_byReference} to
* reference dictionary content instead.
*
* Note 3: Use {@link ZstdX#ZSTD_DCtx_loadDictionary_advanced DCtx_loadDictionary_advanced} to take control of how dictionary content is loaded and interpreted.
*
* @return 0, or an error code (which can be tested with ZSTD_isError())
*/
@NativeType("size_t")
public static long ZSTD_DCtx_loadDictionary(@NativeType("ZSTD_DCtx *") long dctx, @Nullable @NativeType("void const *") ByteBuffer dict) {
if (CHECKS) {
check(dctx);
}
return nZSTD_DCtx_loadDictionary(dctx, memAddressSafe(dict), remainingSafe(dict));
}
// --- [ ZSTD_DCtx_refDDict ] ---
/** Unsafe version of: {@link #ZSTD_DCtx_refDDict DCtx_refDDict} */
public static native long nZSTD_DCtx_refDDict(long dctx, long ddict);
/**
* References a prepared dictionary, to be used to decompress next frames. The dictionary remains active for decompression of future frames using same
* {@code DCtx}.
*
* Note 1: Currently, only one dictionary can be managed. Referencing a new dictionary effectively "discards" any previous one. Special: referencing a
* {@code NULL} {@code DDict} means "return to no-dictionary mode".
*
* Note 2: {@code DDict} is just referenced, its lifetime must outlive its usage from {@code DCtx}.
*
* @return 0, or an error code (which can be tested with {@link #ZSTD_isError isError})
*/
@NativeType("size_t")
public static long ZSTD_DCtx_refDDict(@NativeType("ZSTD_DCtx *") long dctx, @NativeType("ZSTD_DDict const *") long ddict) {
if (CHECKS) {
check(dctx);
}
return nZSTD_DCtx_refDDict(dctx, ddict);
}
// --- [ ZSTD_DCtx_refPrefix ] ---
/** Unsafe version of: {@link #ZSTD_DCtx_refPrefix DCtx_refPrefix} */
public static native long nZSTD_DCtx_refPrefix(long dctx, long prefix, long prefixSize);
/**
* References a prefix (single-usage dictionary) to decompress next frame.
*
* This is the reverse operation of {@link #ZSTD_CCtx_refPrefix CCtx_refPrefix}, and must use the same prefix as the one used during compression. Prefix is only used once.
* Reference is discarded at end of frame. End of frame is reached when {@link #ZSTD_decompressStream decompressStream} returns 0.
*
* Note 1: Adding any prefix (including {@code NULL}) invalidates any previously set prefix or dictionary.
*
* Note 2: Prefix buffer is referenced. It must outlive decompression. Prefix buffer must remain unmodified up to the end of frame, reached when
* {@code ZSTD_decompressStream()} returns 0.
*
* Note 3: By default, the prefix is treated as raw content ({@link ZstdX#ZSTD_dct_rawContent dct_rawContent}). Use {@link ZstdX#ZSTD_CCtx_refPrefix_advanced CCtx_refPrefix_advanced} to alter {@code dictMode}.
*
* Note 4: Referencing a raw content prefix has almost no cpu nor memory cost. A full dictionary is more costly, as it requires building tables.
*
* @return 0, or an error code (which can be tested with {@link #ZSTD_isError isError})
*/
@NativeType("size_t")
public static long ZSTD_DCtx_refPrefix(@NativeType("ZSTD_DCtx *") long dctx, @NativeType("void const *") ByteBuffer prefix) {
if (CHECKS) {
check(dctx);
}
return nZSTD_DCtx_refPrefix(dctx, memAddress(prefix), prefix.remaining());
}
// --- [ ZSTD_sizeof_CCtx ] ---
public static native long nZSTD_sizeof_CCtx(long cctx);
@NativeType("size_t")
public static long ZSTD_sizeof_CCtx(@NativeType("ZSTD_CCtx const *") long cctx) {
if (CHECKS) {
check(cctx);
}
return nZSTD_sizeof_CCtx(cctx);
}
// --- [ ZSTD_sizeof_DCtx ] ---
public static native long nZSTD_sizeof_DCtx(long dctx);
@NativeType("size_t")
public static long ZSTD_sizeof_DCtx(@NativeType("ZSTD_DCtx const *") long dctx) {
if (CHECKS) {
check(dctx);
}
return nZSTD_sizeof_DCtx(dctx);
}
// --- [ ZSTD_sizeof_CStream ] ---
public static native long nZSTD_sizeof_CStream(long zcs);
@NativeType("size_t")
public static long ZSTD_sizeof_CStream(@NativeType("ZSTD_CStream const *") long zcs) {
if (CHECKS) {
check(zcs);
}
return nZSTD_sizeof_CStream(zcs);
}
// --- [ ZSTD_sizeof_DStream ] ---
public static native long nZSTD_sizeof_DStream(long zds);
@NativeType("size_t")
public static long ZSTD_sizeof_DStream(@NativeType("ZSTD_DStream const *") long zds) {
if (CHECKS) {
check(zds);
}
return nZSTD_sizeof_DStream(zds);
}
// --- [ ZSTD_sizeof_CDict ] ---
public static native long nZSTD_sizeof_CDict(long cdict);
@NativeType("size_t")
public static long ZSTD_sizeof_CDict(@NativeType("ZSTD_CDict const *") long cdict) {
if (CHECKS) {
check(cdict);
}
return nZSTD_sizeof_CDict(cdict);
}
// --- [ ZSTD_sizeof_DDict ] ---
public static native long nZSTD_sizeof_DDict(long ddict);
@NativeType("size_t")
public static long ZSTD_sizeof_DDict(@NativeType("ZSTD_DDict const *") long ddict) {
if (CHECKS) {
check(ddict);
}
return nZSTD_sizeof_DDict(ddict);
}
/** Pure Java version of {@link #ZSTD_compressBound}. */
public static long ZSTD_COMPRESSBOUND(long srcSize) {
/* this formula ensures that bound(A) + bound(B) <= bound(A+B) as long as A and B >= 128 KB */
return srcSize
+ (srcSize >> 8)
+ (srcSize < (128 << 10)
? (128 << 10) - srcSize >> 11 /* margin, from 64 to 0 */
: 0
);
}
}