/*
* Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.runtime.config.spring.parsers.generic;
import org.mule.runtime.config.spring.parsers.assembly.BeanAssembler;
import org.springframework.beans.factory.support.AbstractBeanDefinition;
import org.springframework.beans.factory.xml.ParserContext;
import org.w3c.dom.Element;
/**
* Behaves as {@link org.mule.runtime.config.spring.parsers.generic.ParentDefinitionParser}, but allows any named bean to be the
* parent, rather than using the enclosing element in the DOM tree.
*/
public class NamedDefinitionParser extends ParentDefinitionParser {
private String name;
private boolean isDynamic = false;
public NamedDefinitionParser() {
isDynamic = true;
}
public NamedDefinitionParser(String name) {
addIgnored(ATTRIBUTE_NAME);
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
protected String getParentBeanName(Element element) {
return name;
}
protected AbstractBeanDefinition parseInternal(Element element, ParserContext parserContext) {
if (isDynamic) {
if (element.hasAttribute(ATTRIBUTE_NAME)) {
setName(element.getAttribute(ATTRIBUTE_NAME));
element.removeAttribute(ATTRIBUTE_NAME);
} else {
throw new IllegalStateException("Missing name attribute for " + element.getLocalName());
}
}
return super.parseInternal(element, parserContext);
}
protected void postProcess(ParserContext context, BeanAssembler assembler, Element element) {
super.postProcess(context, assembler, element);
// may be used as top level element, so set ID from name
AutoIdUtils.ensureUniqueId(element, "named");
}
}