aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorMarco Poletti <poletti.marco@gmail.com>2020-09-20 12:04:41 -0700
committerMarco Poletti <poletti.marco@gmail.com>2020-09-20 12:04:41 -0700
commit928458857f4b85a0016c2d724486343b4660cb46 (patch)
treefe8ca51ef92c81b4055d0a5c9082b9b340eef3de /include
parentc6d389dab4bcdb61ed1a3d9d0500f8d6feca1ecf (diff)
downloadgoogle-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.h8
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;