Class UseEnhancedSwitchCheck
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.UseEnhancedSwitchCheck
- All Implemented Interfaces:
Configurable,Contextualizable
Ensures that the enhanced switch (using
-> for case labels) is used
instead of the traditional switch (using : for case labels) where possible.
Rationale: Java 14 has introduced enhancements for switch statements and expressions
that disallow fall-through behavior. The enhanced switch syntax using ->
for case labels typically leads to more concise and readable code, reducing the likelihood
of errors associated with fall-through cases.
See the
Java Language Specification for more information about -> case labels, also known as
"switch rules".
- Since:
- 13.3.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 TypeMethodDescriptionprivate static booleanallCaseGroupsTerminate(List<DetailAST> caseGroups) Check if all case groups terminate (i.e. do not fall through), except the last one which terminates regardless of its content.int[]The configurable token set.getCaseGroups(DetailAST switchAst) Get all case groups from the switch.int[]Returns the default token a check is interested in.int[]The tokens that this check must be registered for.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
-
UseEnhancedSwitchCheck
public UseEnhancedSwitchCheck()
-
-
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
-
allCaseGroupsTerminate
Check if all case groups terminate (i.e. do not fall through), except the last one which terminates regardless of its content.- Parameters:
caseGroups- the list of case groups to check- Returns:
trueif all case groups terminate,falseotherwise
-
getCaseGroups
Get all case groups from the switch.- Parameters:
switchAst- the AST node representing aLITERAL_SWITCH- Returns:
- all
CASE_GROUPnodes within the switch
-