diff options
author | Marco Poletti <poletti.marco@gmail.com> | 2020-09-20 12:04:41 -0700 |
---|---|---|
committer | Marco Poletti <poletti.marco@gmail.com> | 2020-09-20 12:04:41 -0700 |
commit | 928458857f4b85a0016c2d724486343b4660cb46 (patch) | |
tree | fe8ca51ef92c81b4055d0a5c9082b9b340eef3de /include | |
parent | c6d389dab4bcdb61ed1a3d9d0500f8d6feca1ecf (diff) | |
download | google-fruit-928458857f4b85a0016c2d724486343b4660cb46.tar.gz |
Support non-assignable (but movable) types in factory arguments when using registerFactory.
Diffstat (limited to 'include')
-rw-r--r-- | include/fruit/impl/component_functors.defn.h | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/include/fruit/impl/component_functors.defn.h b/include/fruit/impl/component_functors.defn.h index 83ef385..e6778b1 100644 --- a/include/fruit/impl/component_functors.defn.h +++ b/include/fruit/impl/component_functors.defn.h @@ -402,7 +402,7 @@ template <int numAssistedBefore, int numNonAssistedBefore, typename Arg> struct GetAssistedArg<numAssistedBefore, numNonAssistedBefore, Assisted<Arg>> { template <typename InjectedArgsTuple, typename UserProvidedArgsTuple> inline Arg operator()(InjectedArgsTuple&, UserProvidedArgsTuple& user_provided_args) { - return std::get<numAssistedBefore>(user_provided_args); + return std::move(std::get<numAssistedBefore>(user_provided_args)); } }; @@ -437,9 +437,9 @@ struct RegisterFactoryHelper { using Result = Eval<R>; void operator()(FixedSizeVector<ComponentStorageEntry>& entries) { auto function_provider = [](NakedInjectedArgs... args) { - auto injected_args = std::make_tuple(args...); - auto object_provider = [injected_args](NakedUserProvidedArgs... params) mutable { - auto user_provided_args = std::tie(params...); + std::tuple<NakedInjectedArgs...> injected_args{args...}; + auto object_provider = [=](NakedUserProvidedArgs... params) mutable { + std::tuple<NakedUserProvidedArgs...> user_provided_args{std::move(params)...}; // These are unused if they are 0-arg tuples. Silence the unused-variable warnings anyway. (void)injected_args; (void)user_provided_args; |