[pipeline](dategen) Support datagen node (#14835)
This commit is contained in:
@ -28,6 +28,7 @@ set(PIPELINE_FILES
|
||||
task_scheduler.cpp
|
||||
exec/operator.cpp
|
||||
exec/scan_operator.cpp
|
||||
exec/datagen_operator.cpp
|
||||
exec/empty_set_operator.cpp
|
||||
exec/exchange_source_operator.cpp
|
||||
exec/exchange_sink_operator.cpp
|
||||
|
||||
38
be/src/pipeline/exec/datagen_operator.cpp
Normal file
38
be/src/pipeline/exec/datagen_operator.cpp
Normal file
@ -0,0 +1,38 @@
|
||||
// Licensed to the Apache Software Foundation (ASF) under one
|
||||
// or more contributor license agreements. See the NOTICE file
|
||||
// distributed with this work for additional information
|
||||
// regarding copyright ownership. The ASF licenses this file
|
||||
// to you under the Apache License, Version 2.0 (the
|
||||
// "License"); you may not use this file except in compliance
|
||||
// with the License. You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing,
|
||||
// software distributed under the License is distributed on an
|
||||
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
// KIND, either express or implied. See the License for the
|
||||
// specific language governing permissions and limitations
|
||||
// under the License.
|
||||
|
||||
#include "datagen_operator.h"
|
||||
|
||||
#include "vec/exec/vdata_gen_scan_node.h"
|
||||
|
||||
namespace doris::pipeline {
|
||||
|
||||
OPERATOR_CODE_GENERATOR(DataGenOperator, Operator)
|
||||
|
||||
Status DataGenOperator::open(RuntimeState* state) {
|
||||
SCOPED_TIMER(_runtime_profile->total_time_counter());
|
||||
RETURN_IF_ERROR(Operator::open(state));
|
||||
return _node->open(state);
|
||||
}
|
||||
|
||||
Status DataGenOperator::close(RuntimeState* state) {
|
||||
RETURN_IF_ERROR(Operator::close(state));
|
||||
_node->close(state);
|
||||
return Status::OK();
|
||||
}
|
||||
|
||||
} // namespace doris::pipeline
|
||||
48
be/src/pipeline/exec/datagen_operator.h
Normal file
48
be/src/pipeline/exec/datagen_operator.h
Normal file
@ -0,0 +1,48 @@
|
||||
// Licensed to the Apache Software Foundation (ASF) under one
|
||||
// or more contributor license agreements. See the NOTICE file
|
||||
// distributed with this work for additional information
|
||||
// regarding copyright ownership. The ASF licenses this file
|
||||
// to you under the Apache License, Version 2.0 (the
|
||||
// "License"); you may not use this file except in compliance
|
||||
// with the License. You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing,
|
||||
// software distributed under the License is distributed on an
|
||||
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||
// KIND, either express or implied. See the License for the
|
||||
// specific language governing permissions and limitations
|
||||
// under the License.
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <utility>
|
||||
|
||||
#include "operator.h"
|
||||
|
||||
namespace doris::vectorized {
|
||||
class VDataGenFunctionScanNode;
|
||||
} // namespace doris::vectorized
|
||||
|
||||
namespace doris::pipeline {
|
||||
|
||||
class DataGenOperatorBuilder : public OperatorBuilder<vectorized::VDataGenFunctionScanNode> {
|
||||
public:
|
||||
DataGenOperatorBuilder(int32_t id, ExecNode* exec_node);
|
||||
bool is_source() const override { return true; }
|
||||
OperatorPtr build_operator() override;
|
||||
};
|
||||
|
||||
class DataGenOperator : public Operator<DataGenOperatorBuilder> {
|
||||
public:
|
||||
DataGenOperator(OperatorBuilderBase* operator_builder, ExecNode* datagen_node);
|
||||
|
||||
bool can_read() override { return true; };
|
||||
|
||||
Status open(RuntimeState* state) override;
|
||||
|
||||
Status close(RuntimeState* state) override;
|
||||
};
|
||||
|
||||
} // namespace doris::pipeline
|
||||
@ -23,6 +23,7 @@
|
||||
#include "exec/exec_node.h"
|
||||
#include "runtime/runtime_state.h"
|
||||
#include "vec/core/block.h"
|
||||
#include "vec/exec/vdata_gen_scan_node.h"
|
||||
|
||||
#define OPERATOR_CODE_GENERATOR(NAME, SUBCLASS) \
|
||||
NAME##Builder::NAME##Builder(int32_t id, ExecNode* exec_node) \
|
||||
|
||||
@ -23,6 +23,7 @@
|
||||
#include "exec/aggregation_sink_operator.h"
|
||||
#include "exec/aggregation_source_operator.h"
|
||||
#include "exec/data_sink.h"
|
||||
#include "exec/datagen_operator.h"
|
||||
#include "exec/empty_set_operator.h"
|
||||
#include "exec/exchange_sink_operator.h"
|
||||
#include "exec/exchange_source_operator.h"
|
||||
@ -298,6 +299,12 @@ Status PipelineFragmentContext::_build_pipelines(ExecNode* node, PipelinePtr cur
|
||||
RETURN_IF_ERROR(cur_pipe->add_operator(operator_t));
|
||||
break;
|
||||
}
|
||||
case TPlanNodeType::DATA_GEN_SCAN_NODE: {
|
||||
OperatorBuilderPtr operator_t =
|
||||
std::make_shared<DataGenOperatorBuilder>(next_operator_builder_id(), node);
|
||||
RETURN_IF_ERROR(cur_pipe->add_operator(operator_t));
|
||||
break;
|
||||
}
|
||||
case TPlanNodeType::AGGREGATION_NODE: {
|
||||
auto* agg_node = assert_cast<vectorized::AggregationNode*>(node);
|
||||
auto new_pipe = add_pipeline();
|
||||
|
||||
Reference in New Issue
Block a user