ClickHouse/dbms/src/Storages/Kafka/KafkaBlockInputStream.h

36 lines
812 B
C++
Raw Normal View History

#pragma once
2019-01-24 12:44:58 +00:00
#include <DataStreams/IBlockInputStream.h>
#include <Interpreters/Context.h>
#include <Storages/Kafka/StorageKafka.h>
namespace DB
{
2019-01-24 12:44:58 +00:00
class KafkaBlockInputStream : public IBlockInputStream
{
public:
2019-05-22 19:38:43 +00:00
KafkaBlockInputStream(StorageKafka & storage_, const Context & context_, const Names & columns, size_t max_block_size_);
~KafkaBlockInputStream() override;
String getName() const override { return storage.getName(); }
2019-05-22 19:38:43 +00:00
Block getHeader() const override;
void readPrefixImpl() override;
2019-05-22 19:38:43 +00:00
Block readImpl() override;
void readSuffixImpl() override;
private:
StorageKafka & storage;
Context context;
2019-05-22 19:38:43 +00:00
Names column_names;
2019-02-11 11:54:30 +00:00
UInt64 max_block_size;
ConsumerBufferPtr buffer;
MutableColumns virtual_columns;
bool broken = true, claimed = false;
};
}