X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=system%2Fgeneral%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fsystem%2Fadapters%2FClassConfiguration.java;h=a686f88cec94cd57f187e3c3ca26eed80fa93a22;hb=0d8d8f24656e585ee75558cfd6a4c661f8f14985;hp=3756bd3b7923fa52c00af73b3ebcfc97c0f27f94;hpb=7273d083a2f03cd3d2061d3c6628a46b679e718b;p=utils diff --git a/system/general/src/main/java/org/wamblee/system/adapters/ClassConfiguration.java b/system/general/src/main/java/org/wamblee/system/adapters/ClassConfiguration.java index 3756bd3b..a686f88c 100644 --- a/system/general/src/main/java/org/wamblee/system/adapters/ClassConfiguration.java +++ b/system/general/src/main/java/org/wamblee/system/adapters/ClassConfiguration.java @@ -15,34 +15,16 @@ */ package org.wamblee.system.adapters; -import java.lang.reflect.Constructor; import java.util.ArrayList; -import java.util.Arrays; import java.util.List; -import org.wamblee.collections.CollectionFilter; -import org.wamblee.conditions.Condition; import org.wamblee.system.core.DefaultProvidedInterface; -import org.wamblee.system.core.DefaultRequiredInterface; import org.wamblee.system.core.ProvidedInterface; import org.wamblee.system.core.RequiredInterface; import org.wamblee.system.core.Scope; -import org.wamblee.system.core.SystemAssemblyException; /** * The class configuration encapsulates the knowledge of how to wrap a class as a component. - * In particular, it provides: - * * * @author Erik Brakkee * @@ -50,7 +32,8 @@ import org.wamblee.system.core.SystemAssemblyException; public class ClassConfiguration { private Class _class; - private ConstructorConfiguration _constructorConfig; + private ConstructorConfiguration constructorConfig; + private ObjectConfiguration objectConfig; /** * Constructs the configuration. By default no constructor is selected and @@ -60,11 +43,16 @@ public class ClassConfiguration { */ public ClassConfiguration(Class aClass) { _class = aClass; - _constructorConfig = new ConstructorConfiguration(aClass); + constructorConfig = new ConstructorConfiguration(aClass); + objectConfig = new ObjectConfiguration(aClass); } public ConstructorConfiguration getConstructorConfig() { - return _constructorConfig; + return constructorConfig; + } + + public ObjectConfiguration getObjectConfig() { + return objectConfig; } /** @@ -73,16 +61,28 @@ public class ClassConfiguration { * @return object. */ public Object create(Scope aScope) { - return _constructorConfig.create(aScope); + return constructorConfig.create(aScope); + } + + /** + * Injects required interfaces through the setters + * @param aObject Object to inject into. + * @param aScope Scope in which injection takes place. + */ + public void inject(Scope aScope, Object aObject) { + objectConfig.inject(aScope, aObject); } - public ProvidedInterface[] getProvidedInterfaces() { - return new ProvidedInterface[] { - new DefaultProvidedInterface("provided", _class) - }; + public List getProvidedInterfaces() { + List result = new ArrayList(); + result.add(new DefaultProvidedInterface("provided", _class)); + return result; } - public RequiredInterface[] getRequiredInterface() { - return _constructorConfig.getRequiredInterfaces().toArray(new RequiredInterface[0]); + public List getRequiredInterfaces() { + List result = new ArrayList(); + result.addAll(constructorConfig.getRequiredInterfaces()); + result.addAll(objectConfig.getRequiredInterfaces()); + return result; } }