Class AnnotationLocationCheck
java.lang.Object
com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
com.puppycrawl.tools.checkstyle.api.AbstractCheck
com.puppycrawl.tools.checkstyle.checks.annotation.AnnotationLocationCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Checks location of annotation on language elements.
 By default, Check enforce to locate annotations before target element,
 annotation should be located on separate line from target element.
 This check also verifies that the annotations are on the same indenting level
 as the annotated element if they are not on the same line.
 
 
 Attention: Elements that cannot have JavaDoc comments like local variables are not in the
 scope of this check even though a token type like VARIABLE_DEF would match them.
 
Attention: Annotations among modifiers are ignored (looks like false-negative) as there might be a problem with annotations for return types:
 public @Nullable Long getStartTimeOrNull() { ... }
 Such annotations are better to keep close to type. Due to limitations, Checkstyle can not examine the target of an annotation.
Example:
 @Override
 @Nullable
 public String getNameIfPresent() { ... }
 Notes: This check does not enforce annotations to be placed immediately after the documentation block. If that behavior is desired, consider also using InvalidJavadocPosition.
- Since:
- 6.0
- 
Nested Class SummaryNested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate booleanAllow annotation(s) to be located on the same line as target element.private booleanAllow one and only parameterized annotation to be located on the same line as target element.private booleanAllow single parameterless annotation to be located on the same line as target element.static final StringA key is pointing to the warning message text in "messages.properties" file.static final StringA key is pointing to the warning message text in "messages.properties" file.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprivate voidcheckAnnotations(DetailAST modifierNode, int correctIndentation) Checks annotations positions in code: 1) Checks whether the annotations locations are correct. 2) Checks whether the annotations have the valid indentation level.int[]The configurable token set.private static StringgetAnnotationName(DetailAST annotation) Returns the name of the given annotation.int[]Returns the default token a check is interested in.private static intReturns an expected annotation indentation.int[]The tokens that this check must be registered for.private static booleanhasNodeAfter(DetailAST annotation) Checks whether an annotation node has any node after on the same line.private static booleanhasNodeBefore(DetailAST annotation) Checks whether an annotation node has any node before on the same line.private static booleanhasNodeBeside(DetailAST annotation) Checks whether an annotation node has any node before or after on the same line.private booleanisCorrectLocation(DetailAST annotation, boolean hasParams) Checks whether an annotation has a correct location.private static booleanisParameterized(DetailAST annotation) Checks whether an annotation has parameters.final voidsetAllowSamelineMultipleAnnotations(boolean allow) Setter to allow annotation(s) to be located on the same line as target element.final voidsetAllowSamelineParameterizedAnnotation(boolean allow) Setter to allow one and only parameterized annotation to be located on the same line as target element.final voidsetAllowSamelineSingleParameterlessAnnotation(boolean allow) Setter to allow single parameterless annotation to be located on the same line as target element.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckbeginTree, clearViolations, destroy, finishTree, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, leaveToken, log, log, log, setFileContents, setTabWidth, setTokensMethods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractViolationReporterfinishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanconfigure, contextualize, getConfiguration, setupChild
- 
Field Details- 
MSG_KEY_ANNOTATION_LOCATION_ALONEA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_KEY_ANNOTATION_LOCATIONA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
allowSamelineSingleParameterlessAnnotationAllow single parameterless annotation to be located on the same line as target element.
- 
allowSamelineParameterizedAnnotationAllow one and only parameterized annotation to be located on the same line as target element.
- 
allowSamelineMultipleAnnotationsAllow annotation(s) to be located on the same line as target element.
 
- 
- 
Constructor Details- 
AnnotationLocationCheckpublic AnnotationLocationCheck()
 
- 
- 
Method Details- 
setAllowSamelineSingleParameterlessAnnotationSetter to allow single parameterless annotation to be located on the same line as target element.- Parameters:
- allow- User's value of allowSamelineSingleParameterlessAnnotation.
- Since:
- 6.1
 
- 
setAllowSamelineParameterizedAnnotationSetter to allow one and only parameterized annotation to be located on the same line as target element.- Parameters:
- allow- User's value of allowSamelineParameterizedAnnotation.
- Since:
- 6.4
 
- 
setAllowSamelineMultipleAnnotationsSetter to allow annotation(s) to be located on the same line as target element.- Parameters:
- allow- User's value of allowSamelineMultipleAnnotations.
- Since:
- 6.0
 
- 
getDefaultTokensDescription copied from class:AbstractCheckReturns the default token a check is interested in. Only used if the configuration for a check does not define the tokens.- Specified by:
- getDefaultTokensin class- AbstractCheck
- Returns:
- the default tokens
- See Also:
 
- 
getAcceptableTokensDescription copied from class:AbstractCheckThe configurable token set. Used to protect Checks against malicious users who specify an unacceptable token set in the configuration file. The default implementation returns the check's default tokens.- Specified by:
- getAcceptableTokensin class- AbstractCheck
- Returns:
- the token set this check is designed for.
- See Also:
 
- 
getRequiredTokensDescription copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
- getRequiredTokensin class- AbstractCheck
- Returns:
- the token set this must be registered for.
- See Also:
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
getExpectedAnnotationIndentationReturns an expected annotation indentation. The expected indentation should be the same as the indentation of the target node.- Parameters:
- node- modifiers or annotations node.
- Returns:
- the annotation indentation.
 
- 
checkAnnotationsChecks annotations positions in code: 1) Checks whether the annotations locations are correct. 2) Checks whether the annotations have the valid indentation level.- Parameters:
- modifierNode- modifiers node.
- correctIndentation- correct indentation of the annotation.
 
- 
isParameterizedChecks whether an annotation has parameters.- Parameters:
- annotation- annotation node.
- Returns:
- true if the annotation has parameters.
 
- 
getAnnotationNameReturns the name of the given annotation.- Parameters:
- annotation- annotation node.
- Returns:
- annotation name.
 
- 
isCorrectLocationChecks whether an annotation has a correct location. Annotation location is considered correct ifallowSamelineMultipleAnnotationsis set to true. The method also: 1) checks parameterized annotation location considering the value ofallowSamelineParameterizedAnnotation; 2) checks parameterless annotation location considering the value ofallowSamelineSingleParameterlessAnnotation; 3) checks annotation location;- Parameters:
- annotation- annotation node.
- hasParams- whether an annotation has parameters.
- Returns:
- true if the annotation has a correct location.
 
- 
hasNodeBeforeChecks whether an annotation node has any node before on the same line.- Parameters:
- annotation- annotation node.
- Returns:
- true if an annotation node has any node before on the same line.
 
- 
hasNodeBesideChecks whether an annotation node has any node before or after on the same line.- Parameters:
- annotation- annotation node.
- Returns:
- true if an annotation node has any node before or after on the same line.
 
- 
hasNodeAfterChecks whether an annotation node has any node after on the same line.- Parameters:
- annotation- annotation node.
- Returns:
- true if an annotation node has any node after on the same line.
 
 
-