ClickHouse/src/Processors/ConcatProcessor.h
2020-06-05 12:30:16 +03:00

33 lines
647 B
C++

#pragma once
#include <Processors/IProcessor.h>
namespace DB
{
/** Has arbitary non zero number of inputs and one output.
* All of them have the same structure.
*
* Pulls all data from first input, then all data from second input, etc...
* Doesn't do any heavy calculations.
* Preserves an order of data.
*/
class ConcatProcessor : public IProcessor
{
public:
ConcatProcessor(const Block & header, size_t num_inputs);
String getName() const override { return "Concat"; }
Status prepare() override;
OutputPort & getOutputPort() { return outputs.front(); }
private:
InputPorts::iterator current_input;
};
}