mirror of
https://github.com/mbierlee/poodinis.git
synced 2025-01-18 21:40:38 +01:00
Add scope to registration, check for unset scope
This commit is contained in:
parent
ac077c24d7
commit
0c084a43b9
3 changed files with 37 additions and 1 deletions
|
@ -44,7 +44,7 @@ class Container {
|
|||
checkValidity!(InterfaceType)(registeredType, instantiatableType);
|
||||
}
|
||||
|
||||
Registration newRegistration = { registeredType, instantiatableType };
|
||||
Registration newRegistration = { registeredType, instantiatableType, new NullScope() };
|
||||
registrations[newRegistration.registeredType] = newRegistration;
|
||||
return newRegistration;
|
||||
}
|
||||
|
|
|
@ -3,8 +3,29 @@ module poodinis.registration;
|
|||
struct Registration {
|
||||
TypeInfo registeredType = null;
|
||||
TypeInfo_Class instantiatableType = null;
|
||||
RegistrationScope registationScope = null;
|
||||
|
||||
public Object getInstance() {
|
||||
if (registationScope is null) {
|
||||
throw new NoScopeDefinedException(registeredType);
|
||||
}
|
||||
|
||||
return instantiatableType.create();
|
||||
}
|
||||
}
|
||||
|
||||
class NoScopeDefinedException : Exception {
|
||||
this(TypeInfo type) {
|
||||
super("No scope defined for registration of type " ~ type.toString());
|
||||
}
|
||||
}
|
||||
|
||||
interface RegistrationScope {
|
||||
public Object getInstance();
|
||||
}
|
||||
|
||||
class NullScope : RegistrationScope {
|
||||
public Object getInstance() {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
|
15
test/poodinis/registrationtest.d
Normal file
15
test/poodinis/registrationtest.d
Normal file
|
@ -0,0 +1,15 @@
|
|||
import poodinis.registration;
|
||||
|
||||
import std.exception;
|
||||
|
||||
version(unittest) {
|
||||
class TestType {
|
||||
}
|
||||
|
||||
// Test getting instance without scope defined throws exception
|
||||
unittest {
|
||||
Registration registration = Registration();
|
||||
registration.registeredType = typeid(TestType);
|
||||
assertThrown!(NoScopeDefinedException)(registration.getInstance());
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue