mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-02 12:32:04 +00:00
38 lines
689 B
C++
38 lines
689 B
C++
#pragma once
|
|
|
|
#include <IO/CompressedReadBufferWrapper.h>
|
|
#include <IO/CompressionMethod.h>
|
|
#include <IO/ReadBuffer.h>
|
|
|
|
#include <zstd.h>
|
|
|
|
|
|
namespace DB
|
|
{
|
|
namespace ErrorCodes
|
|
{
|
|
}
|
|
|
|
class ZstdInflatingReadBuffer : public CompressedReadBufferWrapper
|
|
{
|
|
public:
|
|
explicit ZstdInflatingReadBuffer(
|
|
std::unique_ptr<ReadBuffer> in_,
|
|
size_t buf_size = DBMS_DEFAULT_BUFFER_SIZE,
|
|
char * existing_memory = nullptr,
|
|
size_t alignment = 0,
|
|
int zstd_window_log_max = 0);
|
|
|
|
~ZstdInflatingReadBuffer() override;
|
|
|
|
private:
|
|
bool nextImpl() override;
|
|
|
|
ZSTD_DCtx * dctx;
|
|
ZSTD_inBuffer input;
|
|
ZSTD_outBuffer output;
|
|
bool eof_flag = false;
|
|
};
|
|
|
|
}
|