aboutsummaryrefslogtreecommitdiff
path: root/include/fruit/impl/injection_errors.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/fruit/impl/injection_errors.h')
-rw-r--r--include/fruit/impl/injection_errors.h15
1 files changed, 15 insertions, 0 deletions
diff --git a/include/fruit/impl/injection_errors.h b/include/fruit/impl/injection_errors.h
index a0e9def..68247d2 100644
--- a/include/fruit/impl/injection_errors.h
+++ b/include/fruit/impl/injection_errors.h
@@ -124,6 +124,16 @@ struct NotASignatureError {
"the form MyClass(int, float).");
};
+template <typename CandidateSignature>
+struct AssistedParamInRegisterConstructorSignatureError {
+ static_assert(AlwaysFalse<CandidateSignature>::value,
+ "CandidateSignature was used as signature for a registerConstructor() (explicit or implicit via the "
+ "INJECT macro / Inject typedef) but it contains an assisted parameter. When using assisted parameters"
+ "You need to inject a factory like std::function<std::unique_ptr<MyClass>(int, float)> instead of "
+ "injecting MyClass directly. If you used an explicit registerConstructor(), you also need to switch "
+ "that to registerFactory().");
+};
+
template <typename CandidateLambda>
struct NotALambdaError {
static_assert(AlwaysFalse<CandidateLambda>::value,
@@ -494,6 +504,11 @@ struct NotASignatureErrorTag {
using apply = NotASignatureError<CandidateSignature>;
};
+struct AssistedParamInRegisterConstructorSignatureErrorTag {
+ template <typename CandidateSignature>
+ using apply = AssistedParamInRegisterConstructorSignatureError<CandidateSignature>;
+};
+
struct NotALambdaErrorTag {
template <typename CandidateLambda>
using apply = NotALambdaError<CandidateLambda>;