#pragma once #include /// Common helper methods for implementation of different columns. namespace DB { namespace ErrorCodes { extern const int LOGICAL_ERROR; } /// Counts how many bytes of `filt` are greater than zero. size_t countBytesInFilter(const IColumn::Filter & filt); /// Returns vector with num_columns elements. vector[i] is the count of i values in selector. /// Selector must contain values from 0 to num_columns - 1. NOTE: this is not checked. std::vector countColumnsSizeInSelector(IColumn::ColumnIndex num_columns, const IColumn::Selector & selector); /// Returns true, if the memory contains only zeros. bool memoryIsZero(const void * data, size_t size); /// The general implementation of `filter` function for ColumnArray and ColumnString. template void filterArraysImpl( const PaddedPODArray & src_elems, const IColumn::Offsets & src_offsets, PaddedPODArray & res_elems, IColumn::Offsets & res_offsets, const IColumn::Filter & filt, ssize_t result_size_hint); /// Same as above, but not fills res_offsets. template void filterArraysImplOnlyData( const PaddedPODArray & src_elems, const IColumn::Offsets & src_offsets, PaddedPODArray & res_elems, const IColumn::Filter & filt, ssize_t result_size_hint); namespace detail { template const PaddedPODArray * getIndexesData(const IColumn & indexes); } /// Check limit <= indexes->size() and call column.indexImpl(const PaddedPodArray & indexes, UInt64 limit). template ColumnPtr selectIndexImpl(const Column & column, const IColumn & indexes, UInt64 limit) { if (limit == 0) limit = indexes.size(); if (indexes.size() < limit) throw Exception("Size of indexes is less than required.", ErrorCodes::SIZES_OF_COLUMNS_DOESNT_MATCH); if (auto * data_uint8 = detail::getIndexesData(indexes)) return column.template indexImpl(*data_uint8, limit); else if (auto * data_uint16 = detail::getIndexesData(indexes)) return column.template indexImpl(*data_uint16, limit); else if (auto * data_uint32 = detail::getIndexesData(indexes)) return column.template indexImpl(*data_uint32, limit); else if (auto * data_uint64 = detail::getIndexesData(indexes)) return column.template indexImpl(*data_uint64, limit); else throw Exception("Indexes column for IColumn::select must be ColumnUInt, got" + indexes.getName(), ErrorCodes::LOGICAL_ERROR); } #define INSTANTIATE_INDEX_IMPL(Column) \ template ColumnPtr Column::indexImpl(const PaddedPODArray & indexes, UInt64 limit) const; \ template ColumnPtr Column::indexImpl(const PaddedPODArray & indexes, UInt64 limit) const; \ template ColumnPtr Column::indexImpl(const PaddedPODArray & indexes, UInt64 limit) const; \ template ColumnPtr Column::indexImpl(const PaddedPODArray & indexes, UInt64 limit) const; }