com.github.luben.zstd.ZstdDictDecompress Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulsar-flink-connector_2.11 Show documentation
Show all versions of pulsar-flink-connector_2.11 Show documentation
Elastic data processing with Apache Pulsar and Apache Flink
The newest version!
package com.github.luben.zstd;
import com.github.luben.zstd.util.Native;
public class ZstdDictDecompress extends SharedDictBase {
static {
Native.load();
}
private long nativePtr = 0L;
private native void init(byte[] dict, int dict_offset, int dict_size);
private native void free();
/**
* Convenience constructor to create a new dictionary for use with fast decompress
*
* @param dict buffer containing dictionary to load/parse with exact length
*/
public ZstdDictDecompress(byte[] dict) {
this(dict, 0, dict.length);
}
/**
* Create a new dictionary for use with fast decompress
*
* @param dict buffer containing dictionary
* @param offset the offset into the buffer to read from
* @param length number of bytes to use from the buffer
*/
public ZstdDictDecompress(byte[] dict, int offset, int length) {
init(dict, offset, length);
if (nativePtr == 0L) {
throw new IllegalStateException("ZSTD_createDDict failed");
}
// Ensures that even if ZstdDictDecompress is created and published through a race, no thread could observe
// nativePtr == 0.
storeFence();
}
@Override
void doClose() {
if (nativePtr != 0) {
free();
nativePtr = 0;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy