#pragma once #include #include namespace DB { /* * Calculates the hash from the read data. When reading, the data is read from the nested ReadBuffer. * Small pieces are copied into its own memory. */ class HashingReadBuffer : public IHashingBuffer { public: HashingReadBuffer(ReadBuffer & in_, size_t block_size = DBMS_DEFAULT_HASHING_BLOCK_SIZE) : IHashingBuffer(block_size), in(in_) { working_buffer = in.buffer(); pos = in.position(); /// calculate hash from the data already read if (working_buffer.size()) { calculateHash(pos, working_buffer.end() - pos); } } private: bool nextImpl() override { in.position() = pos; bool res = in.next(); working_buffer = in.buffer(); pos = in.position(); calculateHash(working_buffer.begin(), working_buffer.size()); return res; } private: ReadBuffer & in; }; }