python-zstandard.h
346 lines
| 8.3 KiB
| text/x-c
|
CLexer
Gregory Szorc
|
r30435 | /** | ||
* Copyright (c) 2016-present, Gregory Szorc | ||||
* All rights reserved. | ||||
* | ||||
* This software may be modified and distributed under the terms | ||||
* of the BSD license. See the LICENSE file for details. | ||||
*/ | ||||
#define PY_SSIZE_T_CLEAN | ||||
#include <Python.h> | ||||
Gregory Szorc
|
r30895 | #include "structmember.h" | ||
Gregory Szorc
|
r30435 | |||
#define ZSTD_STATIC_LINKING_ONLY | ||||
#define ZDICT_STATIC_LINKING_ONLY | ||||
Gregory Szorc
|
r37513 | #include <zstd.h> | ||
#include <zdict.h> | ||||
Gregory Szorc
|
r30435 | |||
Gregory Szorc
|
r37513 | #define PYTHON_ZSTANDARD_VERSION "0.9.0" | ||
Gregory Szorc
|
r30822 | |||
typedef enum { | ||||
compressorobj_flush_finish, | ||||
compressorobj_flush_block, | ||||
} CompressorObj_Flush; | ||||
Gregory Szorc
|
r30435 | |||
Gregory Szorc
|
r31796 | /* | ||
Gregory Szorc
|
r37513 | Represents a ZstdCompressionParameters type. | ||
Gregory Szorc
|
r31796 | |||
Gregory Szorc
|
r37513 | This type holds all the low-level compression parameters that can be set. | ||
Gregory Szorc
|
r31796 | */ | ||
Gregory Szorc
|
r30435 | typedef struct { | ||
PyObject_HEAD | ||||
Gregory Szorc
|
r37513 | ZSTD_CCtx_params* params; | ||
unsigned format; | ||||
int compressionLevel; | ||||
Gregory Szorc
|
r30435 | unsigned windowLog; | ||
Gregory Szorc
|
r37513 | unsigned hashLog; | ||
Gregory Szorc
|
r30435 | unsigned chainLog; | ||
unsigned searchLog; | ||||
Gregory Szorc
|
r37513 | unsigned minMatch; | ||
Gregory Szorc
|
r30435 | unsigned targetLength; | ||
Gregory Szorc
|
r37513 | unsigned compressionStrategy; | ||
unsigned contentSizeFlag; | ||||
unsigned checksumFlag; | ||||
unsigned dictIDFlag; | ||||
unsigned threads; | ||||
unsigned jobSize; | ||||
unsigned overlapSizeLog; | ||||
unsigned compressLiterals; | ||||
unsigned forceMaxWindow; | ||||
unsigned enableLongDistanceMatching; | ||||
unsigned ldmHashLog; | ||||
unsigned ldmMinMatch; | ||||
unsigned ldmBucketSizeLog; | ||||
unsigned ldmHashEveryLog; | ||||
} ZstdCompressionParametersObject; | ||||
Gregory Szorc
|
r30435 | |||
Gregory Szorc
|
r37513 | extern PyTypeObject ZstdCompressionParametersType; | ||
Gregory Szorc
|
r30435 | |||
Gregory Szorc
|
r31796 | /* | ||
Represents a FrameParameters type. | ||||
This type is basically a wrapper around ZSTD_frameParams. | ||||
*/ | ||||
Gregory Szorc
|
r30435 | typedef struct { | ||
PyObject_HEAD | ||||
Gregory Szorc
|
r30895 | unsigned long long frameContentSize; | ||
Gregory Szorc
|
r37513 | unsigned long long windowSize; | ||
Gregory Szorc
|
r30895 | unsigned dictID; | ||
char checksumFlag; | ||||
} FrameParametersObject; | ||||
extern PyTypeObject FrameParametersType; | ||||
Gregory Szorc
|
r31796 | /* | ||
Represents a ZstdCompressionDict type. | ||||
Gregory Szorc
|
r30435 | |||
Gregory Szorc
|
r31796 | Instances hold data used for a zstd compression dictionary. | ||
*/ | ||||
Gregory Szorc
|
r30435 | typedef struct { | ||
PyObject_HEAD | ||||
Gregory Szorc
|
r31796 | /* Pointer to dictionary data. Owned by self. */ | ||
Gregory Szorc
|
r30435 | void* dictData; | ||
Gregory Szorc
|
r31796 | /* Size of dictionary data. */ | ||
Gregory Szorc
|
r30435 | size_t dictSize; | ||
Gregory Szorc
|
r37513 | ZSTD_dictContentType_e dictType; | ||
Gregory Szorc
|
r31796 | /* k parameter for cover dictionaries. Only populated by train_cover_dict(). */ | ||
unsigned k; | ||||
/* d parameter for cover dictionaries. Only populated by train_cover_dict(). */ | ||||
unsigned d; | ||||
Gregory Szorc
|
r37513 | /* Digested dictionary, suitable for reuse. */ | ||
ZSTD_CDict* cdict; | ||||
ZSTD_DDict* ddict; | ||||
Gregory Szorc
|
r30435 | } ZstdCompressionDict; | ||
extern PyTypeObject ZstdCompressionDictType; | ||||
Gregory Szorc
|
r31796 | /* | ||
Represents a ZstdCompressor type. | ||||
*/ | ||||
Gregory Szorc
|
r30435 | typedef struct { | ||
PyObject_HEAD | ||||
Gregory Szorc
|
r31796 | /* Number of threads to use for operations. */ | ||
unsigned int threads; | ||||
/* Pointer to compression dictionary to use. NULL if not using dictionary | ||||
compression. */ | ||||
Gregory Szorc
|
r30435 | ZstdCompressionDict* dict; | ||
Gregory Szorc
|
r37513 | /* Compression context to use. Populated during object construction. */ | ||
Gregory Szorc
|
r30822 | ZSTD_CCtx* cctx; | ||
Gregory Szorc
|
r37513 | /* Compression parameters in use. */ | ||
ZSTD_CCtx_params* params; | ||||
Gregory Szorc
|
r30435 | } ZstdCompressor; | ||
extern PyTypeObject ZstdCompressorType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
ZstdCompressor* compressor; | ||||
ZSTD_outBuffer output; | ||||
Gregory Szorc
|
r30822 | int finished; | ||
Gregory Szorc
|
r30435 | } ZstdCompressionObj; | ||
extern PyTypeObject ZstdCompressionObjType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
ZstdCompressor* compressor; | ||||
PyObject* writer; | ||||
Gregory Szorc
|
r37513 | unsigned long long sourceSize; | ||
Gregory Szorc
|
r30435 | size_t outSize; | ||
int entered; | ||||
Gregory Szorc
|
r37513 | unsigned long long bytesCompressed; | ||
Gregory Szorc
|
r30435 | } ZstdCompressionWriter; | ||
extern PyTypeObject ZstdCompressionWriterType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
ZstdCompressor* compressor; | ||||
PyObject* reader; | ||||
Gregory Szorc
|
r37513 | Py_buffer buffer; | ||
Gregory Szorc
|
r30435 | Py_ssize_t bufferOffset; | ||
size_t inSize; | ||||
size_t outSize; | ||||
ZSTD_inBuffer input; | ||||
ZSTD_outBuffer output; | ||||
int finishedOutput; | ||||
int finishedInput; | ||||
PyObject* readResult; | ||||
} ZstdCompressorIterator; | ||||
extern PyTypeObject ZstdCompressorIteratorType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
Gregory Szorc
|
r37513 | ZstdCompressor* compressor; | ||
PyObject* reader; | ||||
Py_buffer buffer; | ||||
unsigned long long sourceSize; | ||||
size_t readSize; | ||||
int entered; | ||||
int closed; | ||||
unsigned long long bytesCompressed; | ||||
ZSTD_inBuffer input; | ||||
ZSTD_outBuffer output; | ||||
int finishedInput; | ||||
int finishedOutput; | ||||
PyObject* readResult; | ||||
} ZstdCompressionReader; | ||||
extern PyTypeObject ZstdCompressionReaderType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
Gregory Szorc
|
r30895 | ZSTD_DCtx* dctx; | ||
Gregory Szorc
|
r30435 | ZstdCompressionDict* dict; | ||
Gregory Szorc
|
r37513 | size_t maxWindowSize; | ||
ZSTD_format_e format; | ||||
Gregory Szorc
|
r30435 | } ZstdDecompressor; | ||
extern PyTypeObject ZstdDecompressorType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
ZstdDecompressor* decompressor; | ||||
Gregory Szorc
|
r37513 | size_t outSize; | ||
Gregory Szorc
|
r30435 | int finished; | ||
} ZstdDecompressionObj; | ||||
extern PyTypeObject ZstdDecompressionObjType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
Gregory Szorc
|
r37513 | /* Parent decompressor to which this object is associated. */ | ||
ZstdDecompressor* decompressor; | ||||
/* Object to read() from (if reading from a stream). */ | ||||
PyObject* reader; | ||||
/* Size for read() operations on reader. */ | ||||
size_t readSize; | ||||
/* Buffer to read from (if reading from a buffer). */ | ||||
Py_buffer buffer; | ||||
/* Whether the context manager is active. */ | ||||
int entered; | ||||
/* Whether we've closed the stream. */ | ||||
int closed; | ||||
/* Number of bytes decompressed and returned to user. */ | ||||
unsigned long long bytesDecompressed; | ||||
/* Tracks data going into decompressor. */ | ||||
ZSTD_inBuffer input; | ||||
/* Holds output from read() operation on reader. */ | ||||
PyObject* readResult; | ||||
/* Whether all input has been sent to the decompressor. */ | ||||
int finishedInput; | ||||
/* Whether all output has been flushed from the decompressor. */ | ||||
int finishedOutput; | ||||
} ZstdDecompressionReader; | ||||
extern PyTypeObject ZstdDecompressionReaderType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
Gregory Szorc
|
r30435 | ZstdDecompressor* decompressor; | ||
PyObject* writer; | ||||
size_t outSize; | ||||
int entered; | ||||
} ZstdDecompressionWriter; | ||||
extern PyTypeObject ZstdDecompressionWriterType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
ZstdDecompressor* decompressor; | ||||
PyObject* reader; | ||||
Gregory Szorc
|
r37513 | Py_buffer buffer; | ||
Gregory Szorc
|
r30435 | Py_ssize_t bufferOffset; | ||
size_t inSize; | ||||
size_t outSize; | ||||
size_t skipBytes; | ||||
ZSTD_inBuffer input; | ||||
ZSTD_outBuffer output; | ||||
Py_ssize_t readCount; | ||||
int finishedInput; | ||||
int finishedOutput; | ||||
} ZstdDecompressorIterator; | ||||
extern PyTypeObject ZstdDecompressorIteratorType; | ||||
typedef struct { | ||||
int errored; | ||||
PyObject* chunk; | ||||
} DecompressorIteratorResult; | ||||
Gregory Szorc
|
r31796 | typedef struct { | ||
Gregory Szorc
|
r37513 | /* The public API is that these are 64-bit unsigned integers. So these can't | ||
* be size_t, even though values larger than SIZE_MAX or PY_SSIZE_T_MAX may | ||||
* be nonsensical for this platform. */ | ||||
Gregory Szorc
|
r31796 | unsigned long long offset; | ||
unsigned long long length; | ||||
} BufferSegment; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
PyObject* parent; | ||||
BufferSegment* segments; | ||||
Py_ssize_t segmentCount; | ||||
} ZstdBufferSegments; | ||||
extern PyTypeObject ZstdBufferSegmentsType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
PyObject* parent; | ||||
void* data; | ||||
Py_ssize_t dataSize; | ||||
unsigned long long offset; | ||||
} ZstdBufferSegment; | ||||
extern PyTypeObject ZstdBufferSegmentType; | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
Py_buffer parent; | ||||
void* data; | ||||
unsigned long long dataSize; | ||||
BufferSegment* segments; | ||||
Py_ssize_t segmentCount; | ||||
int useFree; | ||||
} ZstdBufferWithSegments; | ||||
extern PyTypeObject ZstdBufferWithSegmentsType; | ||||
/** | ||||
* An ordered collection of BufferWithSegments exposed as a squashed collection. | ||||
* | ||||
* This type provides a virtual view spanning multiple BufferWithSegments | ||||
* instances. It allows multiple instances to be "chained" together and | ||||
* exposed as a single collection. e.g. if there are 2 buffers holding | ||||
* 10 segments each, then o[14] will access the 5th segment in the 2nd buffer. | ||||
*/ | ||||
typedef struct { | ||||
PyObject_HEAD | ||||
/* An array of buffers that should be exposed through this instance. */ | ||||
ZstdBufferWithSegments** buffers; | ||||
/* Number of elements in buffers array. */ | ||||
Py_ssize_t bufferCount; | ||||
/* Array of first offset in each buffer instance. 0th entry corresponds | ||||
to number of elements in the 0th buffer. 1st entry corresponds to the | ||||
sum of elements in 0th and 1st buffers. */ | ||||
Py_ssize_t* firstElements; | ||||
} ZstdBufferWithSegmentsCollection; | ||||
extern PyTypeObject ZstdBufferWithSegmentsCollectionType; | ||||
Gregory Szorc
|
r37513 | int set_parameter(ZSTD_CCtx_params* params, ZSTD_cParameter param, unsigned value); | ||
int set_parameters(ZSTD_CCtx_params* params, ZstdCompressionParametersObject* obj); | ||||
FrameParametersObject* get_frame_parameters(PyObject* self, PyObject* args, PyObject* kwargs); | ||||
int ensure_ddict(ZstdCompressionDict* dict); | ||||
int ensure_dctx(ZstdDecompressor* decompressor, int loadDict); | ||||
Gregory Szorc
|
r30435 | ZstdCompressionDict* train_dictionary(PyObject* self, PyObject* args, PyObject* kwargs); | ||
Gregory Szorc
|
r31796 | ZstdBufferWithSegments* BufferWithSegments_FromMemory(void* data, unsigned long long dataSize, BufferSegment* segments, Py_ssize_t segmentsSize); | ||
Py_ssize_t BufferWithSegmentsCollection_length(ZstdBufferWithSegmentsCollection*); | ||||
int cpu_count(void); | ||||
size_t roundpow2(size_t); | ||||
Gregory Szorc
|
r37513 | int safe_pybytes_resize(PyObject** obj, Py_ssize_t size); | ||