/**************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Contact: http://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 http://www.qt.io/terms-conditions. For further ** information use the contact form at http://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 2.1 or version 3 as published by the Free ** Software Foundation and appearing in the file LICENSE.LGPLv21 and ** LICENSE.LGPLv3 included in the packaging of this file. Please review the ** following information to ensure the GNU Lesser General Public License ** requirements will be met: https://www.gnu.org/licenses/lgpl.html and ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** As a special exception, The Qt Company gives you certain additional ** rights. These rights are described in The Qt Company LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU General Public License version 3.0 requirements will be ** met: http://www.gnu.org/copyleft/gpl.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #ifndef QTCONCURRENT_FUNCTIONWRAPPERS_H #define QTCONCURRENT_FUNCTIONWRAPPERS_H #include #ifndef QT_NO_CONCURRENT QT_BEGIN_HEADER QT_BEGIN_NAMESPACE QT_MODULE(Core) #ifndef qdoc 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); } 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; }; template struct MapResultType { typedef typename LazyResultType::Type ResultType; }; template struct MapResultType { typedef U ResultType; }; template struct MapResultType { typedef T ResultType; }; #ifndef QT_NO_TEMPLATE_TEMPLATE_PARAMETERS template