summaryrefslogtreecommitdiffstats
path: root/src/concurrent
diff options
context:
space:
mode:
authorJarek Kobus <jaroslaw.kobus@qt.io>2020-10-27 12:12:11 +0100
committerJarek Kobus <jaroslaw.kobus@qt.io>2020-10-30 17:23:06 +0100
commit0cee264b3a901716d07fdc2cef1b8bed3718674f (patch)
tree456b61b2772841aa3c875cb7703c8e323a437525 /src/concurrent
parent17848a667b30009f5b37769b5f7d9038f115579c (diff)
Don't use pointers or references to functions from std library
Task-number: QTBUG-87719 Change-Id: I7331b7a0095fd41261173d309215f897542669ed Reviewed-by: Sona Kurazyan <sona.kurazyan@qt.io>
Diffstat (limited to 'src/concurrent')
-rw-r--r--src/concurrent/qtconcurrentstoredfunctioncall.h18
1 files changed, 11 insertions, 7 deletions
diff --git a/src/concurrent/qtconcurrentstoredfunctioncall.h b/src/concurrent/qtconcurrentstoredfunctioncall.h
index f52b6e2efc..98ce28f6dc 100644
--- a/src/concurrent/qtconcurrentstoredfunctioncall.h
+++ b/src/concurrent/qtconcurrentstoredfunctioncall.h
@@ -66,9 +66,10 @@ struct NonMemberFunctionResolver<Function, PromiseType, Args...>
static_assert(std::is_void_v<std::invoke_result_t<std::decay_t<Function>, QPromise<PromiseType> &, std::decay_t<Args>...>>,
"The function must return void type.");
- static constexpr auto invokePointer()
+ static constexpr void invoke(std::decay_t<Function> function, QPromise<PromiseType> &promise,
+ std::decay_t<Args>... args)
{
- return &std::invoke<std::decay_t<Function>, QPromise<PromiseType> &, std::decay_t<Args>...>;
+ std::invoke(function, promise, args...);
}
static Type initData(Function &&f, QPromise<PromiseType> &promise, Args &&...args)
{
@@ -88,9 +89,10 @@ struct MemberFunctionResolver<Function, PromiseType, Arg, Args...>
static_assert(std::is_void_v<std::invoke_result_t<std::decay_t<Function>, std::decay_t<Arg>, QPromise<PromiseType> &, std::decay_t<Args>...>>,
"The function must return void type.");
- static constexpr auto invokePointer()
+ static constexpr void invoke(std::decay_t<Function> function, std::decay_t<Arg> object,
+ QPromise<PromiseType> &promise, std::decay_t<Args>... args)
{
- return &std::invoke<std::decay_t<Function>, std::decay_t<Arg>, QPromise<PromiseType> &, std::decay_t<Args>...>;
+ std::invoke(function, object, promise, args...);
}
static Type initData(Function &&f, QPromise<PromiseType> &promise, Arg &&fa, Args &&...args)
{
@@ -145,8 +147,10 @@ struct StoredFunctionCall : public RunFunctionTask<InvokeResultType<Function, Ar
protected:
void runFunctor() override
{
- constexpr auto invoke = &std::invoke<std::decay_t<Function>,
- std::decay_t<Args>...>;
+ constexpr auto invoke = [] (std::decay_t<Function> function,
+ std::decay_t<Args>... args) -> auto {
+ return std::invoke(function, args...);
+ };
if constexpr (std::is_void_v<InvokeResultType<Function, Args...>>)
std::apply(invoke, std::move(data));
@@ -177,7 +181,7 @@ struct StoredFunctionCallWithPromise : public RunFunctionTaskBase<PromiseType>
protected:
void runFunctor() override
{
- std::apply(Resolver::invokePointer(), std::move(data));
+ std::apply(Resolver::invoke, std::move(data));
}
private: