Added a separate assembly for the Ninject bindings because I do not wish to add Ninject as a core dependency (there are a ton of alternative dependency injectors out there!)
git-svn-id: file:///srv/devel/repo-conversion/dumps/svni@1 d2e56fa2-650e-0410-a79f-9358c0239efd
This commit is contained in:
commit
863fff7726
4 changed files with 180 additions and 0 deletions
41
Source/NinjectWindowManager.cs
Normal file
41
Source/NinjectWindowManager.cs
Normal file
|
|
@ -0,0 +1,41 @@
|
|||
using System;
|
||||
|
||||
using Ninject;
|
||||
|
||||
using Nuclex.Windows.Forms.AutoBinding;
|
||||
|
||||
namespace Nuclex.Windows.Forms.Ninject {
|
||||
|
||||
/// <summary>Window manager that is using Ninject</summary>
|
||||
public class NinjectWindowManager : WindowManager {
|
||||
|
||||
/// <summary>Initializes a new window manager</summary>
|
||||
/// <param name="kernel">
|
||||
/// Ninject kernel the window manager uses to construct view models
|
||||
/// </param>
|
||||
/// <param name="autoBinder">
|
||||
/// View model binder that will be used to bind all created views to their models
|
||||
/// </param>
|
||||
public NinjectWindowManager(IKernel kernel, IAutoBinder autoBinder = null) :
|
||||
base(autoBinder) {
|
||||
this.kernel = kernel;
|
||||
}
|
||||
|
||||
/// <summary>Creates an instance of the specified type</summary>
|
||||
/// <param name="type">Type an instance will be created of</param>
|
||||
/// <returns>The created instance</returns>
|
||||
/// <remarks>
|
||||
/// Use this to wire up your dependency injection container. By default,
|
||||
/// the Activator class will be used to create instances which only works
|
||||
/// if all of your view models are concrete classes.
|
||||
/// </remarks>
|
||||
protected override object CreateInstance(Type type) {
|
||||
return this.kernel.Get(type);
|
||||
}
|
||||
|
||||
/// <summary>The Ninject kernel used to create new instances</summary>
|
||||
private readonly IKernel kernel;
|
||||
|
||||
}
|
||||
|
||||
} // namespace Nuclex.Windows.Forms.Ninject
|
||||
Loading…
Add table
Add a link
Reference in a new issue