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=ca64d12f5296802d0bd40f9316317a49c5eec4cc;hb=f86db0937b395c7fa96fa4bf4a29cc2c676fe3f5;hp=7bc04ea5466dba96762e13218f184dc887709047;hpb=bb58cdb33cceffa06b72bc191e63022b9a739d14;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 7bc04ea54..ca64d12f5 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 @@ -1,11 +1,31 @@ +/* + * Copyright (C) 2007-2012 Argeo GmbH + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ 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; +import org.springframework.beans.factory.BeanDefinitionStoreException; import org.springframework.beans.factory.config.RuntimeBeanReference; +import org.springframework.beans.factory.support.AbstractBeanDefinition; import org.springframework.beans.factory.support.BeanDefinitionBuilder; import org.springframework.beans.factory.support.ManagedList; import org.springframework.beans.factory.support.ManagedMap; @@ -17,18 +37,30 @@ 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); + + /** Whether the user has already be warned on path attribute usage. */ + private Boolean warnedAboutPathAttribute = false; @SuppressWarnings("unchecked") @Override protected void doParse(Element element, ParserContext parserContext, BeanDefinitionBuilder builder) { String path = element.getAttribute("path"); - if (StringUtils.hasText(path)) + if (StringUtils.hasText(path)) { builder.addPropertyValue("path", path); + // warns user only once + if (!warnedAboutPathAttribute) + log.warn("The path=\"\" attribute is deprecated" + + " and will be removed in a later release." + + " Use ."); + warnedAboutPathAttribute = true; + } + String spec = element.getAttribute("spec"); if (StringUtils.hasText(spec)) builder.getBeanDefinition().getConstructorArgumentValues() @@ -42,15 +74,21 @@ public class FlowBeanDefinitionParser extends if (StringUtils.hasText(parent)) builder.setParentName(parent); - List execElems = new ArrayList(); + builder.getBeanDefinition().setDescription( + DomUtils.getChildElementValueByTagName(element, "description")); + 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 + else if (DomUtils.nodeNameEquals(node, "spec")) + specElems.add((Element) node); + else if (!DomUtils.nodeNameEquals(node, "description")) execElems.add((Element) node); } } @@ -70,32 +108,51 @@ 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()); - for (int i = 0; i < execElems.size(); i++) { - Element child = execElems.get(i); - String name = child.getLocalName(); - if (DomUtils.nodeNameEquals(child, "bean") - || DomUtils.nodeNameEquals(child, "ref")) { - // Object target = parseBeanReference((Element) child, - // parserContext, builder); - executables.add(NamespaceUtils.parseBeanReference(child, - parserContext, builder.getBeanDefinition())); - } else if (DomUtils.nodeNameEquals(child, "flow")) { - throw new SlcException( - "Nested flows are not yet supported, use a standard ref to another flow."); - } else { - throw new SlcException("Unsupported child '" + name + "'"); - } + for (Element child : execElems) { + // child validity check is performed in xsd + executables.add(NamespaceUtils.parseBeanOrReference(child, + parserContext, builder.getBeanDefinition())); } - builder.addPropertyValue("executables", executables); + if (executables.size() > 0) + builder.addPropertyValue("executables", executables); } } + @SuppressWarnings("unchecked") @Override - protected Class getBeanClass(Element element) { - return DefaultExecutionFlow.class; + protected Class getBeanClass(Element element) { + String clss = element.getAttribute("class"); + if (StringUtils.hasText(clss)) + // TODO: check that it actually works + try { + return (Class) getClass() + .getClassLoader().loadClass(clss); + } catch (ClassNotFoundException e) { + try { + return (Class) Thread + .currentThread().getContextClassLoader() + .loadClass(clss); + } catch (ClassNotFoundException e1) { + throw new SlcException("Cannot load class " + clss, e); + } + } + else + return DefaultExecutionFlow.class; } // parse nested bean definition @@ -105,6 +162,18 @@ public class FlowBeanDefinitionParser extends // builder.getBeanDefinition()); // } + @Override + protected String resolveId(Element element, + AbstractBeanDefinition definition, ParserContext parserContext) + throws BeanDefinitionStoreException { + String name = element.getAttribute("name"); + if (StringUtils.hasText(name)) { + return name; + } else { + return super.resolveId(element, definition, parserContext); + } + } + protected boolean shouldGenerateIdAsFallback() { return true; }