diff options
| author | AlexSm <[email protected]> | 2024-01-04 15:09:05 +0100 |
|---|---|---|
| committer | GitHub <[email protected]> | 2024-01-04 15:09:05 +0100 |
| commit | dab291146f6cd7d35684e3a1150e5bb1c412982c (patch) | |
| tree | 36ef35f6cacb6432845a4a33f940c95871036b32 /contrib/clickhouse/src/Functions/flattenTuple.cpp | |
| parent | 63660ad5e7512029fd0218e7a636580695a24e1f (diff) | |
Library import 5, delete go dependencies (#832)
* Library import 5, delete go dependencies
* Fix yt client
Diffstat (limited to 'contrib/clickhouse/src/Functions/flattenTuple.cpp')
| -rw-r--r-- | contrib/clickhouse/src/Functions/flattenTuple.cpp | 68 |
1 files changed, 0 insertions, 68 deletions
diff --git a/contrib/clickhouse/src/Functions/flattenTuple.cpp b/contrib/clickhouse/src/Functions/flattenTuple.cpp deleted file mode 100644 index bde081b40a0..00000000000 --- a/contrib/clickhouse/src/Functions/flattenTuple.cpp +++ /dev/null @@ -1,68 +0,0 @@ -#include <Functions/IFunction.h> -#include <Functions/FunctionFactory.h> -#include <Functions/FunctionHelpers.h> -#include <DataTypes/DataTypeTuple.h> -#include <DataTypes/ObjectUtils.h> -#include <Columns/ColumnTuple.h> - -namespace DB -{ - -namespace ErrorCodes -{ - extern const int ILLEGAL_COLUMN; - extern const int ILLEGAL_TYPE_OF_ARGUMENT; -} - -namespace -{ - -class FunctionFlattenTuple : public IFunction -{ -public: - static constexpr auto name = "flattenTuple"; - static FunctionPtr create(ContextPtr) { return std::make_shared<FunctionFlattenTuple>(); } - - String getName() const override { return name; } - size_t getNumberOfArguments() const override { return 1; } - bool isSuitableForShortCircuitArgumentsExecution(const DataTypesWithConstInfo &) const override { return true; } - bool useDefaultImplementationForConstants() const override { return true; } - - DataTypePtr getReturnTypeImpl(const DataTypes & arguments) const override - { - const auto & type = arguments[0]; - const auto * type_tuple = checkAndGetDataType<DataTypeTuple>(type.get()); - if (!type_tuple || !type_tuple->haveExplicitNames()) - throw Exception(ErrorCodes::ILLEGAL_TYPE_OF_ARGUMENT, - "Argument for function '{}' must be Named Tuple. Got '{}'", - getName(), type->getName()); - - auto [paths, types] = flattenTuple(type); - Names names; - names.reserve(paths.size()); - for (const auto & path : paths) - names.push_back(path.getPath()); - - return std::make_shared<DataTypeTuple>(types, names); - } - - ColumnPtr executeImpl(const ColumnsWithTypeAndName & arguments, const DataTypePtr &, size_t /*input_rows_count*/) const override - { - auto column = arguments.at(0).column; - if (!checkAndGetColumn<ColumnTuple>(column.get())) - throw Exception(ErrorCodes::ILLEGAL_COLUMN, - "Illegal column {} of first argument of function {}. Expected ColumnTuple", - column->getName(), getName()); - - return flattenTuple(column); - } -}; - -} - -REGISTER_FUNCTION(FlattenTuple) -{ - factory.registerFunction<FunctionFlattenTuple>(); -} - -} |
