#include #include #include namespace DB { namespace ErrorCodes { extern const int NUMBER_OF_ARGUMENTS_DOESNT_MATCH; } class AggregateFunctionCombinatorForEach final : public IAggregateFunctionCombinator { public: String getName() const override { return "ForEach"; } DataTypes transformArguments(const DataTypes & arguments) const override { DataTypes nested_arguments; for (const auto & type : arguments) { if (const DataTypeArray * array = typeid_cast(type.get())) nested_arguments.push_back(array->getNestedType()); else throw Exception("Illegal type " + type->getName() + " of argument" " for aggregate function with " + getName() + " suffix. Must be array.", ErrorCodes::ILLEGAL_TYPE_OF_ARGUMENT); } return nested_arguments; } AggregateFunctionPtr transformAggregateFunction( const AggregateFunctionPtr & nested_function, const DataTypes & arguments, const Array &) const override { return std::make_shared(nested_function, arguments); } }; void registerAggregateFunctionCombinatorForEach(AggregateFunctionCombinatorFactory & factory) { factory.registerCombinator(std::make_shared()); } }