#pragma once #include #include #include #include namespace DB { namespace ErrorCodes { } /// Reads compressed data from ReadBuffer in_ and performs decompression using zlib library. /// This buffer is able to seamlessly decompress multiple concatenated zlib streams. class ZlibInflatingReadBuffer : public BufferWithOwnMemory { public: ZlibInflatingReadBuffer( std::unique_ptr in_, CompressionMethod compression_method, size_t buf_size = DBMS_DEFAULT_BUFFER_SIZE, char * existing_memory = nullptr, size_t alignment = 0); ~ZlibInflatingReadBuffer() override; private: bool nextImpl() override; std::unique_ptr in; z_stream zstr; bool eof; }; }