#pragma once #include #include namespace DB { /** Allows to access internal array of fixed-size column without cast to concrete type. * We will inherit ColumnVector and ColumnFixedString from this class instead of IColumn. * Assumes data layout of ColumnVector, ColumnFixedString and PODArray. * * Why it is needed? * * There are some algorithms that specialize on the size of data type but doesn't care about concrete type. * The same specialization may work for UInt64, Int64, Float64, FixedString(8), if it only does byte moving and hashing. * To avoid code bloat and compile time increase, we can use single template instantiation for these cases * and just static_cast pointer to some single column type (e. g. ColumnUInt64) assuming that all types have identical memory layout. * * But this static_cast (downcast to unrelated type) is illegal according to the C++ standard and UBSan warns about it. * To allow functional tests to work under UBSan we have to separate some base class that will present the memory layout in explicit way, * and we will do static_cast to this class. */ class ColumnFixedSizeHelper : public IColumn { public: template const char * getRawDataBegin() const { return reinterpret_cast, PADDING_FOR_SIMD - 1, PADDING_FOR_SIMD> *>( reinterpret_cast(this) + sizeof(*this)) ->raw_data(); } template void insertRawData(const char * ptr) { return reinterpret_cast, PADDING_FOR_SIMD - 1, PADDING_FOR_SIMD> *>( reinterpret_cast(this) + sizeof(*this)) ->push_back_raw(ptr); } }; }