public interface Lifecycle
Specifies life-cycle hook-ins for applying AST transformation logic before and after the annotation processors have been run.
During execution of GContracts AST transformations, the following process is applied on each ClassNode instance which qualifies for contract annotations:
In order to support Groovy 1.7.x GContracts backported Groovy 1.8 handling of annotation closures. This is done by extracting ClosureExpression from annotations and creating Closure implementation classes.
AnnotationProcessor implementations are used to modify domain classes found in org.apache.groovy.contracts.domain. For that reason, concrete annotation processor often don't modify AST nodes directly, but simply work with domain classes like Contract. Whenever an annotation processor is done, it has finished its work on the underlying domain model.
beforeProcessingClassNode(ProcessingContextInformation, org.codehaus.groovy.ast.ClassNode), beforeProcessingMethodNode(ProcessingContextInformation, org.codehaus.groovy.ast.ClassNode, org.codehaus.groovy.ast.MethodNode), beforeProcessingConstructorNode(ProcessingContextInformation, org.codehaus.groovy.ast.ClassNode, org.codehaus.groovy.ast.MethodNode) are fired before annotation processors are executed.
Takes a look at the domain model instances and generates the corresponding AST transformation code.
afterProcessingClassNode(ProcessingContextInformation, org.codehaus.groovy.ast.ClassNode), afterProcessingMethodNode(ProcessingContextInformation, org.codehaus.groovy.ast.ClassNode, org.codehaus.groovy.ast.MethodNode), afterProcessingConstructorNode(ProcessingContextInformation, org.codehaus.groovy.ast.ClassNode, org.codehaus.groovy.ast.MethodNode) are fired after domain model conversion and injection is done.
| Type Params | Return Type | Name and description |
|---|---|---|
|
public void |
afterProcessingClassNode(ProcessingContextInformation processingContextInformation, ClassNode classNode)Runs after class-level processing and domain-model injection are complete. |
|
public void |
afterProcessingConstructorNode(ProcessingContextInformation processingContextInformation, ClassNode classNode, MethodNode constructorNode)Runs after constructor-level processing and domain-model injection are complete. |
|
public void |
afterProcessingMethodNode(ProcessingContextInformation processingContextInformation, ClassNode classNode, MethodNode methodNode)Runs after method-level processing and domain-model injection are complete. |
|
public void |
beforeProcessingClassNode(ProcessingContextInformation processingContextInformation, ClassNode classNode)Runs before class-level annotation processors are applied. |
|
public void |
beforeProcessingConstructorNode(ProcessingContextInformation processingContextInformation, ClassNode classNode, MethodNode constructorNode)Runs before constructor-level annotation processors are applied. |
|
public void |
beforeProcessingMethodNode(ProcessingContextInformation processingContextInformation, ClassNode classNode, MethodNode methodNode)Runs before method-level annotation processors are applied. |
Runs after class-level processing and domain-model injection are complete.
processingContextInformation - the current processing contextclassNode - the processed classRuns after constructor-level processing and domain-model injection are complete.
processingContextInformation - the current processing contextclassNode - the declaring classconstructorNode - the processed constructorRuns after method-level processing and domain-model injection are complete.
processingContextInformation - the current processing contextclassNode - the declaring classmethodNode - the processed methodRuns before class-level annotation processors are applied.
processingContextInformation - the current processing contextclassNode - the class about to be processedRuns before constructor-level annotation processors are applied.
processingContextInformation - the current processing contextclassNode - the declaring classconstructorNode - the constructor about to be processedRuns before method-level annotation processors are applied.
processingContextInformation - the current processing contextclassNode - the declaring classmethodNode - the method about to be processed