Let’s say I have 5 separate assemblies with the following (assume the class name is different in each):
[Export(typeof(IService))]
public class Service: IService
{
// ...
}
And I have a class that will be a composite of these in my main assembly
public class CompositeService : IService
{
public CompositeService(IEnumerable<IService> services)
{
// ...
}
}
What I would like to do is have the Unity container resolve the CompositeService for the IService and have the MefContrib extension for Unity go and find the 5 other exports and inject them into CompositeService‘s constructor.
The problem is that you can’t have N instances for a nameless unityContainer.RegisterType<IService> nor can you for named instances if they all have the same name.
I think I’m missing something simple in the combination of the 2 technologies (Unity + MEF) via the third (MefContrib) but can’t seem to pick up on what it is.
Is this possible or is there a workaround? Eventually, I’m going for full bi-directional dependency injection and dynamic component discovery.
I think what is likely the best approach is to flip this around. Instead of trying to register your components via Unity, you actually leave the discovery of these parts to MEF. MEFContrib includes an Unity integration mechanism that allows your MEF composed parts to be injected into Unity components. This was original detailed at Piotr WŁodek’s blog, whereby he also gives you a sample. Essentialy, the way it works is you can use a series of extension methods on your
UnityContainerto register your catalogs. Internally, it will create the appropriate extension and wire up your container.Here is a quick and dirty example, we’ll create some interfaces:
And then some sample parts which we’ll export (via MEF):
Now, we’ll create another part (this will be created via Unity):
To wire it all up, we simply need to use the
RegisterCatalogextension method on yourUnityContainer(importMefContrib.Integration.Unityafter you’ve added a reference to MEFContrib):Now you should be able to grab the instance and enumerate the MEF-provided parts:
note: 100% untested.