AbstractProcessor (Java Platform SE 6) (original) (raw)
javax.annotation.processing
Class AbstractProcessor
java.lang.Object
javax.annotation.processing.AbstractProcessor
All Implemented Interfaces:
public abstract class AbstractProcessor
extends Object
implements Processor
An abstract annotation processor designed to be a convenient superclass for most concrete annotation processors. This class examines annotation values to compute the options, annotations, and source version supported by its subtypes.
The getter methods may [issue warnings](../../../javax/annotation/processing/Messager.html#printMessage%28javax.tools.Diagnostic.Kind, java.lang.CharSequence%29) 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.
Since:
1.6
Field Summary | |
---|---|
protected ProcessingEnvironment | processingEnv Processing environment providing by the tool framework. |
Constructor Summary | |
---|---|
protected | AbstractProcessor() Constructor for subclasses to call. |
Method Summary | |
---|---|
Iterable<? extends Completion> | [getCompletions](../../../javax/annotation/processing/AbstractProcessor.html#getCompletions%28javax.lang.model.element.Element, javax.lang.model.element.AnnotationMirror, javax.lang.model.element.ExecutableElement, java.lang.String%29)(Element element,AnnotationMirror annotation,ExecutableElement member,String userText) Returns an empty iterable of completions. |
Set<String> | getSupportedAnnotationTypes() If the processor class is annotated with SupportedAnnotationTypes, return an unmodifiable set with the same set of strings as the annotation. |
Set<String> | getSupportedOptions() If the processor class is annotated with SupportedOptions, return an unmodifiable set with the same set of strings as the annotation. |
SourceVersion | getSupportedSourceVersion() If the processor class is annotated with SupportedSourceVersion, return the source version in the annotation. |
void | init(ProcessingEnvironment processingEnv) Initializes the processor with the processing environment by setting the processingEnv field to the value of theprocessingEnv argument. |
protected boolean | isInitialized() Returns true if this object has been initialized, false otherwise. |
abstract boolean | [process](../../../javax/annotation/processing/AbstractProcessor.html#process%28java.util.Set, javax.annotation.processing.RoundEnvironment%29)(Set<? extends TypeElement> annotations,RoundEnvironment roundEnv) Processes a set of annotation types on type elements originating from the prior round and returns whether or not these annotations are claimed by this processor. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, [wait](../../../java/lang/Object.html#wait%28long, int%29) |
Field Detail |
---|
processingEnv
protected ProcessingEnvironment processingEnv
Processing environment providing by the tool framework.
Constructor Detail |
---|
AbstractProcessor
protected AbstractProcessor()
Constructor for subclasses to call.
Method Detail |
---|
getSupportedOptions
public Set<String> getSupportedOptions()
If the processor class is annotated with 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.
Specified by:
[getSupportedOptions](../../../javax/annotation/processing/Processor.html#getSupportedOptions%28%29)
in interface [Processor](../../../javax/annotation/processing/Processor.html "interface in javax.annotation.processing")
Returns:
the options recognized by this processor, or an empty set if none
See Also:
getSupportedAnnotationTypes
public Set<String> getSupportedAnnotationTypes()
If the processor class is annotated with 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.
Specified by:
[getSupportedAnnotationTypes](../../../javax/annotation/processing/Processor.html#getSupportedAnnotationTypes%28%29)
in interface [Processor](../../../javax/annotation/processing/Processor.html "interface in javax.annotation.processing")
Returns:
the names of the annotation types supported by this processor, or an empty set if none
See Also:
getSupportedSourceVersion
public SourceVersion getSupportedSourceVersion()
If the processor class is annotated with SupportedSourceVersion, return the source version in the annotation. If the class is not so annotated, SourceVersion.RELEASE_6 is returned.
Specified by:
[getSupportedSourceVersion](../../../javax/annotation/processing/Processor.html#getSupportedSourceVersion%28%29)
in interface [Processor](../../../javax/annotation/processing/Processor.html "interface in javax.annotation.processing")
Returns:
the latest source version supported by this processor
See Also:
SupportedSourceVersion, ProcessingEnvironment.getSourceVersion()
init
public void init(ProcessingEnvironment processingEnv)
Initializes the processor with the processing environment by setting the processingEnv
field to the value of theprocessingEnv
argument. An IllegalStateException
will be thrown if this method is called more than once on the same object.
Specified by:
[init](../../../javax/annotation/processing/Processor.html#init%28javax.annotation.processing.ProcessingEnvironment%29)
in interface [Processor](../../../javax/annotation/processing/Processor.html "interface in javax.annotation.processing")
Parameters:
processingEnv
- environment to access facilities the tool framework provides to the processor
Throws:
[IllegalStateException](../../../java/lang/IllegalStateException.html "class in java.lang")
- if this method is called more than once.
process
public abstract boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv)
Processes a set of annotation types on type elements originating from the prior round and returns whether or not these annotations are claimed by this processor. If true
is returned, the annotations are claimed and subsequent processors will not be asked to process them; if false
is returned, the annotations 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 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.
Specified by:
[process](../../../javax/annotation/processing/Processor.html#process%28java.util.Set, javax.annotation.processing.RoundEnvironment%29)
in interface [Processor](../../../javax/annotation/processing/Processor.html "interface in javax.annotation.processing")
Parameters:
annotations
- the annotation types requested to be processed
roundEnv
- environment for information about the current and prior round
Returns:
whether or not the set of annotations are claimed by this processor
getCompletions
public Iterable<? extends Completion> getCompletions(Element element, AnnotationMirror annotation, ExecutableElement member, String userText)
Returns an empty iterable of completions.
Specified by:
[getCompletions](../../../javax/annotation/processing/Processor.html#getCompletions%28javax.lang.model.element.Element, javax.lang.model.element.AnnotationMirror, javax.lang.model.element.ExecutableElement, java.lang.String%29)
in interface [Processor](../../../javax/annotation/processing/Processor.html "interface in javax.annotation.processing")
Parameters:
element
- the element being annotated
annotation
- the (perhaps partial) annotation being applied to the element
member
- the annotation member to return possible completions for
userText
- source code text to be completed
Returns:
suggested completions to the annotation
isInitialized
protected boolean isInitialized()
Returns true
if this object has been initialized, false
otherwise.
Returns:
true
if this object has been initialized,false
otherwise.
Submit a bug or feature
For further API reference and developer documentation, see Java SE Developer Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 1993, 2015, Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.
Scripting on this page tracks web page traffic, but does not change the content in any way.