Package org.codehaus.groovy.transform
Class SealedASTTransformation
java.lang.Object
org.codehaus.groovy.transform.AbstractASTTransformation
org.codehaus.groovy.transform.SealedASTTransformation
- All Implemented Interfaces:
ASTTransformation,ErrorCollecting
Handles generation of code for the @Sealed annotation.
-
Field Summary
FieldsFields inherited from class org.codehaus.groovy.transform.AbstractASTTransformation
RETENTION_CLASSNODE, sourceUnit -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionReturns the explicitly-declared permitted-subclass list forcNode, either from the populatedpermittedSubclassesfield (after the transform has run) or from the@Sealedannotation'spermittedSubclassesmember.Returns the effective permitted-subclass list forcNode: the explicitly-declared list when present, otherwise the inferred list obtained by scanning the enclosing compilation unit for direct subtypes (mirroringSealedCompletionASTTransformation).static booleansealedNative(AnnotatedNode node) Reports true if native sealed class information should be written into the bytecode.static booleanReports true if theSealedannotation should not be included in the bytecode for a sealed or emulated-sealed class.static booleanReports whether the source forcNodeuses@SealedOptions(alwaysAnnotate=false)— independent of compile-phase ordering, so callers earlier thanSEMANTIC_ANALYSIScan use it.voidvisit(ASTNode[] nodes, SourceUnit source) The method is invoked when an AST Transformation is active.static booleanwouldBeNativeSealed(ClassNode cNode, String targetBytecode) Reports whethercNodewould receive native sealed bytecode for the giventargetBytecodelevel.Methods inherited from class org.codehaus.groovy.transform.AbstractASTTransformation
addError, checkIncludeExcludeUndefinedAware, checkIncludeExcludeUndefinedAware, checkNotInterface, checkPropertyList, checkPropertyList, checkPropertyList, copyAnnotatedNodeAnnotations, copyAnnotatedNodeAnnotations, deemedInternal, deemedInternalName, getAnnotationName, getMemberClassList, getMemberClassValue, getMemberClassValue, getMemberIntValue, getMemberStringList, getMemberStringValue, getMemberStringValue, getMemberValue, hasAnnotation, init, markAsInternal, memberHasValue, shouldSkip, shouldSkip, shouldSkip, shouldSkipOnDescriptorUndefinedAware, shouldSkipUndefinedAware, shouldSkipUndefinedAware, shouldSkipUndefinedAware, tokenize
-
Field Details
-
SEALED_ALWAYS_ANNOTATE
Deprecated.- See Also:
-
-
Constructor Details
-
SealedASTTransformation
public SealedASTTransformation()
-
-
Method Details
-
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.- 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.
-
sealedNative
Reports true if native sealed class information should be written into the bytecode. Will only ever return true after the SealedASTTransformation visit method has completed.- Returns:
- true for a native sealed class
-
sealedSkipAnnotation
Reports true if theSealedannotation should not be included in the bytecode for a sealed or emulated-sealed class. Will only ever return true after theSealedASTTransformationtransform has been invoked.- Returns:
- true if a
Sealedannotation is not required for this node
-
wouldBeNativeSealed
Reports whethercNodewould receive native sealed bytecode for the giventargetBytecodelevel. Independent of compile-phase ordering, so callers earlier thanSEMANTIC_ANALYSIS(e.g. the joint-compile stub generator) can use it.- Parameters:
cNode- the class being checkedtargetBytecode- the target bytecode level (seeCompilerConfiguration.getTargetBytecode())
-
getDeclaredPermittedSubclasses
Returns the explicitly-declared permitted-subclass list forcNode, either from the populatedpermittedSubclassesfield (after the transform has run) or from the@Sealedannotation'spermittedSubclassesmember. An empty list means no explicit list is declared in source — inference happens later viaSealedCompletionASTTransformation. Independent of compile-phase ordering, so callers earlier thanSEMANTIC_ANALYSIScan use it. -
getEffectivePermittedSubclasses
Returns the effective permitted-subclass list forcNode: the explicitly-declared list when present, otherwise the inferred list obtained by scanning the enclosing compilation unit for direct subtypes (mirroringSealedCompletionASTTransformation). Phase independent, so callers earlier thanCANONICALIZATIONcan use it. -
sealedSkipAnnotationFromSource
Reports whether the source forcNodeuses@SealedOptions(alwaysAnnotate=false)— independent of compile-phase ordering, so callers earlier thanSEMANTIC_ANALYSIScan use it.
-