Class JavadocMethodCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Violates parameters and type parameters for which no param tags are present can
 be suppressed by defining property allowMissingParamTags.
 
 Violates methods which return non-void but for which no return tag is present can
 be suppressed by defining property allowMissingReturnTag.
 
 Violates exceptions which are declared to be thrown (by throws in the method
 signature or by throw new in the method body), but for which no throws tag is
 present by activation of property validateThrows.
 Note that throw new is not checked in the following places:
 
- Inside a try block (with catch). It is not possible to determine if the thrown exception can be caught by the catch block as there is no knowledge of the inheritance hierarchy, so the try block is ignored entirely. However, catch and finally blocks, as well as try blocks without catch, are still checked.
- Local classes, anonymous classes and lambda expressions. It is not known when the throw statements inside such classes are going to be evaluated, so they are ignored.
ATTENTION: Checkstyle does not have information about hierarchy of exception types so usage of base class is considered as separate exception type. As workaround, you need to specify both types in javadoc (parent and exact type).
 Javadoc is not required on a method that is tagged with the @Override
 annotation. However, under Java 5 it is not possible to mark a method required
 for an interface (this was corrected under Java 6). Hence, Checkstyle
 supports using the convention of using a single {@inheritDoc} tag
 instead of all the other tags.
 
 Note that only inheritable items will allow the {@inheritDoc}
 tag to be used in place of comments. Static methods at all visibilities,
 private non-static methods and constructors are not inheritable.
 
For example, if the following method is implementing a method required by an interface, then the Javadoc could be done as:
 /** {@inheritDoc} */
 public int checkReturnTag(final int aTagIndex,
                           JavadocTag[] aTags,
                           int aLineNo)
 - Since:
