Class WhenShouldBeUsedCheck
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.coding.WhenShouldBeUsedCheck
- All Implemented Interfaces:
Configurable,Contextualizable
Ensures that
when is used instead of a single if
statement inside a case block.
Rationale: Java 21 has introduced enhancements for switch statements and expressions
that allow the use of patterns in case labels. The when keyword is used to specify
condition for a case label, also called as guarded case labels. This syntax is more readable
and concise than the single if statement inside the pattern match block.
See the Java Language Specification for more information about guarded case labels.
See the Java Language Specification for more information about patterns.
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation Message Keys:
-
when.should.be.used
- Since:
- 10.18.0
-
Nested Class Summary
Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
AbstractAutomaticBean.OutputStreamOptions -
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionint[]The configurable token set.getBlockStatements(DetailAST statementList) Get all statements inside the case block.int[]Returns the default token a check is interested in.int[]The tokens that this check must be registered for.private static DetailASTgetStatementList(DetailAST caseAST) Get the statement list token of the case block.private static booleanhasPatternLabel(DetailAST caseAST) Check if the case block has a pattern variable definition or a record pattern definition.private static booleanCheck if the statement is an acceptable statement inside the case block.private static booleanisSingleIfWithNoElse(DetailAST statement) Check if the case block statement is a single if statement with no else branch.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheck
beginTree, 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.AbstractViolationReporter
finishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
configure, contextualize, getConfiguration, setupChild
-
Field Details
-
MSG_KEY
A key is pointing to the warning message text in "messages.properties" file.- See Also:
-
-
Constructor Details
-
WhenShouldBeUsedCheck
public WhenShouldBeUsedCheck()
-
-
Method Details
-
getDefaultTokens
Description 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 classAbstractCheck- Returns:
- the default tokens
- See Also:
-
getAcceptableTokens
Description 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 classAbstractCheck- Returns:
- the token set this check is designed for.
- See Also:
-
getRequiredTokens
Description copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
getRequiredTokensin classAbstractCheck- Returns:
- the token set this must be registered for.
- See Also:
-
visitToken
Description copied from class:AbstractCheckCalled to process a token.- Overrides:
visitTokenin classAbstractCheck- Parameters:
ast- the token to process
-
getStatementList
Get the statement list token of the case block.- Parameters:
caseAST- the AST node representingLITERAL_CASE- Returns:
- the AST node representing
SLISTof the current case
-
getBlockStatements
Get all statements inside the case block.- Parameters:
statementList- the AST node representingSLISTof the current case- Returns:
- statements inside the current case block
-
isAcceptableStatement
Check if the statement is an acceptable statement inside the case block. If these statements are the only ones in the case block, this case can be considered a violation. If at least one of the statements is not acceptable, this case can not be a violation.- Parameters:
ast- the AST node representing the statement- Returns:
- true if the statement is an acceptable statement, false otherwise
-
hasPatternLabel
Check if the case block has a pattern variable definition or a record pattern definition.- Parameters:
caseAST- the AST node representingLITERAL_CASE- Returns:
- true if the case block has a pattern label, false otherwise
-
isSingleIfWithNoElse
Check if the case block statement is a single if statement with no else branch.- Parameters:
statement- statement to check inside the current case block- Returns:
- true if the statement is a single if statement with no else branch, false otherwise
-