diff options
Diffstat (limited to 'src/libs/installer/runextensions.h')
-rw-r--r-- | src/libs/installer/runextensions.h | 378 |
1 files changed, 32 insertions, 346 deletions
diff --git a/src/libs/installer/runextensions.h b/src/libs/installer/runextensions.h index fd76db060..9c7147141 100644 --- a/src/libs/installer/runextensions.h +++ b/src/libs/installer/runextensions.h @@ -1,6 +1,6 @@ /************************************************************************** ** -** Copyright (C) 2017 The Qt Company Ltd. +** Copyright (C) 2023 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the Qt Installer Framework. @@ -37,384 +37,70 @@ QT_BEGIN_NAMESPACE namespace QtConcurrent { -template <typename T, typename FunctionPointer> -class StoredInterfaceFunctionCall0 : public QRunnable +template <typename T, typename FunctionPointer, typename... Args> +class StoredInterfaceFunctionCall : public QRunnable { public: - StoredInterfaceFunctionCall0(void (fn)(QFutureInterface<T> &)) - : fn(fn) { } + StoredInterfaceFunctionCall(void (fn)(QFutureInterface<T> &, Args...), const Args&&... args) + : m_fn(fn), m_args(std::make_tuple(std::forward<Args>(args)...)) { } QFuture<T> start() { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); + m_futureInterface.reportStarted(); + QFuture<T> future = m_futureInterface.future(); QThreadPool::globalInstance()->start(this); return future; } - void run() + void run() override { - fn(futureInterface); - futureInterface.reportFinished(); + fn(m_futureInterface, std::forward<Args>(m_args)...); + m_futureInterface.reportFinished(); } private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - + QFutureInterface<T> m_futureInterface; + FunctionPointer m_fn; + std::tuple<Args...> m_args; }; -template <typename T, typename FunctionPointer, typename Class> -class StoredInterfaceMemberFunctionCall0 : public QRunnable +template <typename T, typename FunctionPointer, typename Class, typename... Args> +class StoredInterfaceMemberFunctionCall : public QRunnable { public: - StoredInterfaceMemberFunctionCall0(void (Class::*fn)(QFutureInterface<T> &), Class *object) - : fn(fn), object(object) { } + StoredInterfaceMemberFunctionCall(void (Class::*fn)(QFutureInterface<T> &, Args...), Class *object, const Args&&... args) + : m_fn(fn), m_object(object), m_args(std::make_tuple(std::forward<Args>(args)...)) { } QFuture<T> start() { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); + m_futureInterface.reportStarted(); + QFuture<T> future = m_futureInterface.future(); QThreadPool::globalInstance()->start(this); return future; } - void run() + void run() override { - (object->*fn)(futureInterface); - futureInterface.reportFinished(); + (m_object->*m_fn)(m_futureInterface, std::forward<Args>(m_args)...); + m_futureInterface.reportFinished(); } private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Class *object; - + QFutureInterface<T> m_futureInterface; + FunctionPointer m_fn; + Class *m_object; + std::tuple<Args...> m_args; }; -template <typename T, typename FunctionPointer, typename Arg1> -class StoredInterfaceFunctionCall1 : public QRunnable +template <typename T, typename... Args> +QFuture<T> run(void (*functionPointer)(QFutureInterface<T> &, Args...), Args... args) { -public: - StoredInterfaceFunctionCall1(void (fn)(QFutureInterface<T> &, Arg1), const Arg1 &arg1) - : fn(fn), arg1(arg1) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - fn(futureInterface, arg1); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Arg1 arg1; -}; -template <typename T, typename FunctionPointer, typename Class, typename Arg1> -class StoredInterfaceMemberFunctionCall1 : public QRunnable -{ -public: - StoredInterfaceMemberFunctionCall1(void (Class::*fn)(QFutureInterface<T> &, Arg1), Class *object, const Arg1 &arg1) - : fn(fn), object(object), arg1(arg1) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - (object->*fn)(futureInterface, arg1); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Class *object; - Arg1 arg1; -}; - -template <typename T, typename FunctionPointer, typename Arg1, typename Arg2> -class StoredInterfaceFunctionCall2 : public QRunnable -{ -public: - StoredInterfaceFunctionCall2(void (fn)(QFutureInterface<T> &, Arg1, Arg2), const Arg1 &arg1, const Arg2 &arg2) - : fn(fn), arg1(arg1), arg2(arg2) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - fn(futureInterface, arg1, arg2); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Arg1 arg1; Arg2 arg2; -}; -template <typename T, typename FunctionPointer, typename Class, typename Arg1, typename Arg2> -class StoredInterfaceMemberFunctionCall2 : public QRunnable -{ -public: - StoredInterfaceMemberFunctionCall2(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2), Class *object, const Arg1 &arg1, const Arg2 &arg2) - : fn(fn), object(object), arg1(arg1), arg2(arg2) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - (object->*fn)(futureInterface, arg1, arg2); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Class *object; - Arg1 arg1; Arg2 arg2; -}; - -template <typename T, typename FunctionPointer, typename Arg1, typename Arg2, typename Arg3> -class StoredInterfaceFunctionCall3 : public QRunnable -{ -public: - StoredInterfaceFunctionCall3(void (fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3), const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3) - : fn(fn), arg1(arg1), arg2(arg2), arg3(arg3) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - fn(futureInterface, arg1, arg2, arg3); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Arg1 arg1; Arg2 arg2; Arg3 arg3; -}; -template <typename T, typename FunctionPointer, typename Class, typename Arg1, typename Arg2, typename Arg3> -class StoredInterfaceMemberFunctionCall3 : public QRunnable -{ -public: - StoredInterfaceMemberFunctionCall3(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3), Class *object, const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3) - : fn(fn), object(object), arg1(arg1), arg2(arg2), arg3(arg3) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - (object->*fn)(futureInterface, arg1, arg2, arg3); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Class *object; - Arg1 arg1; Arg2 arg2; Arg3 arg3; -}; - -template <typename T, typename FunctionPointer, typename Arg1, typename Arg2, typename Arg3, typename Arg4> -class StoredInterfaceFunctionCall4 : public QRunnable -{ -public: - StoredInterfaceFunctionCall4(void (fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4), const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4) - : fn(fn), arg1(arg1), arg2(arg2), arg3(arg3), arg4(arg4) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - fn(futureInterface, arg1, arg2, arg3, arg4); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Arg1 arg1; Arg2 arg2; Arg3 arg3; Arg4 arg4; -}; -template <typename T, typename FunctionPointer, typename Class, typename Arg1, typename Arg2, typename Arg3, typename Arg4> -class StoredInterfaceMemberFunctionCall4 : public QRunnable -{ -public: - StoredInterfaceMemberFunctionCall4(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4), Class *object, const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4) - : fn(fn), object(object), arg1(arg1), arg2(arg2), arg3(arg3), arg4(arg4) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - (object->*fn)(futureInterface, arg1, arg2, arg3, arg4); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Class *object; - Arg1 arg1; Arg2 arg2; Arg3 arg3; Arg4 arg4; -}; - -template <typename T, typename FunctionPointer, typename Arg1, typename Arg2, typename Arg3, typename Arg4, typename Arg5> -class StoredInterfaceFunctionCall5 : public QRunnable -{ -public: - StoredInterfaceFunctionCall5(void (fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4, Arg5), const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4, const Arg5 &arg5) - : fn(fn), arg1(arg1), arg2(arg2), arg3(arg3), arg4(arg4), arg5(arg5) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - fn(futureInterface, arg1, arg2, arg3, arg4, arg5); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Arg1 arg1; Arg2 arg2; Arg3 arg3; Arg4 arg4; Arg5 arg5; -}; -template <typename T, typename FunctionPointer, typename Class, typename Arg1, typename Arg2, typename Arg3, typename Arg4, typename Arg5> -class StoredInterfaceMemberFunctionCall5 : public QRunnable -{ -public: - StoredInterfaceMemberFunctionCall5(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4, Arg5), Class *object, const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4, const Arg5 &arg5) - : fn(fn), object(object), arg1(arg1), arg2(arg2), arg3(arg3), arg4(arg4), arg5(arg5) { } - - QFuture<T> start() - { - futureInterface.reportStarted(); - QFuture<T> future = futureInterface.future(); - QThreadPool::globalInstance()->start(this); - return future; - } - - void run() - { - (object->*fn)(futureInterface, arg1, arg2, arg3, arg4, arg5); - futureInterface.reportFinished(); - } -private: - QFutureInterface<T> futureInterface; - FunctionPointer fn; - Class *object; - Arg1 arg1; Arg2 arg2; Arg3 arg3; Arg4 arg4; Arg5 arg5; -}; - -template <typename T> -QFuture<T> run(void (*functionPointer)(QFutureInterface<T> &)) -{ - return (new StoredInterfaceFunctionCall0<T, void (*)(QFutureInterface<T> &)>(functionPointer))->start(); -} -template <typename T, typename Arg1> -QFuture<T> run(void (*functionPointer)(QFutureInterface<T> &, Arg1), const Arg1 &arg1) -{ - return (new StoredInterfaceFunctionCall1<T, void (*)(QFutureInterface<T> &, Arg1), Arg1>(functionPointer, arg1))->start(); -} -template <typename T, typename Arg1, typename Arg2> -QFuture<T> run(void (*functionPointer)(QFutureInterface<T> &, Arg1, Arg2), const Arg1 &arg1, const Arg2 &arg2) -{ - return (new StoredInterfaceFunctionCall2<T, void (*)(QFutureInterface<T> &, Arg1, Arg2), Arg1, Arg2>(functionPointer, arg1, arg2))->start(); -} -template <typename T, typename Arg1, typename Arg2, typename Arg3> -QFuture<T> run(void (*functionPointer)(QFutureInterface<T> &, Arg1, Arg2, Arg3), const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3) -{ - return (new StoredInterfaceFunctionCall3<T, void (*)(QFutureInterface<T> &, Arg1, Arg2, Arg3), Arg1, Arg2, Arg3>(functionPointer, arg1, arg2, arg3))->start(); -} -template <typename T, typename Arg1, typename Arg2, typename Arg3, typename Arg4> -QFuture<T> run(void (*functionPointer)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4), const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4) -{ - return (new StoredInterfaceFunctionCall4<T, void (*)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4), Arg1, Arg2, Arg3, Arg4>(functionPointer, arg1, arg2, arg3, arg4))->start(); -} -template <typename T, typename Arg1, typename Arg2, typename Arg3, typename Arg4, typename Arg5> -QFuture<T> run(void (*functionPointer)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4, Arg5), const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4, const Arg5 &arg5) -{ - return (new StoredInterfaceFunctionCall5<T, void (*)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4, Arg5), Arg1, Arg2, Arg3, Arg4, Arg5>(functionPointer, arg1, arg2, arg3, arg4, arg5))->start(); -} - -template <typename Class, typename T> -QFuture<T> run(void (Class::*fn)(QFutureInterface<T> &), Class *object) -{ - return (new StoredInterfaceMemberFunctionCall0<T, void (Class::*)(QFutureInterface<T> &), Class>(fn, object))->start(); -} - -template <typename Class, typename T, typename Arg1> -QFuture<T> run(void (Class::*fn)(QFutureInterface<T> &, Arg1), Class *object, Arg1 arg1) -{ - return (new StoredInterfaceMemberFunctionCall1<T, void (Class::*)(QFutureInterface<T> &, Arg1), Class, Arg1>(fn, object, arg1))->start(); -} - -template <typename Class, typename T, typename Arg1, typename Arg2> -QFuture<T> run(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2), Class *object, const Arg1 &arg1, const Arg2 &arg2) -{ - return (new StoredInterfaceMemberFunctionCall2<T, void (Class::*)(QFutureInterface<T> &, Arg1, Arg2), Class, Arg1, Arg2>(fn, object, arg1, arg2))->start(); + return (new StoredInterfaceFunctionCall<T, void (*)(QFutureInterface<T> &, Args...), Args...>(functionPointer, args...))->start(); } -template <typename Class, typename T, typename Arg1, typename Arg2, typename Arg3> -QFuture<T> run(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3), Class *object, const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3) +template <typename Class, typename T, typename... Args> +QFuture<T> run(void (Class::*fn)(QFutureInterface<T> &, Args...), Class *object, Args... args) { - return (new StoredInterfaceMemberFunctionCall3<T, void (Class::*)(QFutureInterface<T> &, Arg1, Arg2, Arg3), Class, Arg1, Arg2, Arg3>(fn, object, arg1, arg2, arg3))->start(); + return (new StoredInterfaceMemberFunctionCall<T, void (Class::*)(QFutureInterface<T> &, Args...), Class, Args...>(fn, object, args...))->start(); } -template <typename Class, typename T, typename Arg1, typename Arg2, typename Arg3, typename Arg4> -QFuture<T> run(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4), Class *object, const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4) -{ - return (new StoredInterfaceMemberFunctionCall4<T, void (Class::*)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4), Class, Arg1, Arg2, Arg3, Arg4>(fn, object, arg1, arg2, arg3, arg4))->start(); -} - -template <typename Class, typename T, typename Arg1, typename Arg2, typename Arg3, typename Arg4, typename Arg5> -QFuture<T> run(void (Class::*fn)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4, Arg5), Class *object, const Arg1 &arg1, const Arg2 &arg2, const Arg3 &arg3, const Arg4 &arg4, const Arg5 &arg5) -{ - return (new StoredInterfaceMemberFunctionCall5<T, void (Class::*)(QFutureInterface<T> &, Arg1, Arg2, Arg3, Arg4, Arg5), Class, Arg1, Arg2, Arg3, Arg4, Arg5>(fn, object, arg1, arg2, arg3, arg4, arg5))->start(); -} } // namespace QtConcurrent QT_END_NAMESPACE |