1

現在、TinyIOC を使用してカスタムReactiveUI IMutableDependencyResolverを接続しようとしています。また、ReactiveUI が複数のインターフェイス実装をユーザー指定のファクトリに登録したいという事実に苦労しています。どの TinyIOC がサポートしていないようです。

私の実装は、レジスタが再度呼び出されるたびに以前の登録を上書きしているようです。助言がありますか?

#region IMutableDependencyResolver implementation

public void Register(Func<object> factory, Type serviceType, string contract = null)
{
  TinyIOC.TinyIOCContainer.Current.Register(serviceType, (a, b)=>
  { 
    var result = factory();
    return result;
  }, contract);
}

#endregion
4

1 に答える 1

1

基本的に、このようなリゾルバーの場合、複数の登録ビットを自分で行う必要があります。つまり、タイプを直接登録する代わりに、「登録されたサービスのリスト」を登録する必要があります。それはちょっと痛いです。

コンストラクターによるサービス インジェクションが必要ない場合は、組み込みのものを使用することをお勧めします。これは実際には Pretty Good™ です。

更新:最後に、AutoFac で同様の問題を回避するために書いたコードの一部を見つけました: var builder = new ContainerBuilder(); var コンテナー = デフォルト (IContainer);

#region Don't actually read this terrible code

// NB: This garbage exists in order to work around the fact that
// Autofac doesn't support multiple registrations for the same type
// (i.e. GetAllServices), but RxUI relies on it.
var registrations = new Dictionary<Tuple<Type, string>, List<Type>>();
RxApp.ConfigureServiceLocator(
    (t, s) => s != null ? container.ResolveNamed(s, t) : container.Resolve(t),
    (t, s) => {
        var type = typeof(IEnumerable<>).MakeGenericType(t);
        var ret = (IEnumerable<Type>)container.ResolveNamed<IEnumerable<Type>>(type.FullName);
        return ret.Select(x => Activator.CreateInstance(x)).ToArray();
    },
    (c, t, s) => {
        // NB: This is the hackiest hack of hack to work around a bug in RxUI
        if (container != null) return;

        var pair = Tuple.Create(t, s);
        if (!registrations.ContainsKey(pair)) registrations[pair] = new List<Type>();

        registrations[pair].Add(c);
    });

foreach (var kvp in registrations) {
    if (kvp.Value.Count == 1) {
        var reg = builder.RegisterType(kvp.Value[0]).As(kvp.Key.Item1);
        if (kvp.Key.Item2 != null) reg.Named(kvp.Key.Item2, kvp.Key.Item1);
    } else {
        var type = typeof(IEnumerable<>).MakeGenericType(kvp.Key.Item1);
        builder.RegisterInstance(kvp.Value).As<IEnumerable<Type>>().Named<IEnumerable<Type>>(type.FullName);
    }
}

#endregion
于 2013-05-25T19:13:35.193 に答える