/**************************************************************************** ** ** Copyright (C) 2022 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtConcurrent module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:COMM$ ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** $QT_END_LICENSE$ ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ** ******************************************************************************/ #ifndef QTCONCURRENT_FUNCTIONWRAPPERS_H #define QTCONCURRENT_FUNCTIONWRAPPERS_H #include #include #include #include #if !defined(QT_NO_CONCURRENT) || defined(Q_CLANG_QDOC) QT_BEGIN_NAMESPACE namespace QtPrivate { struct PushBackWrapper { template inline void operator()(C &c, const U &u) const { return c.push_back(u); } template inline void operator()(C &c, U &&u) const { return c.push_back(u); } }; // -- MapResultType template struct Argument { using Type = void; }; template struct Argument>::type> { using Type = std::decay_t().begin())>; }; template struct Argument>::type> { using Type = std::decay_t())>; }; template using ArgumentType = typename Argument::Type; template struct MapResult { static_assert(std::is_invocable_v, ArgumentType>, "It's not possible to invoke the function with passed argument."); using Type = std::invoke_result_t, ArgumentType>; }; template using MapResultType = typename MapResult::Type; // -- ReduceResultType template struct ReduceResultType; template struct ReduceResultType { using ResultType = U; }; template struct ReduceResultType { using ResultType = C; }; template struct ReduceResultType> { using ResultType = U; }; template struct ReduceResultType { using ResultType = typename std::tuple_element<0, std::tuple>::type; }; #if defined(__cpp_noexcept_function_type) && __cpp_noexcept_function_type >= 201510 template struct ReduceResultType { using ResultType = U; }; template struct ReduceResultType { using ResultType = C; }; #endif template inline constexpr bool isInitialValueCompatible_v = std::conjunction_v< std::is_convertible, std::negation, QtConcurrent::ReduceOption>>>; // -- MapSequenceResultType template struct MapSequenceResultType { static_assert(std::is_same_v>, "Couldn't deduce the output sequence type, you must specify it explicitly."); typedef InputSequence ResultType; }; template struct MapSequenceResultType { typedef QList> ResultType; }; #ifndef QT_NO_TEMPLATE_TEMPLATE_PARAMETERS template