blob: 092708f1a62986af175d9ef80525c9250be4d466 [file]
// 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.
// This file is copied from
// https://github.com/ClickHouse/ClickHouse/blob/master/src/Common/FieldVisitors.h
// and modified by Doris
#pragma once
#include "common/exception.h"
#include "common/status.h"
#include "vec/common/demangle.h"
#include "vec/core/accurate_comparison.h"
#include "vec/core/field.h"
#include "vec/core/types.h"
namespace doris::vectorized {
/** StaticVisitor (and its descendants) - class with overloaded operator() for all types of fields.
* You could call visitor for field using function 'apply_visitor'.
* Also "binary visitor" is supported - its operator() takes two arguments.
*/
template <typename R = void>
struct StaticVisitor {
using ResultType = R;
};
/// F is template parameter, to allow universal reference for field, that is useful for const and non-const values.
template <typename Visitor, typename F>
typename std::decay_t<Visitor>::ResultType apply_visitor(Visitor&& visitor, F&& field) {
switch (field.get_type()) {
case Field::Types::Null:
return visitor(field.template get<Null>());
case Field::Types::UInt64:
return visitor(field.template get<UInt64>());
case Field::Types::UInt128:
return visitor(field.template get<UInt128>());
case Field::Types::Int64:
return visitor(field.template get<Int64>());
case Field::Types::Float64:
return visitor(field.template get<Float64>());
case Field::Types::String:
return visitor(field.template get<String>());
case Field::Types::Array:
return visitor(field.template get<Array>());
case Field::Types::Tuple:
return visitor(field.template get<Tuple>());
case Field::Types::VariantMap:
return visitor(field.template get<VariantMap>());
case Field::Types::Decimal32:
return visitor(field.template get<DecimalField<Decimal32>>());
case Field::Types::Decimal64:
return visitor(field.template get<DecimalField<Decimal64>>());
case Field::Types::Decimal128V2:
return visitor(field.template get<DecimalField<Decimal128V2>>());
case Field::Types::Decimal128V3:
return visitor(field.template get<DecimalField<Decimal128V3>>());
case Field::Types::Decimal256:
return visitor(field.template get<DecimalField<Decimal256>>());
case Field::Types::JSONB:
return visitor(field.template get<JsonbField>());
case Field::Types::Variant:
return visitor(field.template get<VariantField>());
case Field::Types::IPv6:
return visitor(field.template get<IPv6>());
case Field::Types::Int128:
return visitor(field.template get<Int128>());
default:
throw doris::Exception(ErrorCode::INTERNAL_ERROR, "Bad type of Field {}",
static_cast<int>(field.get_type()));
__builtin_unreachable();
return {};
}
}
} // namespace doris::vectorized