#include #include #include #include #include namespace DB { InterpolateNode::InterpolateNode(std::shared_ptr expression_, QueryTreeNodePtr interpolate_expression_) : IQueryTreeNode(children_size) { if(expression_) expression_name = expression_->getIdentifier().getFullName(); children[expression_child_index] = std::move(expression_); children[interpolate_expression_child_index] = std::move(interpolate_expression_); } void InterpolateNode::dumpTreeImpl(WriteBuffer & buffer, FormatState & format_state, size_t indent) const { buffer << std::string(indent, ' ') << "INTERPOLATE id: " << format_state.getNodeId(this); buffer << '\n' << std::string(indent + 2, ' ') << "EXPRESSION\n"; getExpression()->dumpTreeImpl(buffer, format_state, indent + 4); buffer << '\n' << std::string(indent + 2, ' ') << "INTERPOLATE_EXPRESSION\n"; getInterpolateExpression()->dumpTreeImpl(buffer, format_state, indent + 4); } bool InterpolateNode::isEqualImpl(const IQueryTreeNode &, CompareOptions) const { /// No state in interpolate node return true; } void InterpolateNode::updateTreeHashImpl(HashState &, CompareOptions) const { /// No state in interpolate node } QueryTreeNodePtr InterpolateNode::cloneImpl() const { auto cloned = std::make_shared(nullptr /*expression*/, nullptr /*interpolate_expression*/); cloned->expression_name = expression_name; return cloned; } ASTPtr InterpolateNode::toASTImpl(const ConvertToASTOptions & options) const { auto result = std::make_shared(); if (const auto * identifier = getExpression()->as()) result->column = identifier->toAST(options)->getColumnName(); else result->column = expression_name; result->children.push_back(getInterpolateExpression()->toAST(options)); result->expr = result->children.back(); return result; } }