Go to file
2016-02-15 00:17:06 +01:00
example Add example for detailing how registration on resolve works 2016-02-09 21:30:51 +01:00
source/poodinis Fix typos of enum RegistrationOption 2016-02-11 20:40:16 +01:00
test/poodinis Make ApplicationContext more robust 2016-02-10 00:36:44 +01:00
.gitignore Ignore IntelliJ project file 2016-01-17 18:23:26 +01:00
.travis.yml Build with latest LDC on travis 2016-02-15 00:17:06 +01:00
CHANGES.md Prepare version 6.1.0 2016-02-09 23:53:47 +01:00
dub.json Add example for detailing how registration on resolve works 2016-02-09 21:30:51 +01:00
LICENSE.txt Update copyrights 2016-01-06 20:18:35 +01:00
README.md Add future work 2016-02-11 20:46:16 +01:00
TUTORIAL.md Fix typos of enum RegistrationOption 2016-02-11 20:40:16 +01:00

Poodinis Dependency Injection Framework

Version 6.1.0
Copyright 2014-2016 Mike Bierlee
Licensed under the terms of the MIT license - See LICENSE.txt

Master: Build Status - Dev: Build Status

Poodinis is a dependency injection framework for the D programming language. It is inspired by the Spring Framework and Hypodermic IoC container for C++. Poodinis supports registering and resolving classes either by concrete type or interface. Automatic injection of dependencies is supported through the use of UDAs (Referred to as autowiring).

Requires at least a D 2.068.0 compatible compiler
Uses the Phobos standard library
Can be built with DUB 0.9.24

History

For a full overview of changes, see CHANGES.md

Getting started

###DUB Dependency See the Poodinis DUB project page for instructions on how to include Poodinis into your project.

###Quickstart The following example shows the typical usage of Poodinis:

import poodinis;

interface Database{};
class RelationalDatabase : Database {}

class DataWriter {
	@Autowire
	private Database database; // Automatically injected when class is resolved
}

void main() {
	auto dependencies = DependencyContainer.getInstance();
	dependencies.register!DataWriter;
	dependencies.register!(Database, RelationalDatabase);

	auto writer = dependencies.resolve!DataWriter;
}

For more examples, see the examples directory.

###Tutorial For an extended tutorial walking you through all functionality offered by Poodinis, see TUTORIAL.md

Documentation

You can generate Public API documentation from the source code using DUB:

dub build --build=ddox

The documentation can then be found in docs/

Future Work

  • Component scan (auto-registration)
  • Phobos collections autowiring
  • Constructor injection
  • Named qualifiers
  • Value type injection

Contributing

Any and all pull requests are welcome! If you (only) want discuss changes before making them, feel free to open an Issue on github. Please develop your changes on (a branch based on) the develop branch. Continuous integration is preferred so feature branches are not neccessary.