From 45f6a187762ac8ec43175e4d38e9a146653e5632 Mon Sep 17 00:00:00 2001 From: Dan Siegel Date: Tue, 19 Feb 2019 18:50:31 -0800 Subject: [PATCH] Fluent API for IContainerRegistry fixes #1677 --- Source/Prism/Ioc/IContainerRegistry.cs | 12 ++--- .../Prism/Ioc/IContainerRegistryExtensions.cs | 48 +++++++++---------- .../DryIocContainerExtension.cs | 18 ++++--- .../UnityContainerExtension.cs | 18 ++++--- .../Ioc/DryIocContainerExtension.cs | 18 ++++--- .../Ioc/NinjectContainerExtension.cs | 18 ++++--- .../Ioc/UnityContainerExtension.cs | 18 ++++--- .../Mocks/MockContainerAdapter.cs | 12 ++--- .../DryIocContainerExtension.cs | 18 ++++--- .../Mocks/PageNavigationContainerMock.cs | 21 ++++---- .../UnityContainerExtension.cs | 18 ++++--- 11 files changed, 131 insertions(+), 88 deletions(-) diff --git a/Source/Prism/Ioc/IContainerRegistry.cs b/Source/Prism/Ioc/IContainerRegistry.cs index 2b89ad9805..d19e6866a6 100644 --- a/Source/Prism/Ioc/IContainerRegistry.cs +++ b/Source/Prism/Ioc/IContainerRegistry.cs @@ -4,17 +4,17 @@ namespace Prism.Ioc { public interface IContainerRegistry { - void RegisterInstance(Type type, object instance); + IContainerRegistry RegisterInstance(Type type, object instance); - void RegisterInstance(Type type, object instance, string name); + IContainerRegistry RegisterInstance(Type type, object instance, string name); - void RegisterSingleton(Type from, Type to); + IContainerRegistry RegisterSingleton(Type from, Type to); - void RegisterSingleton(Type from, Type to, string name); + IContainerRegistry RegisterSingleton(Type from, Type to, string name); - void Register(Type from, Type to); + IContainerRegistry Register(Type from, Type to); - void Register(Type from, Type to, string name); + IContainerRegistry Register(Type from, Type to, string name); bool IsRegistered(Type type); diff --git a/Source/Prism/Ioc/IContainerRegistryExtensions.cs b/Source/Prism/Ioc/IContainerRegistryExtensions.cs index 4f88814df8..2a9d017627 100644 --- a/Source/Prism/Ioc/IContainerRegistryExtensions.cs +++ b/Source/Prism/Ioc/IContainerRegistryExtensions.cs @@ -4,64 +4,64 @@ namespace Prism.Ioc { public static class IContainerRegistryExtensions { - public static void RegisterInstance(this IContainerRegistry containerRegistry, TInterface instance) + public static IContainerRegistry RegisterInstance(this IContainerRegistry containerRegistry, TInterface instance) { - containerRegistry.RegisterInstance(typeof(TInterface), instance); + return containerRegistry.RegisterInstance(typeof(TInterface), instance); } - public static void RegisterInstance(this IContainerRegistry containerRegistry, TInterface instance, string name) + public static IContainerRegistry RegisterInstance(this IContainerRegistry containerRegistry, TInterface instance, string name) { - containerRegistry.RegisterInstance(typeof(TInterface), instance, name); + return containerRegistry.RegisterInstance(typeof(TInterface), instance, name); } - public static void RegisterSingleton(this IContainerRegistry containerRegistry, Type type) + public static IContainerRegistry RegisterSingleton(this IContainerRegistry containerRegistry, Type type) { - containerRegistry.RegisterSingleton(type, type); + return containerRegistry.RegisterSingleton(type, type); } - public static void RegisterSingleton(this IContainerRegistry containerRegistry) where TTo : TFrom + public static IContainerRegistry RegisterSingleton(this IContainerRegistry containerRegistry) where TTo : TFrom { - containerRegistry.RegisterSingleton(typeof(TFrom), typeof(TTo)); + return containerRegistry.RegisterSingleton(typeof(TFrom), typeof(TTo)); } - public static void RegisterSingleton(this IContainerRegistry containerRegistry, string name) where TTo : TFrom + public static IContainerRegistry RegisterSingleton(this IContainerRegistry containerRegistry, string name) where TTo : TFrom { - containerRegistry.RegisterSingleton(typeof(TFrom), typeof(TTo), name); + return containerRegistry.RegisterSingleton(typeof(TFrom), typeof(TTo), name); } - public static void RegisterSingleton(this IContainerRegistry containerRegistry) + public static IContainerRegistry RegisterSingleton(this IContainerRegistry containerRegistry) { - containerRegistry.RegisterSingleton(typeof(T)); + return containerRegistry.RegisterSingleton(typeof(T)); } - public static void Register(this IContainerRegistry containerRegistry, Type type) + public static IContainerRegistry Register(this IContainerRegistry containerRegistry, Type type) { - containerRegistry.Register(type, type); + return containerRegistry.Register(type, type); } - public static void Register(this IContainerRegistry containerRegistry) + public static IContainerRegistry Register(this IContainerRegistry containerRegistry) { - containerRegistry.Register(typeof(T)); + return containerRegistry.Register(typeof(T)); } - public static void Register(this IContainerRegistry containerRegistry, Type type, string name) + public static IContainerRegistry Register(this IContainerRegistry containerRegistry, Type type, string name) { - containerRegistry.Register(type, type, name); + return containerRegistry.Register(type, type, name); } - public static void Register(this IContainerRegistry containerRegistry, string name) + public static IContainerRegistry Register(this IContainerRegistry containerRegistry, string name) { - containerRegistry.Register(typeof(T), name); + return containerRegistry.Register(typeof(T), name); } - public static void Register(this IContainerRegistry containerRegistry) where TTo : TFrom + public static IContainerRegistry Register(this IContainerRegistry containerRegistry) where TTo : TFrom { - containerRegistry.Register(typeof(TFrom), typeof(TTo)); + return containerRegistry.Register(typeof(TFrom), typeof(TTo)); } - public static void Register(this IContainerRegistry containerRegistry, string name) where TTo : TFrom + public static IContainerRegistry Register(this IContainerRegistry containerRegistry, string name) where TTo : TFrom { - containerRegistry.Register(typeof(TFrom), typeof(TTo), name); + return containerRegistry.Register(typeof(TFrom), typeof(TTo), name); } public static bool IsRegistered(this IContainerRegistry containerRegistry) diff --git a/Source/Windows10/Prism.DryIoc.Windows/DryIocContainerExtension.cs b/Source/Windows10/Prism.DryIoc.Windows/DryIocContainerExtension.cs index 31c1bd26be..239af56224 100644 --- a/Source/Windows10/Prism.DryIoc.Windows/DryIocContainerExtension.cs +++ b/Source/Windows10/Prism.DryIoc.Windows/DryIocContainerExtension.cs @@ -16,34 +16,40 @@ public DryIocContainerExtension(IContainer container) public void FinalizeExtension() { } - public void RegisterInstance(Type type, object instance) + public IContainerRegistry RegisterInstance(Type type, object instance) { Instance.UseInstance(type, instance); + return this; } - public void RegisterInstance(Type type, object instance, string name) + public IContainerRegistry RegisterInstance(Type type, object instance, string name) { Instance.UseInstance(type, instance, serviceKey: name); + return this; } - public void RegisterSingleton(Type from, Type to) + public IContainerRegistry RegisterSingleton(Type from, Type to) { Instance.Register(from, to, Reuse.Singleton); + return this; } - public void RegisterSingleton(Type from, Type to, string name) + public IContainerRegistry RegisterSingleton(Type from, Type to, string name) { Instance.Register(from, to, Reuse.Singleton, serviceKey: name); + return this; } - public void Register(Type from, Type to) + public IContainerRegistry Register(Type from, Type to) { Instance.Register(from, to); + return this; } - public void Register(Type from, Type to, string name) + public IContainerRegistry Register(Type from, Type to, string name) { Instance.Register(from, to, serviceKey: name); + return this; } public object Resolve(Type type) diff --git a/Source/Windows10/Prism.Unity.Windows/UnityContainerExtension.cs b/Source/Windows10/Prism.Unity.Windows/UnityContainerExtension.cs index 02624dd0c7..363edb86dd 100644 --- a/Source/Windows10/Prism.Unity.Windows/UnityContainerExtension.cs +++ b/Source/Windows10/Prism.Unity.Windows/UnityContainerExtension.cs @@ -14,34 +14,40 @@ public sealed class UnityContainerExtension : IContainerExtension public void FinalizeExtension() { } - public void RegisterInstance(Type type, object instance) + public IContainerRegistry RegisterInstance(Type type, object instance) { Instance.RegisterInstance(type, instance); + return this; } - public void RegisterInstance(Type type, object instance, string name) + public IContainerRegistry RegisterInstance(Type type, object instance, string name) { Instance.RegisterInstance(type, name, instance); + return this; } - public void RegisterSingleton(Type from, Type to) + public IContainerRegistry RegisterSingleton(Type from, Type to) { Instance.RegisterSingleton(from, to); + return this; } - public void RegisterSingleton(Type from, Type to, string name) + public IContainerRegistry RegisterSingleton(Type from, Type to, string name) { Instance.RegisterSingleton(from, to, name); + return this; } - public void Register(Type from, Type to) + public IContainerRegistry Register(Type from, Type to) { Instance.RegisterType(from, to); + return this; } - public void Register(Type from, Type to, string name) + public IContainerRegistry Register(Type from, Type to, string name) { Instance.RegisterType(from, to, name); + return this; } public object Resolve(Type type)