Class SummaryJavadocCheck
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.javadoc.AbstractJavadocCheck
com.puppycrawl.tools.checkstyle.checks.javadoc.SummaryJavadocCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Checks that
 
 Javadoc summary sentence does not contain phrases that are not recommended to use.
 Summaries that contain only the 
 {@inheritDoc} tag are skipped.
 Summaries that contain a non-empty {@return} are allowed.
 Check also violate Javadoc that does not contain first sentence, though with {@return} a
 period is not required as the Javadoc tool adds it.
 Note: For defining a summary, both the first sentence and the @summary tag approaches are supported.
- Since:
- 6.0
- 
Nested Class SummaryNested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate static final StringDefault period literal.private PatternSpecify the regexp for forbidden summary fragments.private static final PatternThis regexp is used to remove html tags, whitespace, and asterisks from a string.private static final PatternThis regexp is used to convert multiline javadoc to single-line without stars.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 StringSpecify the period symbol.private booleanWhether to validate untagged summary text in Javadoc.Fields inherited from class com.puppycrawl.tools.checkstyle.checks.javadoc.AbstractJavadocCheckMSG_JAVADOC_PARSE_RULE_ERROR, MSG_KEY_UNCLOSED_HTML_TAG
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprivate booleancontainsForbiddenFragment(String firstSentence) Tests if first sentence contains forbidden summary fragment.findSentenceEnding(String text, String period) Finds the end of a sentence.static StringgetContentOfInlineCustomTag(DetailNode descriptionNode) Gets the content of inline custom tag.int[]Returns the default javadoc token types a check is interested in.getFirstSentence(DetailNode ast, String period) Finds the first sentence.int[]The javadoc tokens that this check must be registered for.private static StringgetStringInsideHtmlTag(String result, DetailNode detailNode) Get concatenated string within text of html tags.private static StringFinds and returns summary sentence.private static StringgetVisibleContent(String summary) Gets the string that is visible to user in javadoc.private static booleanisDefinedFirst(DetailNode inlineTagNode) Whether the{@summary}tag is defined first in the javadoc.static booleanWhether some text is present inside the HTML element or tag.private static booleanisInlineReturnTag(DetailNode javadocInlineTag) Checks if the given node is an inline return node.private static booleanisSummaryTag(DetailNode javadocInlineTag) Checks if the given node is an inline summary tag.voidCalled after all the child nodes have been process.voidsetForbiddenSummaryFragments(Pattern pattern) Setter to specify the regexp for forbidden summary fragments.voidSetter to specify the period symbol.private static booleanChecks if the node starts with an {@inheritDoc}.streamTextParts(DetailNode node) Streams through all the text under the given node.private static StringtrimExcessWhitespaces(String text) Trims the giventextof duplicate whitespaces.private voidvalidateInlineReturnTag(DetailNode inlineReturnTag) Checks the inline return for forbidden fragments.private voidvalidateSummaryTag(DetailNode inlineSummaryTag) Checks the inline summary (if present) forperiodat end and forbidden fragments.private voidChecks the javadoc text forperiodat end and forbidden fragments.voidCalled to process a Javadoc token.Methods inherited from class com.puppycrawl.tools.checkstyle.checks.javadoc.AbstractJavadocCheckacceptJavadocWithNonTightHtml, beginJavadocTree, beginTree, destroy, finishJavadocTree, finishTree, getAcceptableJavadocTokens, getAcceptableTokens, getBlockCommentAst, getDefaultTokens, getRequiredTokens, init, isCommentNodesRequired, setJavadocTokens, setViolateExecutionOnNonTightHtml, visitTokenMethods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckclearViolations, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, 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_SUMMARY_FIRST_SENTENCEA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_SUMMARY_JAVADOCA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_SUMMARY_JAVADOC_MISSINGA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_SUMMARY_MISSING_PERIODA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
JAVADOC_MULTILINE_TO_SINGLELINE_PATTERNThis regexp is used to convert multiline javadoc to single-line without stars.
- 
HTML_ELEMENTSThis regexp is used to remove html tags, whitespace, and asterisks from a string.
- 
DEFAULT_PERIODDefault period literal.- See Also:
 
- 
forbiddenSummaryFragmentsSpecify the regexp for forbidden summary fragments.
- 
periodSpecify the period symbol. Used to check the first sentence ends with a period. Periods that are not followed by a whitespace character are ignored (eg. the period in v1.0). Because some periods include whitespace built into the character, if this is set to a non-default value any period will end the sentence, whether it is followed by whitespace or not.
- 
shouldValidateUntaggedSummaryWhether to validate untagged summary text in Javadoc.
 
- 
- 
Constructor Details- 
SummaryJavadocCheckpublic SummaryJavadocCheck()
 
- 
- 
Method Details- 
setForbiddenSummaryFragmentsSetter to specify the regexp for forbidden summary fragments.- Parameters:
- pattern- a pattern.
- Since:
- 6.0
 
