Class GroovyBeanDefinitionReader
- All Implemented Interfaces:
groovy.lang.GroovyObject
,BeanDefinitionReader
,EnvironmentCapable
This bean definition reader also understands XML bean definition files, allowing for seamless mixing and matching with Groovy bean definition files.
Typically applied to a
DefaultListableBeanFactory
or a GenericApplicationContext
,
but can be used against any BeanDefinitionRegistry
implementation.
Example Syntax
import org.hibernate.SessionFactory import org.apache.commons.dbcp.BasicDataSource def reader = new GroovyBeanDefinitionReader(myApplicationContext) reader.beans { dataSource(BasicDataSource) { // <--- invokeMethod driverClassName = "org.hsqldb.jdbcDriver" url = "jdbc:hsqldb:mem:grailsDB" username = "sa" // <-- setProperty password = "" settings = [mynew:"setting"] } sessionFactory(SessionFactory) { dataSource = dataSource // <-- getProperty for retrieving references } myService(MyService) { nestedBean = { AnotherBean bean -> // <-- setProperty with closure for nested bean dataSource = dataSource } } }
You can also load resources containing beans defined in a Groovy script using
either the AbstractBeanDefinitionReader.loadBeanDefinitions(Resource...)
or
AbstractBeanDefinitionReader.loadBeanDefinitions(String...)
method, with a script looking similar to
the following.
import org.hibernate.SessionFactory import org.apache.commons.dbcp.BasicDataSource beans { dataSource(BasicDataSource) { driverClassName = "org.hsqldb.jdbcDriver" url = "jdbc:hsqldb:mem:grailsDB" username = "sa" password = "" settings = [mynew:"setting"] } sessionFactory(SessionFactory) { dataSource = dataSource } myService(MyService) { nestedBean = { AnotherBean bean -> dataSource = dataSource } } }
- Since:
- 4.0
- Author:
- Jeff Brown, Graeme Rocher, Juergen Hoeller, Sam Brannen
- See Also:
-
Field Summary
Fields inherited from class org.springframework.beans.factory.support.AbstractBeanDefinitionReader
logger
-
Constructor Summary
ConstructorDescriptionCreate a newGroovyBeanDefinitionReader
for the givenBeanDefinitionRegistry
.GroovyBeanDefinitionReader
(XmlBeanDefinitionReader xmlBeanDefinitionReader) Create a newGroovyBeanDefinitionReader
based on the givenXmlBeanDefinitionReader
, loading bean definitions into itsBeanDefinitionRegistry
and delegating Groovy DSL loading to it. -
Method Summary
Modifier and TypeMethodDescriptionprotected void
applyPropertyToBeanDefinition
(String name, Object value) Define an inner bean definition.Define an inner bean definition.beans
(groovy.lang.Closure<?> closure) Defines a set of beans for the given block or closure.groovy.lang.Binding
Return a specified binding for Groovy variables, if any.groovy.lang.MetaClass
getProperty
(String name) This method overrides property retrieval in the scope of theGroovyBeanDefinitionReader
.void
importBeans
(String resourcePattern) Import Spring bean definitions from either XML or Groovy sources into the current bean builder instance.protected GroovyBeanDefinitionReader
invokeBeanDefiningClosure
(groovy.lang.Closure<?> callable) When a method argument is only a closure it is a set of bean definitions.invokeMethod
(String name, Object arg) This method overrides method invocation to create beans for each method name that takes a class argument.int
loadBeanDefinitions
(Resource resource) Load bean definitions from the specified Groovy script or XML file.int
loadBeanDefinitions
(EncodedResource encodedResource) Load bean definitions from the specified Groovy script or XML file.resolveConstructorArguments
(Object[] args, int start, int end) void
setBinding
(groovy.lang.Binding binding) Set the binding, i.e.void
setMetaClass
(groovy.lang.MetaClass metaClass) void
setProperty
(String name, Object value) This method overrides property setting in the scope of theGroovyBeanDefinitionReader
to set properties on the current bean definition.void
Define a Spring XML namespace definition to use.Methods inherited from class org.springframework.beans.factory.support.AbstractBeanDefinitionReader
getBeanClassLoader, getBeanNameGenerator, getEnvironment, getRegistry, getResourceLoader, loadBeanDefinitions, loadBeanDefinitions, loadBeanDefinitions, loadBeanDefinitions, setBeanClassLoader, setBeanNameGenerator, setEnvironment, setResourceLoader
-
Constructor Details
-
GroovyBeanDefinitionReader
Create a newGroovyBeanDefinitionReader
for the givenBeanDefinitionRegistry
.- Parameters:
registry
- theBeanDefinitionRegistry
to load bean definitions into
-
GroovyBeanDefinitionReader
Create a newGroovyBeanDefinitionReader
based on the givenXmlBeanDefinitionReader
, loading bean definitions into itsBeanDefinitionRegistry
and delegating Groovy DSL loading to it.The supplied
XmlBeanDefinitionReader
should typically be pre-configured with XML validation disabled.- Parameters:
xmlBeanDefinitionReader
- theXmlBeanDefinitionReader
to derive the registry from and to delegate Groovy DSL loading to
-
-
Method Details
-
setMetaClass
public void setMetaClass(groovy.lang.MetaClass metaClass) - Specified by:
setMetaClass
in interfacegroovy.lang.GroovyObject
-
getMetaClass
public groovy.lang.MetaClass getMetaClass()- Specified by:
getMetaClass
in interfacegroovy.lang.GroovyObject
-
setBinding
public void setBinding(groovy.lang.Binding binding) Set the binding, i.e. the Groovy variables available in the scope of aGroovyBeanDefinitionReader
closure. -
getBinding
Return a specified binding for Groovy variables, if any. -
loadBeanDefinitions
Load bean definitions from the specified Groovy script or XML file.Note that
".xml"
files will be parsed as XML content; all other kinds of resources will be parsed as Groovy scripts.- Specified by:
loadBeanDefinitions
in interfaceBeanDefinitionReader
- Parameters:
resource
- the resource descriptor for the Groovy script or XML file- Returns:
- the number of bean definitions found
- Throws:
BeanDefinitionStoreException
- in case of loading or parsing errors
-
loadBeanDefinitions
Load bean definitions from the specified Groovy script or XML file.Note that
".xml"
files will be parsed as XML content; all other kinds of resources will be parsed as Groovy scripts.- Parameters:
encodedResource
- the resource descriptor for the Groovy script or XML file, allowing specification of an encoding to use for parsing the file- Returns:
- the number of bean definitions found
- Throws:
BeanDefinitionStoreException
- in case of loading or parsing errors
-
beans
Defines a set of beans for the given block or closure.- Parameters:
closure
- the block or closure- Returns:
- this
GroovyBeanDefinitionReader
instance
-
bean
Define an inner bean definition.- Parameters:
type
- the bean type- Returns:
- the bean definition
-
bean
Define an inner bean definition.- Parameters:
type
- the bean typeargs
- the constructors arguments and closure configurer- Returns:
- the bean definition
-
xmlns
Define a Spring XML namespace definition to use.- Parameters:
definition
- the namespace definition
-
importBeans
Import Spring bean definitions from either XML or Groovy sources into the current bean builder instance.- Parameters:
resourcePattern
- the resource pattern- Throws:
IOException
-
invokeMethod
This method overrides method invocation to create beans for each method name that takes a class argument.- Specified by:
invokeMethod
in interfacegroovy.lang.GroovyObject
-
invokeBeanDefiningClosure
When a method argument is only a closure it is a set of bean definitions.- Parameters:
callable
- the closure argument- Returns:
- this
GroovyBeanDefinitionReader
instance
-
resolveConstructorArguments
-
setProperty
This method overrides property setting in the scope of theGroovyBeanDefinitionReader
to set properties on the current bean definition.- Specified by:
setProperty
in interfacegroovy.lang.GroovyObject
-
applyPropertyToBeanDefinition
-
getProperty
This method overrides property retrieval in the scope of theGroovyBeanDefinitionReader
. A property retrieval will either:- Retrieve a variable from the bean builder's binding if it exists
- Retrieve a RuntimeBeanReference for a specific bean if it exists
- Otherwise just delegate to MetaClass.getProperty which will resolve
properties from the
GroovyBeanDefinitionReader
itself
- Specified by:
getProperty
in interfacegroovy.lang.GroovyObject
-