|
Groovy Documentation | |||||||
FRAMES NO FRAMES All Classes | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object groovy.beans.BindableASTTransformation groovy.beans.VetoableASTTransformation
@GroovyASTTransformation(phase = CompilePhase.CANONICALIZATION) public class VetoableASTTransformation extends BindableASTTransformation
Handles generation of code for the @Vetoable annotation, and @Bindable if also present.
Generally, it adds (if needed) a VetoableChangeSupport field and the needed add/removeVetoableChangeListener methods to support the listeners.
It also generates the setter and wires the setter through the VetoableChangeSupport.
If a Bindable annotation is detected it also adds support similar to what BindableASTTransformation would do.
Field Summary | |
---|---|
protected static ClassNode |
constrainedClassNode
|
protected ClassNode |
vcsClassNode
|
Fields inherited from class BindableASTTransformation | |
---|---|
boundClassNode, pcsClassNode |
Method Summary | |
---|---|
protected void
|
addVetoableChangeSupport(ClassNode declaringClass)
|
protected Statement
|
createConstrainedStatement(PropertyNode propertyNode, Expression fieldExpression)
Creates a statement body similar to:
|
protected Statement
|
createSetStatement(Expression fieldExpression)
Creates a statement body similar to:
|
protected void
|
createSetterMethod(ClassNode declaringClass, PropertyNode propertyNode, java.lang.String setterName, Statement setterBlock)
Creates a setter method with the given body. |
static boolean
|
hasVetoableAnnotation(AnnotatedNode node)
Convenience method to see if an annotated node is @Vetoable. |
protected boolean
|
needsVetoableChangeSupport(ClassNode declaringClass, SourceUnit sourceUnit)
|
void
|
visit(ASTNode[] nodes, SourceUnit source)
Handles the bulk of the processing, mostly delegating to other methods. |
Methods inherited from class BindableASTTransformation | |
---|---|
addPropertyChangeSupport, createBindableStatement, createSetterMethod, hasBindableAnnotation, needsPropertyChangeSupport, visit |
Methods inherited from class java.lang.Object | |
---|---|
java.lang.Object#wait(long, int), java.lang.Object#wait(long), java.lang.Object#wait(), java.lang.Object#equals(java.lang.Object), java.lang.Object#toString(), java.lang.Object#hashCode(), java.lang.Object#getClass(), java.lang.Object#notify(), java.lang.Object#notifyAll() |
Field Detail |
---|
protected static ClassNode constrainedClassNode
protected ClassNode vcsClassNode
Method Detail |
---|
protected void addVetoableChangeSupport(ClassNode declaringClass)
protected Statement createConstrainedStatement(PropertyNode propertyNode, Expression fieldExpression)
this.fireVetoableChange("field", field, field = value)
propertyNode
- the field node for the propertyfieldExpression
- a field expression for setting the property value
protected Statement createSetStatement(Expression fieldExpression)
field = value
.
Used when the field is not also
protected void createSetterMethod(ClassNode declaringClass, PropertyNode propertyNode, java.lang.String setterName, Statement setterBlock)
This differs from normal setters in that we need to add a declared exception java.beans.PropertyVetoException
declaringClass
- the class to which we will add the setterpropertyNode
- the field to back the settersetterName
- the name of the settersetterBlock
- the statement representing the setter block
public static boolean hasVetoableAnnotation(AnnotatedNode node)
node
- the node to check
protected boolean needsVetoableChangeSupport(ClassNode declaringClass, SourceUnit sourceUnit)
public void visit(ASTNode[] nodes, SourceUnit source)
nodes
- the AST nodessource
- the source unit for the nodes
Groovy Documentation