#pragma once #include #include #include #include namespace DB { /// Expand data by mask. After expanding data will satisfy the following: if we filter data /// by given mask, we get initial data. In places where mask[i] = 0 we insert default value. /// If inverted is true, we will work with inverted mask. This function is used in implementations of /// expand() method in IColumn interface. template void expandDataByMask(PaddedPODArray & data, const PaddedPODArray & mask, bool inverted, T default_value = T()); struct MaskInfo { bool has_ones; bool has_zeros; }; /// The next functions are used to extract UInt8 mask from a column, /// filtered by some condition (mask). We will use value from a column /// only when value in condition is 1. Column should satisfy the /// condition: sum(mask) = column.size() or mask.size() = column.size(). /// You can set flag 'inverted' to use inverted values /// from a column. You can also determine value that will be used when /// column value is Null (argument null_value). MaskInfo extractMask( PaddedPODArray & mask, const ColumnPtr & column, UInt8 null_value = 0); MaskInfo extractInvertedMask( PaddedPODArray & mask, const ColumnPtr & column, UInt8 null_value = 0); /// The same as extractMask, but fills /// nulls so that nulls[i] = 1 when column[i] = Null. MaskInfo extractMask( PaddedPODArray & mask, const ColumnPtr & column, PaddedPODArray * nulls, UInt8 null_value = 0); MaskInfo extractInvertedMask( PaddedPODArray & mask, const ColumnPtr & column, PaddedPODArray * nulls, UInt8 null_value = 0); /// Inplace inversion. void inverseMask(PaddedPODArray & mask, MaskInfo & mask_info); /// If given column is lazy executed argument (ColumnFunction with isShortCircuitArgument() = true), /// filter it by mask and then reduce. If inverted is true, we will work with inverted mask. /// mask_info is used for for optimization in cases when we have all zeros or all ones in mask, so /// in general case this info is not used and we can skip it. void maskedExecute( ColumnWithTypeAndName & column, const PaddedPODArray & mask, const MaskInfo & mask_info = {true, true}); /// If given column is lazy executed argument, reduce it. If empty is true, /// create an empty column with the execution result type. void executeColumnIfNeeded(ColumnWithTypeAndName & column, bool empty = false); /// Check if arguments contain lazy executed argument. If contain, return index of the last one, /// otherwise return -1. int checkShortCircuitArguments(const ColumnsWithTypeAndName & arguments); void copyMask(const PaddedPODArray & from, PaddedPODArray & to); }