- 3.0
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprivate static classContains class'sToken.private static final classStores useful information about declared exception.private static final classRepresents text element with location in the text.Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate AccessModifierOption[]Specify the access modifiers where Javadoc comments are checked.Specify annotations that allow missed documentation.private booleanControl whether to allow inline return tags.private booleanControl whether to ignore violations when a method has parameters but does not have matchingparamtags in the javadoc.private booleanControl whether to ignore violations when a method returns non-void type and does not have areturntag in the javadoc.private static final StringHtml element end symbol.private static final StringHtml element start symbol.private static final StringMultiline finished at end of comment.private static final PatternCompiled regexp to match Javadoc tags that take an argument.private static final PatternCompiled regexp to match Javadoc tags with argument but with missing description.private static final PatternCompiled regexp to look for a continuation of the comment.private static final PatternCompiled regexp to match Javadoc tags with no argument.private static final PatternCompiled regexp to match Javadoc tags with no argument and {}.private static final PatternCompiled regexp to match Javadoc tags with no argument allowing inline return tag.private static final PatternCompiled regexp to match first part of multilineJavadoc tags.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.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.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.static final StringA key is pointing to the warning message text in "messages.properties" file.private static final StringMultiline finished at next Javadoc.private booleanControl whether to validatethrowstags.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprivate static intcalculateTagColumn(MatchResult javadocTagMatchResult, int lineNumber, int startColumnNumber) Calculates column number using Javadoc tag matcher.private voidcheckComment(DetailAST ast, TextBlock comment) Checks the Javadoc for a method.private voidcheckParamTags(List<JavadocTag> tags, DetailAST parent, boolean reportExpectedTags) Checks a set of tags for matching parameters.private voidcheckRecordParamTags(List<JavadocTag> tags, DetailAST compactDef, boolean reportExpectedTags) Checks if all record components in a compact constructor have corresponding@paramtags.private voidcheckReturnTag(List<JavadocTag> tags, int lineNo, boolean reportExpectedTags) Checks for only one return tag.private voidcheckThrowsTags(List<JavadocTag> tags, List<JavadocMethodCheck.ExceptionInfo> throwsList, boolean reportExpectedTags) Checks a set of tags for matching throws.private static List<JavadocMethodCheck.ExceptionInfo>combineExceptionInfo(Collection<JavadocMethodCheck.ExceptionInfo> first, Iterable<JavadocMethodCheck.ExceptionInfo> second) Combine ExceptionInfo collections together by matching names.findTokensInAstByType(DetailAST root, int astType) Finds node of specified type among root children, siblings, siblings children on any deep level.int[]The configurable token set.int[]Returns the default token a check is interested in.private static JavadocMethodCheck.ExceptionInfoGet ExceptionInfo instance.private static DetailASTGet node where class name of exception starts.private List<JavadocTag>getMethodTags(TextBlock comment) Returns the tags in a javadoc comment.private static List<JavadocTag>getMultilineNoArgTags(Matcher noargMultilineStart, String[] lines, int lineIndex, int tagLine) Gets multiline Javadoc tags with no arguments.getParameters(DetailAST ast) Computes the parameter nodes for a method.getRecordComponents(DetailAST recordDef) Retrieves the list of record components from a given record definition.private static DetailASTgetRecordDef(DetailAST ast) Finds the nearest ancestor record definition node for the given AST node.final int[]The tokens that this check must be registered for.private static List<JavadocMethodCheck.ExceptionInfo>getThrowed(DetailAST methodAst) Get ExceptionInfo for all exceptions that throws in method code by 'throw new'.private static List<JavadocMethodCheck.ExceptionInfo>Computes the exception nodes for a method.private booleanhasShortCircuitTag(DetailAST ast, List<JavadocTag> tags) Validates whether the Javadoc has a short circuit tag.private static booleanisClassNamesSame(String class1, String class2) Check that class names are same by short name of class.private static booleanCheck that ExceptionInfo objects are same by name.private static booleanisInIgnoreBlock(DetailAST methodBodyAst, DetailAST throwAst) Checks if a 'throw' usage is contained within a block that should be ignored.private voidprocessAST(DetailAST ast) Called to process an AST when visiting it.private static voidprocessThrows(Iterable<JavadocMethodCheck.ExceptionInfo> throwsIterable, String documentedClassName) Verifies that documented exception is in throws.private static booleanremoveMatchingParam(Iterable<DetailAST> params, String paramName) Remove parameter from params collection by name.private static booleansearchMatchingTypeParameter(Iterable<DetailAST> typeParams, String requiredTypeName) Returns true if required type found in type parameters.voidsetAccessModifiers(AccessModifierOption... accessModifiers) Setter to specify the access modifiers where Javadoc comments are checked.voidsetAllowedAnnotations(String... userAnnotations) Setter to specify annotations that allow missed documentation.voidsetAllowInlineReturn(boolean value) Setter to control whether to allow inline return tags.voidsetAllowMissingParamTags(boolean flag) Setter to control whether to ignore violations when a method has parameters but does not have matchingparamtags in the javadoc.voidsetAllowMissingReturnTag(boolean flag) Setter to control whether to ignore violations when a method returns non-void type and does not have areturntag in the javadoc.voidsetValidateThrows(boolean value) Setter to control whether to validatethrowstags.private booleanshouldCheck(DetailAST ast) Whether we should check this node.final 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_CLASS_INFOA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_UNUSED_TAG_GENERALA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_INVALID_INHERIT_DOCA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_UNUSED_TAGA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_EXPECTED_TAGA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_RETURN_EXPECTEDA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_DUPLICATE_TAGA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
ELEMENT_STARTHtml element start symbol.- See Also:
 
- 
ELEMENT_ENDHtml element end symbol.- See Also:
 
- 
MATCH_JAVADOC_ARGCompiled regexp to match Javadoc tags that take an argument.
- 
MATCH_JAVADOC_ARG_MISSING_DESCRIPTIONCompiled regexp to match Javadoc tags with argument but with missing description.
- 
MATCH_JAVADOC_MULTILINE_CONTCompiled regexp to look for a continuation of the comment.
- 
END_JAVADOCMultiline finished at end of comment.- See Also:
 
- 
NEXT_TAGMultiline finished at next Javadoc.- See Also:
 
