X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2Fxml%2FFlowBeanDefinitionParser.java;h=23b05074840ef8b1ac9bc3eb0e0c397a0b96ccd0;hb=fa15e0d0a70b92ba12153f5d5d02d7e900fc25d2;hp=f2e961fbcd0745b2f618210d67c03ee75e14ae0a;hpb=277128107535986b7dfa0ecbab5ec90ac08ee8f9;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/xml/FlowBeanDefinitionParser.java b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/xml/FlowBeanDefinitionParser.java index f2e961fbc..23b050748 100644 --- a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/xml/FlowBeanDefinitionParser.java +++ b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/xml/FlowBeanDefinitionParser.java @@ -18,6 +18,8 @@ package org.argeo.slc.core.execution.xml; import java.util.ArrayList; import java.util.List; +import org.apache.commons.logging.Log; +import org.apache.commons.logging.LogFactory; import org.argeo.slc.SlcException; import org.argeo.slc.core.execution.DefaultExecutionFlow; import org.argeo.slc.execution.ExecutionFlow; @@ -35,9 +37,10 @@ import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; +/** Interprets the tag */ public class FlowBeanDefinitionParser extends AbstractSingleBeanDefinitionParser { - // private Log log = LogFactory.getLog(FlowBeanDefinitionParser.class); + private Log log = LogFactory.getLog(FlowBeanDefinitionParser.class); @SuppressWarnings("unchecked") @Override @@ -45,7 +48,7 @@ public class FlowBeanDefinitionParser extends BeanDefinitionBuilder builder) { String path = element.getAttribute("path"); if (StringUtils.hasText(path)) - builder.addPropertyValue("path", path); + log.warn("The 'path' attribute is not used anymore to build flows"); String spec = element.getAttribute("spec"); if (StringUtils.hasText(spec)) @@ -63,14 +66,17 @@ public class FlowBeanDefinitionParser extends builder.getBeanDefinition().setDescription( DomUtils.getChildElementValueByTagName(element, "description")); - List execElems = new ArrayList(); List argsElems = new ArrayList(); + List execElems = new ArrayList(); + List specElems = new ArrayList(); NodeList nodeList = element.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node instanceof Element) { if (DomUtils.nodeNameEquals(node, "arg")) argsElems.add((Element) node); + else if (DomUtils.nodeNameEquals(node, "spec")) + specElems.add((Element) node); else if (!DomUtils.nodeNameEquals(node, "description")) execElems.add((Element) node); } @@ -91,6 +97,18 @@ public class FlowBeanDefinitionParser extends .addGenericArgumentValue(args); } + // Execution specs + if (StringUtils.hasText(spec) && specElems.size() != 0) + throw new SlcException("A flow cannot have multiple specs"); + if (specElems.size() == 1) { + Object specObj = NamespaceUtils.parseBeanOrReference( + specElems.get(0), parserContext, + builder.getBeanDefinition()); + builder.getBeanDefinition().getConstructorArgumentValues() + .addGenericArgumentValue(specObj); + } else if (specElems.size() > 1) + throw new SlcException("A flow cannot have multiple specs"); + // Executables if (execElems.size() != 0) { ManagedList executables = new ManagedList(execElems.size()); @@ -116,8 +134,8 @@ public class FlowBeanDefinitionParser extends } catch (ClassNotFoundException e) { try { return (Class) Thread - .currentThread().getContextClassLoader().loadClass( - clss); + .currentThread().getContextClassLoader() + .loadClass(clss); } catch (ClassNotFoundException e1) { throw new SlcException("Cannot load class " + clss, e); }