|
Groovy 1.8.4 | |||||||
FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectgroovy.lang.GroovyObjectSupport
groovy.lang.Binding
groovy.util.FactoryBuilderSupport
public abstract class FactoryBuilderSupport extends Binding
Mix of BuilderSupport and SwingBuilder's factory support. Warning: this implementation is not thread safe and should not be used across threads in a multi-threaded environment. A locking mechanism should be implemented by the subclass if use is expected across multiple threads.
Field Summary | |
---|---|
static String |
CHILD_BUILDER
|
static String |
CURRENT_BUILDER
|
static String |
CURRENT_FACTORY
|
static String |
CURRENT_NAME
|
static String |
CURRENT_NODE
|
static String |
OWNER
|
static String |
PARENT_BUILDER
|
static String |
PARENT_CONTEXT
|
static String |
PARENT_FACTORY
|
static String |
PARENT_NAME
|
static String |
PARENT_NODE
|
static String |
SCRIPT_CLASS_NAME
|
protected LinkedList |
attributeDelegates
|
protected boolean |
autoRegistrationComplete
|
protected boolean |
autoRegistrationRunning
|
protected Map |
explicitMethods
|
protected Map |
explicitProperties
|
protected LinkedList |
postInstantiateDelegates
|
protected LinkedList |
postNodeCompletionDelegates
|
protected LinkedList |
preInstantiateDelegates
|
protected Map |
registrationGroup
|
protected String |
registrationGroupName
|
Constructor Summary | |
FactoryBuilderSupport()
|
|
FactoryBuilderSupport(boolean init)
|
Method Summary | |
---|---|
Closure
|
addAttributeDelegate(Closure attrDelegate)
Add an attribute delegate so it can intercept attributes being set. |
void
|
addDisposalClosure(Closure closure)
|
Closure
|
addPostInstantiateDelegate(Closure delegate)
Add a postInstantiate delegate so it can intercept nodes after they are created. |
Closure
|
addPostNodeCompletionDelegate(Closure delegate)
Add a nodeCompletion delegate so it can intercept nodes after they done with building. |
Closure
|
addPreInstantiateDelegate(Closure delegate)
Add a preInstantiate delegate so it can intercept nodes before they are created. |
void
|
autoRegisterNodes()
Ask the nodes to be registered |
Object
|
build(Class viewClass)
|
Object
|
build(Script script)
|
Object
|
build(String script, GroovyClassLoader loader)
|
protected boolean
|
checkExplicitMethod(String methodName, Object args, Reference result)
|
static void
|
checkValueIsNull(Object value, Object name)
Throws an exception if value is null. |
static boolean
|
checkValueIsType(Object value, Object name, Class type)
Checks type of value against builder type |
static boolean
|
checkValueIsTypeNotString(Object value, Object name, Class type)
Checks values against factory's type |
protected Object
|
createNode(Object name, Map attributes, Object value)
This method is responsible for instantiating a node and configure its properties. |
protected Object
|
dispathNodeCall(Object name, Object args)
|
void
|
dispose()
|
List
|
getAttributeDelegates()
|
FactoryBuilderSupport
|
getChildBuilder()
|
Map
|
getContext()
@return the context of the current node. |
Object
|
getContextAttribute(String key)
|
protected LinkedList
|
getContexts()
@return the stack of available contexts. |
protected Map
|
getContinuationData()
Stores the thread local states in a Map that can be passed across threads |
Object
|
getCurrent()
@return the current node being built. |
FactoryBuilderSupport
|
getCurrentBuilder()
@return the builder that built the current node. |
Factory
|
getCurrentFactory()
@return the factory that built the current node. |
String
|
getCurrentName()
@return the factory of the parent of the current node. |
Map
|
getExplicitMethods()
@return the explicit methods map (Unmodifiable Map). |
Map
|
getExplicitProperties()
@return the explicit properties map (Unmodifiable Map). |
Map
|
getFactories()
@return the factory map (Unmodifiable Map). |
Map
|
getLocalExplicitMethods()
@return the explicit methods map (Unmodifiable Map). |
Map
|
getLocalExplicitProperties()
@return the explicit properties map (Unmodifiable Map). |
Map
|
getLocalFactories()
@return the factory map (Unmodifiable Map). |
Object
|
getName(String methodName)
A hook to allow names to be converted into some other object such as a QName in XML or ObjectName in JMX. |
Closure
|
getNameMappingClosure()
|
Map
|
getParentContext()
@return the context of the parent of the current node. |
Factory
|
getParentFactory()
@return the factory of the parent of the current node. |
String
|
getParentName()
@return the name of the parent of the current node. |
Object
|
getParentNode()
@return the node of the parent of the current node. |
List
|
getPostInstantiateDelegates()
|
List
|
getPostNodeCompletionDelegates()
|
List
|
getPreInstantiateDelegates()
|
Object
|
getProperty(String property)
Overloaded to make variables appear as bean properties or via the subscript operator |
protected FactoryBuilderSupport
|
getProxyBuilder()
Proxy builders are useful for changing the building context, thus enabling mix & match builders. |
Set
|
getRegistrationGroupItems(String group)
|
Set
|
getRegistrationGroups()
|
Object
|
getVariable(String name)
@param name the name of the variable to lookup |
Map
|
getVariables()
|
protected void
|
handleNodeAttributes(Object node, Map attributes)
Assigns any existing properties to the node. |
Object
|
invokeMethod(String methodName)
Convenience method when no arguments are required |
Object
|
invokeMethod(String methodName, Object args)
|
protected void
|
newContext()
Pushes a new context on the stack. |
protected void
|
nodeCompleted(Object parent, Object node)
A hook to allow nodes to be processed once they have had all of their children applied. |
protected Map
|
popContext()
Removes the last context from the stack. |
protected void
|
postInstantiate(Object name, Map attributes, Object node)
A hook after the factory creates the node and before attributes are set. |
protected Object
|
postNodeCompletion(Object parent, Object node)
A hook to allow nodes to be processed once they have had all of their children applied and allows the actual node object that represents the Markup element to be changed. |
protected void
|
preInstantiate(Object name, Map attributes, Object value)
A hook before the factory creates the node. |
void
|
registerBeanFactory(String theName, Class beanClass)
Registers a factory for a JavaBean. |
void
|
registerBeanFactory(String theName, String groupName, Class beanClass)
Registers a factory for a JavaBean. |
void
|
registerExplicitMethod(String name, Closure closure)
|
void
|
registerExplicitMethod(String name, String groupName, Closure closure)
|
void
|
registerExplicitProperty(String name, Closure getter, Closure setter)
|
void
|
registerExplicitProperty(String name, String groupName, Closure getter, Closure setter)
|
void
|
registerFactory(String name, Factory factory)
Registers a factory for a node name. |
void
|
registerFactory(String name, String groupName, Factory factory)
Registers a factory for a node name. |
void
|
removeAttributeDelegate(Closure attrDelegate)
Remove the most recently added instance of the attribute delegate. |
void
|
removePostInstantiateDelegate(Closure delegate)
Remove the most recently added instance of the postInstantiate delegate. |
void
|
removePostNodeCompletionDelegate(Closure delegate)
Remove the most recently added instance of the nodeCompletion delegate. |
void
|
removePreInstantiateDelegate(Closure delegate)
Remove the most recently added instance of the preInstantiate delegate. |
protected void
|
reset()
Clears the context stack. |
protected Closure
|
resolveExplicitMethod(String methodName, Object args)
This is a hook for subclasses to plugin a custom strategy for mapping names to explicit methods. |
protected Closure[]
|
resolveExplicitProperty(String propertyName)
This is a hook for subclasses to plugin a custom strategy for mapping names to property methods. |
protected Factory
|
resolveFactory(Object name, Map attributes, Object value)
This is a hook for subclasses to plugin a custom strategy for mapping names to factories. |
protected void
|
restoreFromContinuationData(Map data)
Restores the state of the current builder to the same state as an older build. |
protected void
|
setClosureDelegate(Closure closure, Object node)
A strategy method to allow derived builders to use builder-trees and switch in different kinds of builders. |
void
|
setNameMappingClosure(Closure nameMappingClosure)
|
protected void
|
setNodeAttributes(Object node, Map attributes)
Maps attributes key/values to properties on node. |
protected void
|
setParent(Object parent, Object child)
Strategy method to establish parent/child relationships. |
void
|
setProperty(String property, Object newValue)
Overloaded to make variables appear as bean properties or via the subscript operator |
protected void
|
setProxyBuilder(FactoryBuilderSupport proxyBuilder)
Sets the builder to be used as a proxy. |
void
|
setVariable(String name, Object value)
Sets the value of the given variable |
Object
|
withBuilder(FactoryBuilderSupport builder, Closure closure)
Switches the builder's proxyBuilder during the execution of a closure. |
Object
|
withBuilder(FactoryBuilderSupport builder, String name, Closure closure)
Switches the builder's proxyBuilder during the execution of a closure. |
Object
|
withBuilder(Map attributes, FactoryBuilderSupport builder, String name, Closure closure)
Switches the builder's proxyBuilder during the execution of a closure. |
Methods inherited from class Binding | |
---|---|
getProperty, getVariable, getVariables, setProperty, setVariable |
Methods inherited from class GroovyObjectSupport | |
---|---|
getMetaClass, getProperty, invokeMethod, setMetaClass, setProperty |
Methods inherited from class Object | |
---|---|
wait, wait, wait, equals, toString, hashCode, getClass, notify, notifyAll |
Field Detail |
---|
public static final String CHILD_BUILDER
public static final String CURRENT_BUILDER
public static final String CURRENT_FACTORY
public static final String CURRENT_NAME
public static final String CURRENT_NODE
public static final String OWNER
public static final String PARENT_BUILDER
public static final String PARENT_CONTEXT
public static final String PARENT_FACTORY
public static final String PARENT_NAME
public static final String PARENT_NODE
public static final String SCRIPT_CLASS_NAME
protected LinkedList attributeDelegates
protected boolean autoRegistrationComplete
protected boolean autoRegistrationRunning
protected Map explicitMethods
protected Map explicitProperties
protected LinkedList postInstantiateDelegates
protected LinkedList postNodeCompletionDelegates
protected LinkedList preInstantiateDelegates
protected Map registrationGroup
protected String registrationGroupName
Constructor Detail |
---|
public FactoryBuilderSupport()
public FactoryBuilderSupport(boolean init)
Method Detail |
---|
public Closure addAttributeDelegate(Closure attrDelegate)
attrDelegate
- the closure to be called
public void addDisposalClosure(Closure closure)
public Closure addPostInstantiateDelegate(Closure delegate)
delegate
- the closure to invoke
public Closure addPostNodeCompletionDelegate(Closure delegate)
delegate
- the closure to invoke
public Closure addPreInstantiateDelegate(Closure delegate)
delegate
- the closure to invoke
public void autoRegisterNodes()
public Object build(Class viewClass)
public Object build(Script script)
public Object build(String script, GroovyClassLoader loader)
protected boolean checkExplicitMethod(String methodName, Object args, Reference result)
public static void checkValueIsNull(Object value, Object name)
value
- the node's valuename
- the node's name
public static boolean checkValueIsType(Object value, Object name, Class type)
value
- the node's valuename
- the node's nametype
- a Class that may be assignable to the value's class
public static boolean checkValueIsTypeNotString(Object value, Object name, Class type)
value
- the node's valuename
- the node's nametype
- a Class that may be assignable to the value's class
protected Object createNode(Object name, Map attributes, Object value)
name
- the name of the nodeattributes
- the attributes for the nodevalue
- the value arguments for the node
protected Object dispathNodeCall(Object name, Object args)
public void dispose()
public List getAttributeDelegates()
public FactoryBuilderSupport getChildBuilder()
public Map getContext()
public Object getContextAttribute(String key)
protected LinkedList getContexts()
protected Map getContinuationData()
public Object getCurrent()
public FactoryBuilderSupport getCurrentBuilder()
public Factory getCurrentFactory()
public String getCurrentName()
public Map getExplicitMethods()
public Map getExplicitProperties()
public Map getFactories()
public Map getLocalExplicitMethods()
public Map getLocalExplicitProperties()
public Map getLocalFactories()
public Object getName(String methodName)
methodName
- the name of the desired method
public Closure getNameMappingClosure()
public Map getParentContext()
public Factory getParentFactory()
public String getParentName()
public Object getParentNode()
public List getPostInstantiateDelegates()
public List getPostNodeCompletionDelegates()
public List getPreInstantiateDelegates()
public Object getProperty(String property)
protected FactoryBuilderSupport getProxyBuilder()
public Set getRegistrationGroupItems(String group)
public Set getRegistrationGroups()
public Object getVariable(String name)
name
- the name of the variable to lookup
public Map getVariables()
protected void handleNodeAttributes(Object node, Map attributes)
node
- the object returned by tne node factoryattributes
- the attributes for the node
public Object invokeMethod(String methodName)
methodName
- the name of the method to invoke
public Object invokeMethod(String methodName, Object args)
protected void newContext()
protected void nodeCompleted(Object parent, Object node)
node
- the current node being processedparent
- the parent of the node being processed
protected Map popContext()
protected void postInstantiate(Object name, Map attributes, Object node)
name
- the name of the nodeattributes
- the attributes for the nodenode
- the object created by the node factory
protected Object postNodeCompletion(Object parent, Object node)
node
- the current node being processedparent
- the parent of the node being processed
protected void preInstantiate(Object name, Map attributes, Object value)
name
- the name of the nodeattributes
- the attributes of the nodevalue
- the value argument(s) of the node
public void registerBeanFactory(String theName, Class beanClass)
theName
- name of the nodebeanClass
- the factory to handle the name
public void registerBeanFactory(String theName, String groupName, Class beanClass)
theName
- name of the nodegroupName
- thr group to register this node inbeanClass
- the factory to handle the name
public void registerExplicitMethod(String name, Closure closure)
public void registerExplicitMethod(String name, String groupName, Closure closure)
public void registerExplicitProperty(String name, Closure getter, Closure setter)
public void registerExplicitProperty(String name, String groupName, Closure getter, Closure setter)
public void registerFactory(String name, Factory factory)
name
- the name of the nodefactory
- the factory to return the values
public void registerFactory(String name, String groupName, Factory factory)
name
- the name of the nodegroupName
- thr group to register this node infactory
- the factory to return the values
public void removeAttributeDelegate(Closure attrDelegate)
attrDelegate
- the instance of the closure to be removed
public void removePostInstantiateDelegate(Closure delegate)
delegate
- the closure to invoke
public void removePostNodeCompletionDelegate(Closure delegate)
delegate
- the closure to be removed
public void removePreInstantiateDelegate(Closure delegate)
delegate
- the closure to invoke
protected void reset()
@SuppressWarnings({"UnusedDeclaration"}) protected Closure resolveExplicitMethod(String methodName, Object args)
methodName
- the name of the explicit methodargs
- the arguments for the method
protected Closure[] resolveExplicitProperty(String propertyName)
propertyName
- the name of the explicit method
protected Factory resolveFactory(Object name, Map attributes, Object value)
name
- the name of the factoryattributes
- the attributes from the nodevalue
- value arguments from te node
protected void restoreFromContinuationData(Map data)
data
- the data retrieved from a compatible getContinuationData call
@SuppressWarnings({"UnusedDeclaration"}) protected void setClosureDelegate(Closure closure, Object node)
closure
- the closure on which to call setDelegate()node
- the node value that we've just created, which could be a
builder
public void setNameMappingClosure(Closure nameMappingClosure)
protected void setNodeAttributes(Object node, Map attributes)
node
- the object from the nodeattributes
- the attributes to be set
protected void setParent(Object parent, Object child)
parent
- the object from the parent nodechild
- the object from the child node
public void setProperty(String property, Object newValue)
protected void setProxyBuilder(FactoryBuilderSupport proxyBuilder)
proxyBuilder
- the new proxy
public void setVariable(String name, Object value)
name
- the name of the variable to setvalue
- the new value for the given variable
public Object withBuilder(FactoryBuilderSupport builder, Closure closure)
builder
- the temporary builder to switch to as proxyBuilder.closure
- the closure to be executed under the temporary builder.
public Object withBuilder(FactoryBuilderSupport builder, String name, Closure closure)
builder
- the temporary builder to switch to as proxyBuilder.name
- the node to build on the 'parent' builder.closure
- the closure to be executed under the temporary builder.
public Object withBuilder(Map attributes, FactoryBuilderSupport builder, String name, Closure closure)
attributes
- additional properties for the node on the parent builder.builder
- the temporary builder to switch to as proxyBuilder.name
- the node to build on the 'parent' builder.closure
- the closure to be executed under the temporary builder.
Copyright © 2003-2011 The Codehaus. All rights reserved.