Class AbstractBeanDefinitionParser
- All Implemented Interfaces:
BeanDefinitionParser
- Direct Known Subclasses:
AbstractSingleBeanDefinitionParser
BeanDefinitionParser
implementation providing
a number of convenience methods and a
template method
that subclasses must override to provide the actual parsing logic.
Use this BeanDefinitionParser
implementation when you want
to parse some arbitrarily complex XML into one or more
BeanDefinitions
. If you just want to parse some
XML into a single BeanDefinition
, you may wish to consider
the simpler convenience extensions of this class, namely
AbstractSingleBeanDefinitionParser
and
AbstractSimpleBeanDefinitionParser
.
- Since:
- 2.0
- Author:
- Rob Harrop, Juergen Hoeller, Rick Evans, Dave Syer
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionfinal BeanDefinition
parse
(Element element, ParserContext parserContext) Parse the specifiedElement
and register the resultingBeanDefinition(s)
with theBeanDefinitionRegistry
embedded in the suppliedParserContext
.protected abstract AbstractBeanDefinition
parseInternal
(Element element, ParserContext parserContext) Central template method to actually parse the suppliedElement
into one or moreBeanDefinitions
.protected void
postProcessComponentDefinition
(BeanComponentDefinition componentDefinition) Hook method called after the primary parsing of aBeanComponentDefinition
but before theBeanComponentDefinition
has been registered with aBeanDefinitionRegistry
.protected void
registerBeanDefinition
(BeanDefinitionHolder definition, BeanDefinitionRegistry registry) protected String
resolveId
(Element element, AbstractBeanDefinition definition, ParserContext parserContext) Resolve the ID for the suppliedBeanDefinition
.protected boolean
Determine whether this parser is supposed to fire aBeanComponentDefinition
event after parsing the bean definition.protected boolean
Should an ID be generated instead of read from the passed inElement
?protected boolean
Should an ID be generated instead if the passed inElement
does not specify an "id" attribute explicitly?protected boolean
Determine whether the element's "name" attribute should get parsed as bean definition aliases, i.e.
-
Field Details
-
ID_ATTRIBUTE
Constant for the "id" attribute.- See Also:
-
NAME_ATTRIBUTE
Constant for the "name" attribute.- See Also:
-
-
Constructor Details
-
AbstractBeanDefinitionParser
public AbstractBeanDefinitionParser()
-
-
Method Details
-
parse
Description copied from interface:BeanDefinitionParser
Parse the specifiedElement
and register the resultingBeanDefinition(s)
with theBeanDefinitionRegistry
embedded in the suppliedParserContext
.Implementations must return the primary
BeanDefinition
that results from the parse if they will ever be used in a nested fashion (for example as an inner tag in a<property/>
tag). Implementations may returnnull
if they will not be used in a nested fashion.- Specified by:
parse
in interfaceBeanDefinitionParser
- Parameters:
element
- the element that is to be parsed into one or moreBeanDefinitions
parserContext
- the object encapsulating the current state of the parsing process; provides access to aBeanDefinitionRegistry
- Returns:
- the primary
BeanDefinition
-
resolveId
protected String resolveId(Element element, AbstractBeanDefinition definition, ParserContext parserContext) throws BeanDefinitionStoreException Resolve the ID for the suppliedBeanDefinition
.When using
generation
, a name is generated automatically. Otherwise, the ID is extracted from the "id" attribute, potentially with afallback
to a generated id.- Parameters:
element
- the element that the bean definition has been built fromdefinition
- the bean definition to be registeredparserContext
- the object encapsulating the current state of the parsing process; provides access to aBeanDefinitionRegistry
- Returns:
- the resolved id
- Throws:
BeanDefinitionStoreException
- if no unique name could be generated for the given bean definition
-
registerBeanDefinition
protected void registerBeanDefinition(BeanDefinitionHolder definition, BeanDefinitionRegistry registry) Register the suppliedbean
with the suppliedregistry
.Subclasses can override this method to control whether the supplied
bean
is actually even registered, or to register even more beans.The default implementation registers the supplied
bean
with the suppliedregistry
only if theisNested
parameter isfalse
, because one typically does not want inner beans to be registered as top level beans.- Parameters:
definition
- the bean definition to be registeredregistry
- the registry that the bean is to be registered with- See Also:
-
parseInternal
@Nullable protected abstract AbstractBeanDefinition parseInternal(Element element, ParserContext parserContext) Central template method to actually parse the suppliedElement
into one or moreBeanDefinitions
.- Parameters:
element
- the element that is to be parsed into one or moreBeanDefinitions
parserContext
- the object encapsulating the current state of the parsing process; provides access to aBeanDefinitionRegistry
- Returns:
- the primary
BeanDefinition
resulting from the parsing of the suppliedElement
- See Also:
-
shouldGenerateId
protected boolean shouldGenerateId()Should an ID be generated instead of read from the passed inElement
?Disabled by default; subclasses can override this to enable ID generation. Note that this flag is about always generating an ID; the parser won't even check for an "id" attribute in this case.
- Returns:
- whether the parser should always generate an id
-
shouldGenerateIdAsFallback
protected boolean shouldGenerateIdAsFallback()Should an ID be generated instead if the passed inElement
does not specify an "id" attribute explicitly?Disabled by default; subclasses can override this to enable ID generation as fallback: The parser will first check for an "id" attribute in this case, only falling back to a generated ID if no value was specified.
- Returns:
- whether the parser should generate an id if no id was specified
-
shouldParseNameAsAliases
protected boolean shouldParseNameAsAliases()Determine whether the element's "name" attribute should get parsed as bean definition aliases, i.e. alternative bean definition names.The default implementation returns
true
.- Returns:
- whether the parser should evaluate the "name" attribute as aliases
- Since:
- 4.1.5
-
shouldFireEvents
protected boolean shouldFireEvents()Determine whether this parser is supposed to fire aBeanComponentDefinition
event after parsing the bean definition.This implementation returns
true
by default; that is, an event will be fired when a bean definition has been completely parsed. Override this to returnfalse
in order to suppress the event.- Returns:
true
in order to fire a component registration event after parsing the bean definition;false
to suppress the event- See Also:
-
postProcessComponentDefinition
Hook method called after the primary parsing of aBeanComponentDefinition
but before theBeanComponentDefinition
has been registered with aBeanDefinitionRegistry
.Derived classes can override this method to supply any custom logic that is to be executed after all the parsing is finished.
The default implementation is a no-op.
- Parameters:
componentDefinition
- theBeanComponentDefinition
that is to be processed
-