- 
MATCH_JAVADOC_NOARGCompiled regexp to match Javadoc tags with no argument.
- 
MATCH_JAVADOC_NOARG_INLINE_RETURNCompiled regexp to match Javadoc tags with no argument allowing inline return tag.
- 
MATCH_JAVADOC_NOARG_MULTILINE_STARTCompiled regexp to match first part of multilineJavadoc tags.
- 
MATCH_JAVADOC_NOARG_CURLYCompiled regexp to match Javadoc tags with no argument and {}.
- 
allowInlineReturnControl whether to allow inline return tags.
- 
accessModifiersSpecify the access modifiers where Javadoc comments are checked.
- 
validateThrowsControl whether to validatethrowstags.
- 
allowMissingParamTagsControl whether to ignore violations when a method has parameters but does not have matchingparamtags in the javadoc.
- 
allowMissingReturnTagControl whether to ignore violations when a method returns non-void type and does not have areturntag in the javadoc.
- 
allowedAnnotationsSpecify annotations that allow missed documentation.
 
- 
- 
Constructor Details- 
JavadocMethodCheckpublic JavadocMethodCheck()
 
- 
- 
Method Details- 
setAllowInlineReturnSetter to control whether to allow inline return tags.- Parameters:
- value- a- booleanvalue
- Since:
- 10.23.0
 
- 
setValidateThrowsSetter to control whether to validatethrowstags.- Parameters:
- value- user's value.
- Since:
- 6.0
 
- 
setAllowedAnnotationsSetter to specify annotations that allow missed documentation.- Parameters:
- userAnnotations- user's value.
- Since:
- 6.0
 
- 
setAccessModifiersSetter to specify the access modifiers where Javadoc comments are checked.- Parameters:
- accessModifiers- access modifiers.
- Since:
- 8.42
 
- 
setAllowMissingParamTagsSetter to control whether to ignore violations when a method has parameters but does not have matchingparamtags in the javadoc.- Parameters:
- flag- a- Booleanvalue
- Since:
- 3.1
 
- 
setAllowMissingReturnTagSetter to control whether to ignore violations when a method returns non-void type and does not have areturntag in the javadoc.- Parameters:
- flag- a- Booleanvalue
- Since:
- 3.1
 
- 
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:
 
- 
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:
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
processASTCalled to process an AST when visiting it.- Parameters:
- ast- the AST to process. Guaranteed to not be PACKAGE_DEF or IMPORT tokens.
 
- 
shouldCheckWhether we should check this node.- Parameters:
- ast- a given node.
- Returns:
- whether we should check a given node.
 
- 
checkCommentChecks the Javadoc for a method.- Parameters:
- ast- the token for the method
- comment- the Javadoc comment
 
- 
getRecordComponentsRetrieves the list of record components from a given record definition.- Parameters:
- recordDef- the AST node representing the record definition
- Returns:
- a list of AST nodes representing the record components
 
- 
getRecordDefFinds the nearest ancestor record definition node for the given AST node.- Parameters:
- ast- the AST node to start searching from
- Returns:
- the nearest RECORD_DEFAST node, ornullif not found
 
- 
hasShortCircuitTagValidates whether the Javadoc has a short circuit tag. Currently, this is the inheritTag. Any violations are logged.- Parameters:
- ast- the construct being checked
- tags- the list of Javadoc tags associated with the construct
- Returns:
- true if the construct has a short circuit tag.
 
- 
getMethodTagsReturns the tags in a javadoc comment. Only finds throws, exception, param, return and see tags.- Parameters:
- comment- the Javadoc comment
- Returns:
- the tags found
 
- 
calculateTagColumnprivate static int calculateTagColumn(MatchResult javadocTagMatchResult, int lineNumber, int startColumnNumber) Calculates column number using Javadoc tag matcher.- Parameters:
- javadocTagMatchResult- found javadoc tag match result
- lineNumber- line number of Javadoc tag in comment
- startColumnNumber- column number of Javadoc comment beginning
- Returns:
- column number
 
- 
getMultilineNoArgTagsprivate static List<JavadocTag> getMultilineNoArgTags(Matcher noargMultilineStart, String[] lines, int lineIndex, int tagLine) Gets multiline Javadoc tags with no arguments.- Parameters:
- noargMultilineStart- javadoc tag Matcher
- lines- comment text lines
- lineIndex- line number that contains the javadoc tag
- tagLine- javadoc tag line number in file
- Returns:
- javadoc tags with no arguments
 
- 
getParametersComputes the parameter nodes for a method.- Parameters:
- ast- the method node.
- Returns:
- the list of parameter nodes for ast.
 
- 
getThrowsComputes the exception nodes for a method.- Parameters:
- ast- the method node.
- Returns:
- the list of exception nodes for ast.
 
