Processorpublic abstract class AbstractProcessor extends Object implements Processor
The getter methods may issue warnings about noteworthy conditions using the facilities available after the processor has been initialized.
Subclasses are free to override the implementation and specification of any of the methods in this class as long as the general Processor contract for that method is obeyed.
| Modifier and Type | Field | Description |
|---|---|---|
protected ProcessingEnvironment |
processingEnv |
Processing environment providing by the tool framework. |
| Modifier | Constructor | Description |
|---|---|---|
protected |
Constructor for subclasses to call. |
| Modifier and Type | Method | Description |
|---|---|---|
Iterable |
getCompletions |
Returns an empty iterable of completions. |
Set |
getSupportedAnnotationTypes() |
Returns the names of the annotation interfaces supported by this processor. |
Set |
getSupportedOptions() |
Returns the options recognized by this processor. |
SourceVersion |
getSupportedSourceVersion() |
Returns the latest source version supported by this annotation processor. |
void |
init |
Initializes the processor with the processing environment. |
protected boolean |
isInitialized() |
|
abstract boolean |
process |
Processes a set of annotation interfaces on root elements originating from the prior round and returns whether or not these annotation interfaces are claimed by this processor. |
protected ProcessingEnvironment processingEnv
protected AbstractProcessor()
public Set<String> getSupportedOptions()
getSupportedOptions in interface Processor
SupportedOptions, return an unmodifiable set with the same set of strings as the annotation. If the class is not so annotated, an empty set is returned.public Set<String> getSupportedAnnotationTypes()
getSupportedAnnotationTypes in interface Processor
SupportedAnnotationTypes, return an unmodifiable set with the same set of strings as the annotation. If the class is not so annotated, an empty set is returned. If the source version does not support modules, in other words if it is less than or equal to RELEASE_8, then any leading module prefixes are stripped from the names.public SourceVersion getSupportedSourceVersion()
getSupportedSourceVersion in interface Processor
SupportedSourceVersion, return the source version in the annotation. If the class is not so annotated, SourceVersion.RELEASE_6 is returned.public void init(ProcessingEnvironment processingEnv)
init in interface Processor
processingEnv field to the value of the processingEnv argument. An
IllegalStateException will be thrown if this method is called more than once on the same object.processingEnv - environment to access facilities the tool framework provides to the processorIllegalStateException - if this method is called more than once.public abstract boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv)
true is returned, the annotation interfaces are claimed and subsequent processors will not be asked to process them; if false is returned, the annotation interfaces are unclaimed and subsequent processors may be asked to process them. A processor may always return the same boolean value or may vary the result based on its own chosen criteria. The input set will be empty if the processor supports
"*" and the root elements have no annotations. A
Processor must gracefully handle an empty set of annotations.
public Iterable<? extends Completion> getCompletions(Element element, AnnotationMirror annotation, ExecutableElement member, String userText)
getCompletions in interface Processor
element - the element being annotatedannotation - the (perhaps partial) annotation being applied to the elementmember - the annotation member to return possible completions foruserText - source code text to be completedprotected boolean isInitialized()
true if this object has been initialized, false otherwise
© 1993, 2025, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/25/docs/api/java.compiler/javax/annotation/processing/AbstractProcessor.html