]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - org.argeo.slc.core/src/main/java/org/argeo/slc/ant/spring/AbstractSpringArg.java
Create separate agent project
[gpl/argeo-slc.git] / org.argeo.slc.core / src / main / java / org / argeo / slc / ant / spring / AbstractSpringArg.java
index b7a63c9d28d42c4d02905ccd82044edcbc1d8574..6096f1f63ac215f8933fc9bd64f921db0c46cfec 100644 (file)
@@ -11,6 +11,7 @@ import org.springframework.context.ApplicationContext;
 import org.apache.commons.logging.LogFactory;\r
 import org.apache.tools.ant.types.DataType;\r
 \r
+import org.argeo.slc.ant.SlcAntException;\r
 import org.argeo.slc.ant.SlcProjectHelper;\r
 import org.argeo.slc.core.SlcException;\r
 \r
@@ -40,13 +41,8 @@ public abstract class AbstractSpringArg extends DataType {
        public Object getBeanInstance() {\r
                if (beanInstance == null) {\r
                        beanInstance = getContext().getBean(bean);\r
-\r
-                       BeanWrapper wrapper = new BeanWrapperImpl(beanInstance);\r
-                       for (OverrideArg override : overrides) {\r
-                               LogFactory.getLog(getClass()).debug("Prop "+override.getName());\r
-                               wrapper.setPropertyValue(override.getName(), override\r
-                                               .getObject());\r
-                       }\r
+                       \r
+                       setOverridenProperties(beanInstance);\r
 \r
                        if (beanInstance instanceof InitializingBean) {\r
                                try {\r
@@ -58,6 +54,22 @@ public abstract class AbstractSpringArg extends DataType {
                }\r
                return beanInstance;\r
        }\r
+       \r
+       protected void setOverridenProperties(Object obj){\r
+               BeanWrapper wrapper = new BeanWrapperImpl(obj);\r
+               for (OverrideArg override : overrides) {\r
+                       if (override.getName() == null) {\r
+                               throw new SlcAntException(\r
+                                               "The name of the property to override has to be set.");\r
+                       }\r
+\r
+//                     LogFactory.getLog(getClass()).debug(\r
+//                                     "Prop " + override.getName());\r
+                       wrapper.setPropertyValue(override.getName(), override\r
+                                       .getObject());\r
+               }\r
+       \r
+       }\r
 \r
        /** Creates an override subtag. */\r
        public OverrideArg createOverride() {\r