- 
setPeriodSetter to specify the period symbol. Used to check the first sentence ends with a period. Periods that are not followed by a whitespace character are ignored (eg. the period in v1.0). Because some periods include whitespace built into the character, if this is set to a non-default value any period will end the sentence, whether it is followed by whitespace or not.- Parameters:
- period- period's value.
- Since:
- 6.2
 
- 
getDefaultJavadocTokensDescription copied from class:AbstractJavadocCheckReturns the default javadoc token types a check is interested in.- Specified by:
- getDefaultJavadocTokensin class- AbstractJavadocCheck
- Returns:
- the default javadoc token types
- See Also:
 
- 
getRequiredJavadocTokensDescription copied from class:AbstractJavadocCheckThe javadoc tokens that this check must be registered for.- Overrides:
- getRequiredJavadocTokensin class- AbstractJavadocCheck
- Returns:
- the javadoc token set this must be registered for.
- See Also:
 
- 
visitJavadocTokenDescription copied from class:AbstractJavadocCheckCalled to process a Javadoc token.- Specified by:
- visitJavadocTokenin class- AbstractJavadocCheck
- Parameters:
- ast- the token to process
 
- 
leaveJavadocTokenDescription copied from class:AbstractJavadocCheckCalled after all the child nodes have been process.- Overrides:
- leaveJavadocTokenin class- AbstractJavadocCheck
- Parameters:
- ast- the token leaving
 
- 
validateUntaggedSummaryChecks the javadoc text forperiodat end and forbidden fragments.- Parameters:
- ast- the javadoc text node
 
- 
isDefinedFirstWhether the{@summary}tag is defined first in the javadoc.- Parameters:
- inlineTagNode- node of type- JavadocCommentsTokenTypes.JAVADOC_INLINE_TAG
- Returns:
- trueif the- {@summary}tag is defined first in the javadoc
 
- 
isHtmlTagWithoutTextWhether some text is present inside the HTML element or tag.- Parameters:
- node- DetailNode of type- JavadocCommentsTokenTypes.HTML_ELEMENT
- Returns:
- trueif some text is present inside the HTML element
 
- 
isSummaryTagChecks if the given node is an inline summary tag.- Parameters:
- javadocInlineTag- node
- Returns:
- trueif inline tag is of type- JavadocCommentsTokenTypes.SUMMARY_INLINE_TAG
 
- 
isInlineReturnTagChecks if the given node is an inline return node.- Parameters:
- javadocInlineTag- node
- Returns:
- trueif inline tag is of type- JavadocCommentsTokenTypes.RETURN_INLINE_TAG
 
- 
validateSummaryTagChecks the inline summary (if present) forperiodat end and forbidden fragments.- Parameters:
- inlineSummaryTag- node of type- JavadocCommentsTokenTypes.SUMMARY_INLINE_TAG
 
- 
validateInlineReturnTagChecks the inline return for forbidden fragments.- Parameters:
- inlineReturnTag- node of type- JavadocCommentsTokenTypes.RETURN_INLINE_TAG
 
- 
getContentOfInlineCustomTagGets the content of inline custom tag.- Parameters:
- descriptionNode- node of type- JavadocCommentsTokenTypes.DESCRIPTION
- Returns:
- String consisting of the content of inline custom tag.
 
- 
getVisibleContentGets the string that is visible to user in javadoc.- Parameters:
- summary- entire content of summary javadoc.
- Returns:
- string that is visible to user in javadoc.
 
- 
containsForbiddenFragmentTests if first sentence contains forbidden summary fragment.- Parameters:
- firstSentence- string with first sentence.
- Returns:
- trueif first sentence contains forbidden summary fragment.
 
- 
trimExcessWhitespacesTrims the giventextof duplicate whitespaces.- Parameters:
- text- the text to transform.
- Returns:
- the finalized form of the text.
 
- 
startsWithInheritDocChecks if the node starts with an {@inheritDoc}.- Parameters:
- root- the root node to examine.
- Returns:
- trueif the javadoc starts with an {@inheritDoc}.
 
- 
getSummarySentenceFinds and returns summary sentence.- Parameters:
- ast- javadoc root node.
- Returns:
- violation string.
 
- 
getStringInsideHtmlTagGet concatenated string within text of html tags.- Parameters:
- result- javadoc string
- detailNode- htmlContent node
- Returns:
- java doc tag content appended in result
 
- 
getFirstSentenceFinds the first sentence.- Parameters:
- ast- The Javadoc root node.
- period- The configured period symbol.
- Returns:
- An Optional containing the first sentence up to and excluding the period, or an empty Optional if no ending was found.
 
- 
streamTextPartsStreams through all the text under the given node.- Parameters:
- node- The Javadoc node to examine.
- Returns:
- All the text in all nodes that have no child nodes.
 
- 
findSentenceEndingFinds the end of a sentence. The end of sentence detection here could be replaced in the future by Java's built-in BreakIterator class.- Parameters:
- text- The string to search.
- period- The period character to find.
- Returns:
- An Optional containing the string up to and excluding the period, or empty Optional if no ending was found.
 
 
-