Class AnnotationStatistics
java.lang.Object
javax.annotation.processing.AbstractProcessor
org.checkerframework.javacutil.AbstractTypeProcessor
org.checkerframework.framework.source.SourceChecker
org.checkerframework.common.util.count.AnnotationStatistics
- All Implemented Interfaces:
- Processor,- OptionConfiguration
@SupportedOptions({"nolocations","annotations","annotationserror","annotationsummaryonly"})
@SupportedSourceVersion(RELEASE_8)
public class AnnotationStatistics
extends SourceChecker
An annotation processor for listing the potential locations of annotations. To invoke it, use
 
javac -proc:only -processor org.checkerframework.common.util.count.AnnotationStatistics MyFile.java ...
You probably want to pipe the output through another program:
- Total annotation count: ... | wc.
- Breakdown by location type: ... | sort | uniq -c
- Count for only certain location types: use grep
By default, this utility displays annotation locations only. The following two options may be used to adjust the output:
- -Aannotations: prints information about the annotations
- -Anolocations: suppresses location output; only makes sense in conjunction with- -Aannotations
- -Aannotationsummaryonly: with both of the obove, only outputs a summary
- -Aannotationserror: histogram is issued as a warning, not just printed
- See Also:
- 
Field SummaryFields inherited from class org.checkerframework.framework.source.SourceCheckercurrentRoot, DETAILS_SEPARATOR, elements, elementsWithSuppressedWarnings, errsOnLastExit, javacErrored, messager, messagesProperties, MSGS_FILE, OPTION_SEPARATOR, parentChecker, SUPPRESS_ALL_MESSAGE_KEY, SUPPRESS_ALL_PREFIX, trees, types, UNNEEDED_SUPPRESSION_KEY, upstreamCheckerNames, useAllcheckersPrefix, visitorFields inherited from class javax.annotation.processing.AbstractProcessorprocessingEnv
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprotected SourceVisitor<?,?> Provides theSourceVisitorthat the checker should use to scan input source trees.Returns the AnnotationProvider (the type factory) associated with this.protected voidincrementCount(Name annoName) Increment the number of times annotation with nameannoNamehas appeared.voidA method to be called once all the classes are processed.Methods inherited from class org.checkerframework.framework.source.SourceCheckeraddOptions, createSupportedLintOptions, expandCFOptions, fullMessageOf, getBooleanOption, getBooleanOption, getElementUtils, getLintOption, getLintOption, getMessagesProperties, getOption, getOption, getOptionConfiguration, getOptions, getParentChecker, getPathToCompilationUnit, getProcessingEnvironment, getProperties, getStandardSuppressWarningsPrefixes, getSupportedAnnotationTypes, getSupportedLintOptions, getSupportedOptions, getSupportedSourceVersion, getSuppressWarningsPrefixes, getTreeUtils, getTypeUtils, getUpstreamCheckerNames, getVisitor, hasOption, init, initChecker, message, message, printOrStoreMessage, printOrStoreMessage, printStats, processArg, report, reportError, reportJavacError, reportWarning, setLintOption, setParentChecker, setProcessingEnvironment, setRoot, setSupportedLintOptions, shouldAddShutdownHook, shouldSkipDefs, shouldSkipDefs, shouldSkipUses, shouldSkipUses, shouldSuppressWarnings, shouldSuppressWarnings, shouldSuppressWarnings, shutdownHook, typeProcess, typeProcessingStart, useConservativeDefault, warnUnneededSuppressions, warnUnneededSuppressionsMethods inherited from class org.checkerframework.javacutil.AbstractTypeProcessorgetCompilerLog, processMethods inherited from class javax.annotation.processing.AbstractProcessorgetCompletions, isInitialized
- 
Constructor Details- 
AnnotationStatisticspublic AnnotationStatistics()Creates an AnnotationStatistics.
 
- 
- 
Method Details- 
typeProcessingOverpublic void typeProcessingOver()Description copied from class:AbstractTypeProcessorA method to be called once all the classes are processed.Subclasses may override this method to do any aggregate analysis (e.g. generate report, persistence) or resource deallocation. Method AbstractTypeProcessor.getCompilerLog()can be used to access the number of compiler errors.- Overrides:
- typeProcessingOverin class- AbstractTypeProcessor
 
- 
incrementCountIncrement the number of times annotation with nameannoNamehas appeared.
- 
createSourceVisitorDescription copied from class:SourceCheckerProvides theSourceVisitorthat the checker should use to scan input source trees.- Specified by:
- createSourceVisitorin class- SourceChecker
- Returns:
- a SourceVisitorto use to scan source trees
 
- 
getAnnotationProviderDescription copied from class:SourceCheckerReturns the AnnotationProvider (the type factory) associated with this.- Overrides:
- getAnnotationProviderin class- SourceChecker
- Returns:
- the AnnotationProvider (the type factory) associated with this
 
 
-