// 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/Functions/bitAnd.cpp // and modified by Doris #include #include "common/status.h" #include "vec/columns/column.h" #include "vec/columns/column_string.h" #include "vec/columns/column_vector.h" #include "vec/common/pod_array_fwd.h" #include "vec/core/types.h" #include "vec/data_types/data_type_number.h" #include "vec/data_types/number_traits.h" #include "vec/functions/function_binary_arithmetic.h" #include "vec/functions/function_totype.h" #include "vec/functions/function_unary_arithmetic.h" #include "vec/functions/simple_function_factory.h" namespace doris::vectorized { struct NameBitAnd { static constexpr auto name = "bitand"; }; template struct BitAndImpl { using ResultType = typename NumberTraits::ResultOfBit::Type; template static inline Result apply(A a, B b) { return static_cast(a) & static_cast(b); } }; struct NameBitNot { static constexpr auto name = "bitnot"; }; template struct BitNotImpl { using ResultType = typename NumberTraits::ResultOfBitNot::Type; static inline ResultType apply(A a) { return ~static_cast(a); } }; struct NameBitOr { static constexpr auto name = "bitor"; }; template struct BitOrImpl { using ResultType = typename NumberTraits::ResultOfBit::Type; template static inline Result apply(A a, B b) { return static_cast(a) | static_cast(b); } }; struct NameBitXor { static constexpr auto name = "bitxor"; }; template struct BitXorImpl { using ResultType = typename NumberTraits::ResultOfBit::Type; template static inline Result apply(A a, B b) { return static_cast(a) ^ static_cast(b); } }; struct NameBitLength { static constexpr auto name = "bit_length"; }; struct BitLengthImpl { using ReturnType = DataTypeInt32; static constexpr auto TYPE_INDEX = TypeIndex::String; using Type = String; using ReturnColumnType = ColumnVector; static Status vector(const ColumnString::Chars& data, const ColumnString::Offsets& offsets, PaddedPODArray& res) { auto size = offsets.size(); res.resize(size); for (int i = 0; i < size; ++i) { int str_size = offsets[i] - offsets[i - 1]; res[i] = (str_size * 8); } return Status::OK(); } }; using FunctionBitAnd = FunctionBinaryArithmetic; using FunctionBitNot = FunctionUnaryArithmetic; using FunctionBitOr = FunctionBinaryArithmetic; using FunctionBitXor = FunctionBinaryArithmetic; using FunctionBitLength = FunctionUnaryToType; void register_function_bit(SimpleFunctionFactory& factory) { factory.register_function(); factory.register_function(); factory.register_function(); factory.register_function(); factory.register_function(); } } // namespace doris::vectorized