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

34 lines
831 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:
KafkaBlockInputStream(StorageKafka & storage_, const Context & context_, const String & schema, size_t max_block_size_);
~KafkaBlockInputStream() override;
String getName() const override { return storage.getName(); }
Block readImpl() override { return children.back()->read(); }
Block getHeader() const override { return storage.getSampleBlock(); }
void readPrefixImpl() override;
void readSuffixImpl() override;
private:
StorageKafka & storage;
Context context;
2019-02-11 11:54:30 +00:00
UInt64 max_block_size;
BufferPtr buffer;
bool broken = true, claimed = false;
};
} // namespace DB