Class AbstractProcessor
java.lang.Object
javax.annotation.processing.AbstractProcessor
- All Implemented Interfaces:
- 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, annotation interfaces, and
 source version supported by
 its subtypes.
 
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.
- Since:
- 1.6
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected ProcessingEnvironmentProcessing environment providing by the tool framework.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionIterable<? extends Completion> getCompletions(Element element, AnnotationMirror annotation, ExecutableElement member, String userText) Returns an empty iterable of completions.Returns the names of the annotation interfaces supported by this processor.Returns the options recognized by this processor.Returns the latest source version supported by this annotation processor.voidinit(ProcessingEnvironment processingEnv) Initializes the processor with the processing environment.protected booleanabstract booleanprocess(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) 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.
- 
Field Details- 
processingEnvProcessing environment providing by the tool framework.
 
- 
- 
Constructor Details- 
AbstractProcessorprotected AbstractProcessor()Constructor for subclasses to call.
 
- 
- 
Method Details- 
getSupportedOptionsReturns the options recognized by this processor.- Specified by:
- getSupportedOptionsin interface- Processor
- Implementation Requirements:
- 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.
- Returns:
- the options recognized by this processor, or an empty set if none
- See Also:
 
- 
getSupportedAnnotationTypesReturns the names of the annotation interfaces supported by this processor.- Specified by:
- getSupportedAnnotationTypesin interface- Processor
- Implementation Requirements:
- 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. If the source version does not support modules, in other words if it is less than or equal toRELEASE_8, then any leading module prefixes are stripped from the names.
- Returns:
- the names of the annotation interfaces supported by this processor or an empty set if none
- See Also:
 
- 
getSupportedSourceVersionReturns the latest source version supported by this annotation processor.- Specified by:
- getSupportedSourceVersionin interface- Processor
- Implementation Requirements:
- If the processor class is annotated with SupportedSourceVersion, return the source version in the annotation. If the class is not so annotated,SourceVersion.RELEASE_6is returned.
- Returns:
- the latest source version supported by this annotation processor
- See Also:
 
- 
initInitializes the processor with the processing environment.- Specified by:
- initin interface- Processor
- Implementation Requirements:
- Initializes the processor with the processing environment by
 setting the processingEnvfield to the value of theprocessingEnvargument. AnIllegalStateExceptionwill be thrown if this method is called more than once on the same object.
- Parameters:
- processingEnv- environment to access facilities the tool framework provides to the processor
- Throws:
- IllegalStateException- if this method is called more than once.
 
- 
processProcesses 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. Iftrueis returned, the annotation interfaces are claimed and subsequent processors will not be asked to process them; iffalseis 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. AProcessormust gracefully handle an empty set of annotations.
- 
getCompletionspublic Iterable<? extends Completion> getCompletions(Element element, AnnotationMirror annotation, ExecutableElement member, String userText) Returns an empty iterable of completions.- Specified by:
- getCompletionsin interface- Processor
- 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:
- an empty iterable of completions
 
- 
isInitializedprotected boolean isInitialized()- Returns:
- trueif this object has been initialized,- falseotherwise
 
 
-