I have the following function in c#:
bool Handle<TCommandHandler, TModel>(TModel model) where TCommandHandler : ICommandHandler<TModel> {
// ...
_container.Resolve<TCommandHandler>();
// ...
}
Since TModel is clear from a function parameter I want some way to not specify its type when calling a function. Ideally I want to call it like:
Handle<MyCommandHandler>(model);
Since this is probably impossible, I came up with the following:
HandleTemp<TModel> Handle<TModel>(TModel model) {
return new HandleTemp<TModel>(model);
}
public class HandleTemp<TModel> {
private TModel _model;
public HandleTemp(TModel model) { _model = model;}
public bool With<TCommandHandler>() where TCommandHandler : ICommandHandler<TModel> {
}
}
So I’m now calling it like:
Handle(model).With<MyCommandHandler>();
Are there other possibilities? Did I make something completely wrong with my solution?
No, your analysis and solution look about right. Indeed, generic type inference can work only on an all-or-nothing basis. If there are some generic parameters that can’t be inferred, all must be explicitly stated. Personally I’d quite like a way to say “you worry about these parameters, I’ll tell you this one”, but… that doesn’t exist.
The only other option is to add an artificial extra regular parameter to allow it to infer the generic parameter – a bit yucky.
One other option: challenge the assumption that generics are needed here. For example, could it just be a
Typeinstance? Would:work, for example? I can’t answer this directly, as I don’t know the particulars of your
_container.Resolve<TCommandHandler>();method, as to whether that could be adjusted to take aTyperather than a<T>.