/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtCore module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** 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. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or (at your option) the GNU General ** Public license version 3 or any later version approved by the KDE Free ** Qt Foundation. The licenses are as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-2.0.html and ** https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #ifndef QTCONCURRENT_FUNCTIONWRAPPERS_H #define QTCONCURRENT_FUNCTIONWRAPPERS_H #include #include #if !defined(QT_NO_CONCURRENT) || defined(Q_CLANG_QDOC) QT_BEGIN_NAMESPACE namespace QtConcurrent { template class FunctionWrapper0 { public: typedef T (*FunctionPointerType)(); typedef T result_type; inline FunctionWrapper0(FunctionPointerType _functionPointer) :functionPointer(_functionPointer) { } inline T operator()() { return functionPointer(); } private: FunctionPointerType functionPointer; }; template class FunctionWrapper1 { public: typedef T (*FunctionPointerType)(U u); typedef T result_type; inline FunctionWrapper1(FunctionPointerType _functionPointer) :functionPointer(_functionPointer) { } inline T operator()(U u) { return functionPointer(u); } private: FunctionPointerType functionPointer; }; template class FunctionWrapper2 { public: typedef T (*FunctionPointerType)(U u, V v); typedef T result_type; inline FunctionWrapper2(FunctionPointerType _functionPointer) :functionPointer(_functionPointer) { } inline T operator()(U u, V v) { return functionPointer(u, v); } private: FunctionPointerType functionPointer; }; template class MemberFunctionWrapper { public: typedef T (C::*FunctionPointerType)(); typedef T result_type; inline MemberFunctionWrapper(FunctionPointerType _functionPointer) :functionPointer(_functionPointer) { } inline T operator()(C &c) { return (c.*functionPointer)(); } private: FunctionPointerType functionPointer; }; template class MemberFunctionWrapper1 { public: typedef T (C::*FunctionPointerType)(U); typedef T result_type; inline MemberFunctionWrapper1(FunctionPointerType _functionPointer) : functionPointer(_functionPointer) { } inline T operator()(C &c, U u) { return (c.*functionPointer)(u); } private: FunctionPointerType functionPointer; }; template class ConstMemberFunctionWrapper { public: typedef T (C::*FunctionPointerType)() const; typedef T result_type; inline ConstMemberFunctionWrapper(FunctionPointerType _functionPointer) :functionPointer(_functionPointer) { } inline T operator()(const C &c) const { return (c.*functionPointer)(); } private: FunctionPointerType functionPointer; }; } // namespace QtConcurrent. namespace QtPrivate { template const T& createFunctionWrapper(const T& t) { return t; } template QtConcurrent::FunctionWrapper1 createFunctionWrapper(T (*func)(U)) { return QtConcurrent::FunctionWrapper1(func); } template QtConcurrent::MemberFunctionWrapper createFunctionWrapper(T (C::*func)()) { return QtConcurrent::MemberFunctionWrapper(func); } template QtConcurrent::MemberFunctionWrapper1 createFunctionWrapper(T (C::*func)(U)) { return QtConcurrent::MemberFunctionWrapper1(func); } template QtConcurrent::ConstMemberFunctionWrapper createFunctionWrapper(T (C::*func)() const) { return QtConcurrent::ConstMemberFunctionWrapper(func); } #if defined(__cpp_noexcept_function_type) && __cpp_noexcept_function_type >= 201510 template QtConcurrent::FunctionWrapper1 createFunctionWrapper(T (*func)(U) noexcept) { return QtConcurrent::FunctionWrapper1(func); } template QtConcurrent::MemberFunctionWrapper createFunctionWrapper(T (C::*func)() noexcept) { return QtConcurrent::MemberFunctionWrapper(func); } template QtConcurrent::MemberFunctionWrapper1 createFunctionWrapper(T (C::*func)(U) noexcept) { return QtConcurrent::MemberFunctionWrapper1(func); } template QtConcurrent::ConstMemberFunctionWrapper createFunctionWrapper(T (C::*func)() const noexcept) { return QtConcurrent::ConstMemberFunctionWrapper(func); } #endif struct PushBackWrapper { typedef void result_type; template inline void operator()(C &c, const U &u) const { return c.push_back(u); } #ifdef Q_COMPILER_RVALUE_REFS template inline void operator()(C &c, U &&u) const { return c.push_back(u); } #endif }; template ::Value> struct LazyResultType { typedef typename Functor::result_type Type; }; template struct LazyResultType { typedef void Type; }; template struct ReduceResultType; template struct ReduceResultType { typedef U ResultType; }; template struct ReduceResultType { typedef C ResultType; }; #if defined(__cpp_noexcept_function_type) && __cpp_noexcept_function_type >= 201510 template struct ReduceResultType { typedef U ResultType; }; template struct ReduceResultType { typedef C ResultType; }; #endif template struct MapResultType { typedef typename LazyResultType::Type ResultType; }; template struct MapResultType { typedef U ResultType; }; template struct MapResultType { typedef T ResultType; }; #if defined(__cpp_noexcept_function_type) && __cpp_noexcept_function_type >= 201510 template struct MapResultType { typedef U ResultType; }; template struct MapResultType { typedef T ResultType; }; #endif #ifndef QT_NO_TEMPLATE_TEMPLATE_PARAMETERS template