Groovy 1.8.4

org.codehaus.groovy.control.customizers
[Groovy] Class ASTTransformationCustomizer

java.lang.Object
  CompilationUnit.PrimaryClassNodeOperation
      org.codehaus.groovy.control.customizers.CompilationCustomizer
          org.codehaus.groovy.control.customizers.ASTTransformationCustomizer

class ASTTransformationCustomizer
extends CompilationCustomizer

This customizer allows applying an AST transformation to a source unit with several strategies. Creating a customizer with the class constructor will trigger an AST transformation for each class node of a source unit. However, you cannot pass parameters to the annotation so the default values will be used. Writing :

     def configuration = new CompilerConfiguration()
     configuration.addCompilationCustomizers(new ASTTransformationCustomizer(Log))
     def shell = new GroovyShell(configuration)
     shell.evaluate("""
        class MyClass {

        }""")
 
is equivalent to :
     def shell = new GroovyShell()
     shell.evaluate("""
        @Log
        class MyClass {

        }""")
 
The class passed as a constructor parameter must be an AST transformation annotation. Alternatively, you can apply a global AST transformation by calling the AST transformation. In that case, the transformation is applied once for the whole source unit. Unlike a global AST transformation declared in the META-INF/services/org.codehaus.groovy.transform.ASTTransformation file, which are applied if the file is in the classpath, using this customizer you'll have the choice to apply your transformation selectively. It can also be useful to debug global AST transformations without having to package your annotation in a jar file.
Authors:
Cedric Champeau
Since:
1.8.0


Constructor Summary
ASTTransformationCustomizer(Class transformationAnnotation)

ASTTransformationCustomizer(ASTTransformation transformation)

ASTTransformationCustomizer(Map annotationParams, Class transformationAnnotation)

ASTTransformationCustomizer(Map annotationParams, ASTTransformation transformation)

 
Method Summary
void call(SourceUnit source, GeneratorContext context, ClassNode classNode)

void setAnnotationParameters(Map params)

Specify annotation parameters.

 
Methods inherited from class CompilationCustomizer
getPhase
 

Constructor Detail

ASTTransformationCustomizer

ASTTransformationCustomizer(Class transformationAnnotation)


ASTTransformationCustomizer

ASTTransformationCustomizer(ASTTransformation transformation)


ASTTransformationCustomizer

ASTTransformationCustomizer(Map annotationParams, Class transformationAnnotation)


ASTTransformationCustomizer

ASTTransformationCustomizer(Map annotationParams, ASTTransformation transformation)


 
Method Detail

call

@Override
void call(SourceUnit source, GeneratorContext context, ClassNode classNode)


setAnnotationParameters

void setAnnotationParameters(Map params)
Specify annotation parameters. For example, if the annotation is :
@Log(value='logger')
You could create an AST transformation customizer and specify the "value" parameter thanks to this method:
annotationParameters = [value: 'logger']

 Note that you cannot specify annotation closure values directly. If the annotation you want to add takes
 a closure as an argument, you will have to set a ClosureExpression instead. This can be done by either
 creating a custom ClosureExpression from code, or using the AstBuilder.

 Here is an example :
 
        // add @Contract({distance >= 0 })
        customizer = new ASTTransformationCustomizer(Contract)
        final expression = new AstBuilder().buildFromCode(CompilePhase.CONVERSION) {->
            distance >= 0
        }.expression[0]
        customizer.annotationParameters = [value: expression]
Parameters:
params - the annotation parameters
Since:
1.8.1


 

Copyright © 2003-2011 The Codehaus. All rights reserved.