Package groovy.util
Class ProxyGenerator
java.lang.Object
groovy.util.ProxyGenerator
Generates 'Proxy' objects which implement interfaces, maps of closures and/or
extend classes/delegates.
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionboolean
getDebug()
boolean
instantiateAggregate
(List<Class> interfaces) instantiateAggregate
(Map closureMap, List<Class> interfaces) instantiateAggregate
(Map closureMap, List<Class> interfaces, Class clazz) instantiateAggregateFromBaseClass
(Closure cl, Class clazz) instantiateAggregateFromBaseClass
(Class clazz, Object[] constructorArgs) instantiateAggregateFromBaseClass
(Map map, Class clazz) instantiateAggregateFromBaseClass
(Map map, Class clazz, Object[] constructorArgs) instantiateAggregateFromInterface
(Map map, Class clazz) instantiateDelegate
(Object delegate) instantiateDelegate
(List<Class> interfaces, Object delegate) instantiateDelegate
(Map closureMap, List<Class> interfaces, Object delegate) instantiateDelegateWithBaseClass
(Map closureMap, List<Class> interfaces, Object delegate) instantiateDelegateWithBaseClass
(Map closureMap, List<Class> interfaces, Object delegate, Class baseClass) instantiateDelegateWithBaseClass
(Map closureMap, List<Class> interfaces, Object delegate, Class baseClass, String name) Creates a proxy with a delegate object.void
setDebug
(boolean debug) InstructsProxyGenerator
to dump generated Groovy source code to standard output during construction.void
setEmptyMethods
(boolean emptyMethods) Changes generated methods to have empty implementations.void
setOverride
(ClassLoader override)
-
Field Details
-
INSTANCE
-
-
Constructor Details
-
ProxyGenerator
public ProxyGenerator()
-
-
Method Details
-
getDebug
public boolean getDebug() -
setDebug
public void setDebug(boolean debug) InstructsProxyGenerator
to dump generated Groovy source code to standard output during construction. This is useful for debugging purposes but should be turned off in production.- Parameters:
debug
- true if you want generated source to be printed
-
getEmptyMethods
public boolean getEmptyMethods() -
setEmptyMethods
public void setEmptyMethods(boolean emptyMethods) Changes generated methods to have empty implementations.Methods in generated aggregates not supplied in a closures map or base class are given 'default' implementations. The implementation will normally throw an
UnsupportedOperationException
but setting this boolean will leave it empty.- Parameters:
emptyMethods
- true if you want generated methods to be empty
-
getOverride
-
setOverride
-
instantiateAggregateFromBaseClass
-
instantiateAggregateFromBaseClass
-
instantiateAggregateFromBaseClass
-
instantiateAggregateFromBaseClass
-
instantiateAggregateFromBaseClass
public GroovyObject instantiateAggregateFromBaseClass(Map map, Class clazz, Object[] constructorArgs) -
instantiateAggregateFromInterface
-
instantiateAggregateFromInterface
-
instantiateAggregate
-
instantiateAggregate
-
instantiateAggregate
-
instantiateAggregate
-
instantiateDelegate
-
instantiateDelegate
-
instantiateDelegate
-
instantiateDelegateWithBaseClass
public GroovyObject instantiateDelegateWithBaseClass(Map closureMap, List<Class> interfaces, Object delegate) -
instantiateDelegateWithBaseClass
-
instantiateDelegateWithBaseClass
public GroovyObject instantiateDelegateWithBaseClass(Map closureMap, List<Class> interfaces, Object delegate, Class baseClass, String name) Creates a proxy with a delegate object.- Parameters:
closureMap
- the closure for methods not handled by the delegateinterfaces
- interfaces to be implementeddelegate
- the delegate objectbaseClass
- the base classname
- the name of the proxy, unused, but kept for compatibility with previous versions of Groovy.- Returns:
- a proxy object implementing the specified interfaces, and delegating to the provided object
-