#include #include #include namespace DB { template struct PlusImpl { using ResultType = typename NumberTraits::ResultOfAdditionMultiplication::Type; static const constexpr bool allow_decimal = true; template static inline Result apply(A a, B b) { /// Next everywhere, static_cast - so that there is no wrong result in expressions of the form Int64 c = UInt32(a) * Int32(-1). return static_cast(a) + b; } /// Apply operation and check overflow. It's used for Deciamal operations. @returns true if overflowed, false othervise. template static inline bool apply(A a, B b, Result & c) { return common::addOverflow(static_cast(a), b, c); } #if USE_EMBEDDED_COMPILER static constexpr bool compilable = true; static inline llvm::Value * compile(llvm::IRBuilder<> & b, llvm::Value * left, llvm::Value * right, bool) { return left->getType()->isIntegerTy() ? b.CreateAdd(left, right) : b.CreateFAdd(left, right); } #endif }; struct NamePlus { static constexpr auto name = "plus"; }; using FunctionPlus = FunctionBinaryArithmetic; void registerFunctionPlus(FunctionFactory & factory) { factory.registerFunction(); } }