Package org.codehaus.groovy.transform
Class RecordTypeASTTransformation
java.lang.Object
org.codehaus.groovy.transform.AbstractASTTransformation
org.codehaus.groovy.transform.RecordTypeASTTransformation
- All Implemented Interfaces:
CompilationUnitAware,ASTTransformation,ErrorCollecting
public class RecordTypeASTTransformation
extends AbstractASTTransformation
implements CompilationUnitAware
Handles generation of code for the @RecordType annotation.
-
Field Summary
FieldsFields inherited from class org.codehaus.groovy.transform.AbstractASTTransformation
RETENTION_CLASSNODE, sourceUnit -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionIf the transform is associated with a single annotation, returns a name suitable for displaying in error messages.protected GroovyClassLoaderstatic booleanrecordNative(ClassNode node) Indicates that the given classnode is a native JVM record class.voidSets the compilation unit currently applying this transformation.voidvisit(ASTNode[] nodes, SourceUnit source) The method is invoked when an AST Transformation is active.static booleanwouldBeNativeRecord(ClassNode cNode, String targetBytecode) Predicts whethercNodewill be compiled as a native JVM record.Methods inherited from class org.codehaus.groovy.transform.AbstractASTTransformation
addError, checkIncludeExcludeUndefinedAware, checkIncludeExcludeUndefinedAware, checkNotInterface, checkPropertyList, checkPropertyList, checkPropertyList, copyAnnotatedNodeAnnotations, copyAnnotatedNodeAnnotations, deemedInternal, deemedInternalName, getMemberClassList, getMemberClassValue, getMemberClassValue, getMemberIntValue, getMemberStringList, getMemberStringValue, getMemberStringValue, getMemberValue, hasAnnotation, init, markAsInternal, memberHasValue, shouldSkip, shouldSkip, shouldSkip, shouldSkipOnDescriptorUndefinedAware, shouldSkipUndefinedAware, shouldSkipUndefinedAware, shouldSkipUndefinedAware, tokenize
-
Field Details
-
MY_TYPE
-
-
Constructor Details
-
RecordTypeASTTransformation
public RecordTypeASTTransformation()
-
-
Method Details
-
getAnnotationName
Description copied from class:AbstractASTTransformationIf the transform is associated with a single annotation, returns a name suitable for displaying in error messages.- Overrides:
getAnnotationNamein classAbstractASTTransformation- Returns:
- The simple name of the annotation including the "@" or null if no such name is defined
-
setCompilationUnit
Description copied from interface:CompilationUnitAwareSets the compilation unit currently applying this transformation.- Specified by:
setCompilationUnitin interfaceCompilationUnitAware- Parameters:
unit- the active compilation unit
-
getTransformLoader
-
recordNative
Indicates that the given classnode is a native JVM record class. For classes being compiled, this will only be valid after theRecordTypeASTTransformationtransform has been invoked. -
wouldBeNativeRecord
Predicts whethercNodewill be compiled as a native JVM record. Mirrors the decision logic indoProcessRecordType(org.codehaus.groovy.ast.ClassNode, groovy.transform.options.PropertyHandler)(presence of@RecordBase, target bytecode>= 16, and@RecordOptions(mode != EMULATE)) so callers running before the transform itself fires can act on the same outcome.The joint-compilation stub generator uses this at
Phases.CONVERSIONto decide whether to emitrecord Foo(...)syntax. UnlikerecordNative(ClassNode), which inspects the post-transform super class, this predicate inspects only the source-level annotations.- Parameters:
cNode- the candidate class nodetargetBytecode- the target bytecode level (seeCompilerConfiguration.getTargetBytecode())- Since:
- 6.0.0
-
visit
Description copied from interface:ASTTransformationThe method is invoked when an AST Transformation is active. For local transformations, it is invoked once each time the local annotation is encountered. For global transformations, it is invoked once for every source unit, which is typically a source file.- Specified by:
visitin interfaceASTTransformation- Parameters:
nodes- The ASTnodes when the call was triggered. Element 0 is the AnnotationNode that triggered this annotation to be activated. Element 1 is the AnnotatedNode decorated, such as a MethodNode or ClassNode. For global transformations it is usually safe to ignore this parameter.source- The source unit being compiled. The source unit may contain several classes. For global transformations, information about the AST can be retrieved from this object.
-