25 pg_fatal(
"this build does not support compression with %s",
"ZSTD");
31 pg_fatal(
"this build does not support compression with %s",
"ZSTD");
38typedef struct ZstdCompressorState
43 ZSTD_CStream *cstream;
44 ZSTD_DStream *dstream;
49 const char *zstderror;
55 const void *
data,
size_t dLen);
59_Zstd_CCtx_setParam_or_die(ZSTD_CStream *cstream,
60 ZSTD_cParameter param,
int value,
char *paramname)
64 res = ZSTD_CCtx_setParameter(cstream, param,
value);
65 if (ZSTD_isError(res))
66 pg_fatal(
"could not set compression parameter \"%s\": %s",
67 paramname, ZSTD_getErrorName(res));
74 ZSTD_CStream *cstream;
76 cstream = ZSTD_createCStream();
78 pg_fatal(
"could not initialize compression library");
80 _Zstd_CCtx_setParam_or_die(cstream, ZSTD_c_compressionLevel,
81 compress.
level,
"level");
84 _Zstd_CCtx_setParam_or_die(cstream,
85 ZSTD_c_enableLongDistanceMatching,
95 ZstdCompressorState *zstdcs = (ZstdCompressorState *) cs->
private_data;
96 ZSTD_inBuffer *
input = &zstdcs->input;
97 ZSTD_outBuffer *
output = &zstdcs->output;
105 res = ZSTD_compressStream2(zstdcs->cstream,
output,
106 input, flush ? ZSTD_e_end : ZSTD_e_continue);
108 if (ZSTD_isError(res))
109 pg_fatal(
"could not compress data: %s", ZSTD_getErrorName(res));
127 ZstdCompressorState *zstdcs = (ZstdCompressorState *) cs->
private_data;
131 Assert(zstdcs->cstream == NULL);
132 ZSTD_freeDStream(zstdcs->dstream);
135 else if (cs->
writeF != NULL)
137 Assert(zstdcs->dstream == NULL);
138 _ZstdWriteCommon(AH, cs,
true);
139 ZSTD_freeCStream(zstdcs->cstream);
150 const void *
data,
size_t dLen)
152 ZstdCompressorState *zstdcs = (ZstdCompressorState *) cs->
private_data;
154 zstdcs->input.src =
data;
155 zstdcs->input.size = dLen;
156 zstdcs->input.pos = 0;
158 _ZstdWriteCommon(AH, cs,
false);
164 ZstdCompressorState *zstdcs = (ZstdCompressorState *) cs->
private_data;
165 ZSTD_outBuffer *
output = &zstdcs->output;
166 ZSTD_inBuffer *
input = &zstdcs->input;
167 size_t input_allocated_size = ZSTD_DStreamInSize();
178 input->size = input_allocated_size;
183 input_allocated_size =
input->size;
194 res = ZSTD_decompressStream(zstdcs->dstream,
output,
input);
195 if (ZSTD_isError(res))
196 pg_fatal(
"could not decompress data: %s", ZSTD_getErrorName(res));
215 ZstdCompressorState *zstdcs;
217 cs->
readData = ReadDataFromArchiveZstd;
219 cs->
end = EndCompressorZstd;
223 zstdcs = (ZstdCompressorState *)
pg_malloc0(
sizeof(*zstdcs));
229 if (cs->
readF != NULL)
231 zstdcs->dstream = ZSTD_createDStream();
232 if (zstdcs->dstream == NULL)
233 pg_fatal(
"could not initialize compression library");
235 zstdcs->input.size = ZSTD_DStreamInSize();
236 zstdcs->input.src =
pg_malloc(zstdcs->input.size);
244 zstdcs->output.size = ZSTD_DStreamOutSize();
245 zstdcs->output.dst =
pg_malloc(zstdcs->output.size + 1);
247 else if (cs->
writeF != NULL)
251 zstdcs->output.size = ZSTD_CStreamOutSize();
252 zstdcs->output.dst =
pg_malloc(zstdcs->output.size);
253 zstdcs->output.pos = 0;
264 ZstdCompressorState *zstdcs = (ZstdCompressorState *) CFH->
private_data;
265 ZSTD_inBuffer *
input = &zstdcs->input;
266 ZSTD_outBuffer *
output = &zstdcs->output;
267 size_t input_allocated_size = ZSTD_DStreamInSize();
294 cnt = fread(
unconstify(
void *,
input->src), 1, input_allocated_size, zstdcs->fp);
297 Assert(cnt <= input_allocated_size);
307 res = ZSTD_decompressStream(zstdcs->dstream,
output,
input);
309 if (ZSTD_isError(res))
310 pg_fatal(
"could not decompress data: %s", ZSTD_getErrorName(res));
332 ZstdCompressorState *zstdcs = (ZstdCompressorState *) CFH->
private_data;
333 ZSTD_inBuffer *
input = &zstdcs->input;
334 ZSTD_outBuffer *
output = &zstdcs->output;
346 res = ZSTD_compressStream2(zstdcs->cstream,
output,
input, ZSTD_e_continue);
347 if (ZSTD_isError(res))
349 zstdcs->zstderror = ZSTD_getErrorName(res);
356 zstdcs->zstderror =
strerror(errno);
367 ZstdCompressorState *zstdcs = (ZstdCompressorState *) CFH->
private_data;
372 if (feof(zstdcs->fp))
373 pg_fatal(
"could not read from input file: end of file");
375 pg_fatal(
"could not read from input file: %m");
391 for (
i = 0;
i <
len - 1; ++
i)
406 return i > 0 ?
buf : NULL;
412 ZstdCompressorState *zstdcs = (ZstdCompressorState *) CFH->
private_data;
418 ZSTD_inBuffer *
input = &zstdcs->input;
419 ZSTD_outBuffer *
output = &zstdcs->output;
425 res = ZSTD_compressStream2(zstdcs->cstream,
output,
input, ZSTD_e_end);
426 if (ZSTD_isError(res))
428 zstdcs->zstderror = ZSTD_getErrorName(res);
435 zstdcs->zstderror =
strerror(errno);
443 ZSTD_freeCStream(zstdcs->cstream);
449 ZSTD_freeDStream(zstdcs->dstream);
453 if (fclose(zstdcs->fp) != 0)
463 ZstdCompressorState *zstdcs = (ZstdCompressorState *) CFH->
private_data;
465 return feof(zstdcs->fp);
469Zstd_open(
const char *path,
int fd,
const char *
mode,
473 ZstdCompressorState *zstdcs;
478 fp = fopen(path,
mode);
483 zstdcs = (ZstdCompressorState *)
pg_malloc0(
sizeof(*zstdcs));
489 zstdcs->input.src =
pg_malloc0(ZSTD_DStreamInSize());
490 zstdcs->dstream = ZSTD_createDStream();
491 if (zstdcs->dstream == NULL)
492 pg_fatal(
"could not initialize compression library");
494 else if (
mode[0] ==
'w' ||
mode[0] ==
'a')
496 zstdcs->output.size = ZSTD_CStreamOutSize();
497 zstdcs->output.dst =
pg_malloc0(zstdcs->output.size);
499 if (zstdcs->cstream == NULL)
500 pg_fatal(
"could not initialize compression library");
513 sprintf(fname,
"%s.zst", path);
520 ZstdCompressorState *zstdcs = (ZstdCompressorState *) CFH->
private_data;
522 return zstdcs->zstderror;
#define unconstify(underlying_type, expr)
void InitCompressorZstd(CompressorState *cs, const pg_compress_specification compression_spec)
void InitCompressFileHandleZstd(CompressFileHandle *CFH, const pg_compress_specification compression_spec)
#define PG_COMPRESSION_OPTION_LONG_DISTANCE
void * pg_malloc(size_t size)
void * pg_malloc0(size_t size)
Assert(PointerIsAligned(start, uint64))
if(TABLE==NULL||TABLE_index==NULL)
void ahwrite(const void *ptr, size_t size, size_t nmemb, ArchiveHandle *AH)
static PgChecksumMode mode
static int fd(const char *x, int i)
char *(* gets_func)(char *s, int size, CompressFileHandle *CFH)
bool(* open_write_func)(const char *path, const char *mode, CompressFileHandle *CFH)
bool(* write_func)(const void *ptr, size_t size, struct CompressFileHandle *CFH)
int(* getc_func)(CompressFileHandle *CFH)
const char *(* get_error_func)(CompressFileHandle *CFH)
bool(* eof_func)(CompressFileHandle *CFH)
bool(* open_func)(const char *path, int fd, const char *mode, CompressFileHandle *CFH)
pg_compress_specification compression_spec
bool(* close_func)(CompressFileHandle *CFH)
bool(* read_func)(void *ptr, size_t size, size_t *rsize, CompressFileHandle *CFH)
void(* readData)(ArchiveHandle *AH, CompressorState *cs)
pg_compress_specification compression_spec
void(* end)(ArchiveHandle *AH, CompressorState *cs)
void(* writeData)(ArchiveHandle *AH, CompressorState *cs, const void *data, size_t dLen)