Class AbstractSingleBeanDefinitionParser
- All Implemented Interfaces:
BeanDefinitionParser
- Direct Known Subclasses:
AbstractSimpleBeanDefinitionParser
,ExecutorBeanDefinitionParser
,FreeMarkerConfigurerBeanDefinitionParser
,JtaTransactionManagerBeanDefinitionParser
,ScheduledTasksBeanDefinitionParser
,SchedulerBeanDefinitionParser
BeanDefinitionParser
implementations that
need to parse and define just a single BeanDefinition
.
Extend this parser class when you want to create a single bean definition
from an arbitrarily complex XML element. You may wish to consider extending
the AbstractSimpleBeanDefinitionParser
when you want to create a
single bean definition from a relatively simple custom XML element.
The resulting BeanDefinition
will be automatically registered
with the BeanDefinitionRegistry
.
Your job simply is to parse
the custom XML Element
into a single BeanDefinition
.
- Since:
- 2.0
- Author:
- Rob Harrop, Juergen Hoeller, Rick Evans
- See Also:
-
Field Summary
Fields inherited from class org.springframework.beans.factory.xml.AbstractBeanDefinitionParser
ID_ATTRIBUTE, NAME_ATTRIBUTE
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected void
doParse
(Element element, BeanDefinitionBuilder builder) Parse the suppliedElement
and populate the suppliedBeanDefinitionBuilder
as required.protected void
doParse
(Element element, ParserContext parserContext, BeanDefinitionBuilder builder) Parse the suppliedElement
and populate the suppliedBeanDefinitionBuilder
as required.protected Class<?>
getBeanClass
(Element element) Determine the bean class corresponding to the suppliedElement
.protected String
getBeanClassName
(Element element) Determine the bean class name corresponding to the suppliedElement
.protected String
getParentName
(Element element) Determine the name for the parent of the currently parsed bean, in case of the current bean being defined as a child bean.protected final AbstractBeanDefinition
parseInternal
(Element element, ParserContext parserContext) Creates aBeanDefinitionBuilder
instance for thebean Class
and passes it to thedoParse(org.w3c.dom.Element, org.springframework.beans.factory.xml.ParserContext, org.springframework.beans.factory.support.BeanDefinitionBuilder)
strategy method.Methods inherited from class org.springframework.beans.factory.xml.AbstractBeanDefinitionParser
parse, postProcessComponentDefinition, registerBeanDefinition, resolveId, shouldFireEvents, shouldGenerateId, shouldGenerateIdAsFallback, shouldParseNameAsAliases
-
Constructor Details
-
AbstractSingleBeanDefinitionParser
public AbstractSingleBeanDefinitionParser()
-
-
Method Details
-
parseInternal
Creates aBeanDefinitionBuilder
instance for thebean Class
and passes it to thedoParse(org.w3c.dom.Element, org.springframework.beans.factory.xml.ParserContext, org.springframework.beans.factory.support.BeanDefinitionBuilder)
strategy method.- Specified by:
parseInternal
in classAbstractBeanDefinitionParser
- Parameters:
element
- the element that is to be parsed into a single BeanDefinitionparserContext
- the object encapsulating the current state of the parsing process- Returns:
- the BeanDefinition resulting from the parsing of the supplied
Element
- Throws:
IllegalStateException
- if the beanClass
returned fromgetBeanClass(org.w3c.dom.Element)
isnull
- See Also:
-
getParentName
Determine the name for the parent of the currently parsed bean, in case of the current bean being defined as a child bean.The default implementation returns
null
, indicating a root bean definition.- Parameters:
element
- theElement
that is being parsed- Returns:
- the name of the parent bean for the currently parsed bean,
or
null
if none
-
getBeanClass
Determine the bean class corresponding to the suppliedElement
.Note that, for application classes, it is generally preferable to override
getBeanClassName(org.w3c.dom.Element)
instead, in order to avoid a direct dependence on the bean implementation class. The BeanDefinitionParser and its NamespaceHandler can be used within an IDE plugin then, even if the application classes are not available on the plugin's classpath.- Parameters:
element
- theElement
that is being parsed- Returns:
- the
Class
of the bean that is being defined via parsing the suppliedElement
, ornull
if none - See Also:
-
getBeanClassName
Determine the bean class name corresponding to the suppliedElement
.- Parameters:
element
- theElement
that is being parsed- Returns:
- the class name of the bean that is being defined via parsing
the supplied
Element
, ornull
if none - See Also:
-
doParse
Parse the suppliedElement
and populate the suppliedBeanDefinitionBuilder
as required.The default implementation delegates to the
doParse
version without ParserContext argument.- Parameters:
element
- the XML element being parsedparserContext
- the object encapsulating the current state of the parsing processbuilder
- used to define theBeanDefinition
- See Also:
-
doParse
Parse the suppliedElement
and populate the suppliedBeanDefinitionBuilder
as required.The default implementation does nothing.
- Parameters:
element
- the XML element being parsedbuilder
- used to define theBeanDefinition
-