Comment puis-je utiliser StructureMap pour résoudre une implémentation appropriée d'une interface basée sur un nom stocké dans un attribut?Utiliser StructureMap pour créer des classes par un nom?
Dans mon projet, j'ai beaucoup de différents types de widgets, chacun descendant de IWidget
, et chacun décoré avec un attribut spécifiant le type d'élément associé.
À titre d'illustration:
[Configuration("header")]
public class HeaderWidget : IWidget { }
[Configuration("linegraph")]
public class LineGraphWidget : IWidget { }
Lors du traitement de mon fichier de configuration (XML), je veux obtenir une instance de la classe concrète appropriée en fonction du nom de l'élément que je suis le traitement. Chaque définition doit aboutir à la création d'un widget différent - je n'ai pas besoin ou je ne veux pas que les instances soient partagées. Dans le passé, j'ai écrit beaucoup de code pour faire ce genre de chose manuellement, y compris l'écriture d'un conteneur IoC personnalisé "roll-your-own" pour un projet. Cependant, un de mes objectifs avec ce projet est de devenir compétent avec StructureMap au lieu de réinventer la roue.
Je pense que je l'ai déjà réussi à mettre en place l'analyse automatique des assemblages de sorte que StructureMap connaît tous mes implémentations IWidget:
public class WidgetRegistration : Registry
{
public WidgetRegistration()
{
Scan(
scanner =>
{
scanner.AssembliesFromApplicationBaseDirectory();
scanner.AddAllTypesOf<IWidget>();
});
}
}
Cependant, ce n'enregistre les noms de mes widgets avec StructureMap. Que dois-je ajouter pour que mon scénario fonctionne?
(Alors que je suis en train d'utiliser StructureMap dans ce projet, une réponse me montrant comment résoudre ce problème avec un outil DI/IoC différent serait toujours valable.)
Mise à jour
I « m assez sûr que le côté de la consommation implique d'appeler GetNamedInstance
comme ceci:
public IWidget CreateWidget(XElement definition)
{
var kind = definition.Name.LocalName;
var widget = ObjectFactory.GetNamedInstance<IWidget>(kind);
widget.Configure(definition);
return widget;
}
Ainsi, le morceau restant du puzzle est comment enregistrer automagiquement les types dans mon WidgetReg classe d'isolation.
une réponse utile (+1), bien que je ne l'ai pas besoin de mettre en œuvre mon propre scanner dans ma propre situation. – Bevan