- 
getThrowedGet ExceptionInfo for all exceptions that throws in method code by 'throw new'.- Parameters:
- methodAst- method DetailAST object where to find exceptions
- Returns:
- list of ExceptionInfo
 
- 
getExceptionInfoGet ExceptionInfo instance.- Parameters:
- ast- DetailAST object where to find exceptions node;
- Returns:
- ExceptionInfo
 
- 
getFirstClassNameNodeGet node where class name of exception starts.- Parameters:
- ast- DetailAST object where to find exceptions node;
- Returns:
- exception node where class name starts
 
- 
isInIgnoreBlockChecks if a 'throw' usage is contained within a block that should be ignored. Such blocks consist of try (with catch) blocks, local classes, anonymous classes, and lambda expressions. Note that a try block without catch is not considered.- Parameters:
- methodBodyAst- DetailAST node representing the method body
- throwAst- DetailAST node representing the 'throw' literal
- Returns:
- true if throwAst is inside a block that should be ignored
 
- 
combineExceptionInfoprivate static List<JavadocMethodCheck.ExceptionInfo> combineExceptionInfo(Collection<JavadocMethodCheck.ExceptionInfo> first, Iterable<JavadocMethodCheck.ExceptionInfo> second) Combine ExceptionInfo collections together by matching names.- Parameters:
- first- the first collection of ExceptionInfo
- second- the second collection of ExceptionInfo
- Returns:
- combined list of ExceptionInfo
 
- 
findTokensInAstByTypeFinds node of specified type among root children, siblings, siblings children on any deep level.
- 
checkRecordParamTagsprivate void checkRecordParamTags(List<JavadocTag> tags, DetailAST compactDef, boolean reportExpectedTags) Checks if all record components in a compact constructor have corresponding@paramtags. Reports missing or extra@paramtags in the Javadoc.- Parameters:
- tags- the list of Javadoc tags
- compactDef- the compact constructor AST node
- reportExpectedTags- whether to report missing- @paramtags
 
- 
checkParamTagsChecks a set of tags for matching parameters.- Parameters:
- tags- the tags to check
- parent- the node which takes the parameters
- reportExpectedTags- whether we should report if do not find expected tag
 
- 
searchMatchingTypeParameterprivate static boolean searchMatchingTypeParameter(Iterable<DetailAST> typeParams, String requiredTypeName) Returns true if required type found in type parameters.- Parameters:
- typeParams- collection of type parameters
- requiredTypeName- name of required type
- Returns:
- true if required type found in type parameters.
 
- 
removeMatchingParamRemove parameter from params collection by name.- Parameters:
- params- collection of DetailAST parameters
- paramName- name of parameter
- Returns:
- true if parameter found and removed
 
- 
checkReturnTagChecks for only one return tag. All return tags will be removed from the supplied list.- Parameters:
- tags- the tags to check
- lineNo- the line number of the expected tag
- reportExpectedTags- whether we should report if do not find expected tag
 
- 
checkThrowsTagsprivate void checkThrowsTags(List<JavadocTag> tags, List<JavadocMethodCheck.ExceptionInfo> throwsList, boolean reportExpectedTags) Checks a set of tags for matching throws.- Parameters:
- tags- the tags to check
- throwsList- the throws to check
- reportExpectedTags- whether we should report if do not find expected tag
 
- 
processThrowsprivate static void processThrows(Iterable<JavadocMethodCheck.ExceptionInfo> throwsIterable, String documentedClassName) Verifies that documented exception is in throws.- Parameters:
- throwsIterable- collection of throws
- documentedClassName- documented exception class name
 
- 
isExceptionInfoSameprivate static boolean isExceptionInfoSame(JavadocMethodCheck.ExceptionInfo info1, JavadocMethodCheck.ExceptionInfo info2) Check that ExceptionInfo objects are same by name.- Parameters:
- info1- ExceptionInfo object
- info2- ExceptionInfo object
- Returns:
- true is ExceptionInfo object have the same name
 
- 
isClassNamesSameCheck that class names are same by short name of class. If some class name is fully qualified it is cut to short name.- Parameters:
- class1- class name
- class2- class name
- Returns:
- true is ExceptionInfo object have the same name
 
 
-