ClickHouse/dbms/src/DataStreams/SquashingBlockInputStream.h

35 lines
742 B
C++
Raw Normal View History

#pragma once
#include <DataStreams/IProfilingBlockInputStream.h>
#include <DataStreams/SquashingTransform.h>
namespace DB
{
2016-07-07 01:57:48 +00:00
/** Merging consecutive blocks of stream to specified minimum size.
*/
class SquashingBlockInputStream : public IProfilingBlockInputStream
{
public:
SquashingBlockInputStream(BlockInputStreamPtr & src, size_t min_block_size_rows, size_t min_block_size_bytes);
String getName() const override { return "Squashing"; }
String getID() const override
{
std::stringstream res;
res << "Squashing(" << children.at(0)->getID() << ")";
return res.str();
}
protected:
Block readImpl() override;
private:
SquashingTransform transform;
bool all_read = false;
};
}