|
Groovy Documentation | |||||||
| FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||
java.lang.Objectgroovy.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 @Bindable.
fieldExpression - a field expression for setting the property value
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