mirror of
https://github.com/mbierlee/poodinis.git
synced 2025-01-18 21:40:38 +01:00
Extracting debug info printing to separate functions
This commit is contained in:
parent
58073dd160
commit
3d6ab10b6d
1 changed files with 12 additions and 9 deletions
|
@ -64,6 +64,10 @@ struct Autowire(QualifierType = UseMemberType) {
|
|||
QualifierType qualifier;
|
||||
};
|
||||
|
||||
private void printDebugAutowiredInstance(TypeInfo instanceType, void* instanceAddress) {
|
||||
writeln(format("DEBUG: Autowiring members of [%s@%s]", instanceType, instanceAddress));
|
||||
}
|
||||
|
||||
/**
|
||||
* Autowires members of a given instance using dependencies registered in the given container.
|
||||
*
|
||||
|
@ -78,9 +82,7 @@ struct Autowire(QualifierType = UseMemberType) {
|
|||
*/
|
||||
public void autowire(Type)(DependencyContainer container, Type instance) {
|
||||
debug(poodinisVerbose) {
|
||||
auto instanceType = typeid(Type);
|
||||
auto instanceAddress = &instance;
|
||||
writeln(format("DEBUG: Autowiring members of [%s@%s]", instanceType, instanceAddress));
|
||||
printDebugAutowiredInstance(typeid(Type), &instance);
|
||||
}
|
||||
|
||||
foreach (member ; __traits(allMembers, Type)) {
|
||||
|
@ -88,6 +90,10 @@ public void autowire(Type)(DependencyContainer container, Type instance) {
|
|||
}
|
||||
}
|
||||
|
||||
private void printDebugAutowiringCandidate(TypeInfo candidateInstanceType, void* candidateInstanceAddress, TypeInfo instanceType, void* instanceAddress, string member) {
|
||||
writeln(format("DEBUG: Autowired instance [%s@%s] to [%s@%s].%s", candidateInstanceType, candidateInstanceAddress, instanceType, instanceAddress, member));
|
||||
}
|
||||
|
||||
private void autowireMember(string member, Type)(DependencyContainer container, Type instance) {
|
||||
// For the love of god, refactor this! <-- Doing it, bro!
|
||||
static if(__traits(compiles, __traits(getMember, Type, member)) && __traits(compiles, __traits(getAttributes, __traits(getMember, Type, member)))) {
|
||||
|
@ -98,7 +104,7 @@ private void autowireMember(string member, Type)(DependencyContainer container,
|
|||
alias MemberType = typeof(memberReference)[0];
|
||||
|
||||
debug(poodinisVerbose) {
|
||||
string qualifiedInstanceTypeString = typeid(MemberType).toString;
|
||||
TypeInfo qualifiedInstanceType = typeid(MemberType);
|
||||
}
|
||||
|
||||
MemberType qualifiedInstance;
|
||||
|
@ -106,7 +112,7 @@ private void autowireMember(string member, Type)(DependencyContainer container,
|
|||
alias QualifierType = typeof(autowireAttribute.qualifier);
|
||||
qualifiedInstance = container.resolve!(typeof(memberReference), QualifierType);
|
||||
debug(poodinisVerbose) {
|
||||
qualifiedInstanceTypeString = typeid(QualifierType).toString;
|
||||
qualifiedInstanceType = typeid(QualifierType);
|
||||
}
|
||||
} else {
|
||||
qualifiedInstance = container.resolve!(typeof(memberReference));
|
||||
|
@ -115,10 +121,7 @@ private void autowireMember(string member, Type)(DependencyContainer container,
|
|||
__traits(getMember, instance, member) = qualifiedInstance;
|
||||
|
||||
debug(poodinisVerbose) {
|
||||
auto instanceType = typeid(Type);
|
||||
auto instanceAddress = &instance;
|
||||
auto qualifiedInstanceAddress = &qualifiedInstance;
|
||||
writeln(format("DEBUG: Autowired instance [%s@%s] to [%s@%s].%s", qualifiedInstanceTypeString, qualifiedInstanceAddress, instanceType, instanceAddress, member));
|
||||
printDebugAutowiringCandidate(qualifiedInstanceType, &qualifiedInstance, typeid(Type), &instance, member);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue