/**************************************************************************** ** ** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** 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 Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/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 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt 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 #include #ifndef QT_NO_CONCURRENT QT_BEGIN_NAMESPACE #ifndef Q_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