2018-05-24 01:02:16 +00:00
|
|
|
#include <Processors/ConcatProcessor.h>
|
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
|
|
|
ConcatProcessor::Status ConcatProcessor::prepare()
|
|
|
|
{
|
|
|
|
auto & output = outputs[0];
|
|
|
|
|
|
|
|
if (output.hasData())
|
|
|
|
return Status::PortFull;
|
|
|
|
|
|
|
|
if (!output.isNeeded())
|
|
|
|
{
|
|
|
|
for (auto & input : inputs)
|
|
|
|
input.setNotNeeded();
|
|
|
|
|
|
|
|
return Status::Unneeded;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (current_input == inputs.end())
|
|
|
|
return Status::Finished;
|
|
|
|
|
|
|
|
auto & input = *current_input;
|
|
|
|
|
|
|
|
input.setNeeded();
|
|
|
|
|
|
|
|
if (input.hasData())
|
|
|
|
{
|
|
|
|
output.push(input.pull());
|
|
|
|
}
|
|
|
|
|
|
|
|
if (input.isFinished())
|
|
|
|
{
|
|
|
|
input.setNotNeeded();
|
2018-05-24 02:39:22 +00:00
|
|
|
|
2018-05-24 01:02:16 +00:00
|
|
|
++current_input;
|
2018-05-24 02:39:22 +00:00
|
|
|
if (current_input == inputs.end())
|
2018-05-24 02:52:21 +00:00
|
|
|
{
|
|
|
|
output.setFinished();
|
2018-05-24 02:39:22 +00:00
|
|
|
return Status::Finished;
|
2018-05-24 02:52:21 +00:00
|
|
|
}
|
2018-05-24 02:39:22 +00:00
|
|
|
|
2018-05-24 01:02:16 +00:00
|
|
|
current_input->setNeeded();
|
|
|
|
}
|
|
|
|
|
2018-05-24 02:39:22 +00:00
|
|
|
return Status::NeedData;
|
2018-05-24 01:02:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|