mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-12 01:12:12 +00:00
31 lines
992 B
C++
31 lines
992 B
C++
#include <Processors/Port.h>
|
|
#include <Processors/IProcessor.h>
|
|
|
|
namespace DB
|
|
{
|
|
namespace ErrorCodes
|
|
{
|
|
extern const int LOGICAL_ERROR;
|
|
}
|
|
|
|
void connect(OutputPort & output, InputPort & input, bool reconnect)
|
|
{
|
|
if (!reconnect && input.state)
|
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "Port is already connected, (header: [{}])", input.header.dumpStructure());
|
|
|
|
if (!reconnect && output.state)
|
|
throw Exception(ErrorCodes::LOGICAL_ERROR, "Port is already connected, (header: [{}])", output.header.dumpStructure());
|
|
|
|
auto out_name = output.processor ? output.getProcessor().getName() : "null";
|
|
auto in_name = input.processor ? input.getProcessor().getName() : "null";
|
|
|
|
assertCompatibleHeader(output.getHeader(), input.getHeader(), fmt::format("function connect between {} and {}", out_name, in_name));
|
|
|
|
input.output_port = &output;
|
|
output.input_port = &input;
|
|
input.state = std::make_shared<Port::State>();
|
|
output.state = input.state;
|
|
}
|
|
|
|
}
|