Class UnusedCatchParameterShouldBeUnnamedCheck
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.UnusedCatchParameterShouldBeUnnamedCheck
- All Implemented Interfaces:
Configurable,Contextualizable
Ensures that catch parameters that are not used are declared as an unnamed variable.
Rationale:
- Improves code readability by clearly indicating which parameters are unused.
-
Follows Java conventions for denoting unused parameters with an underscore (
_).
See the Java Language Specification for more information about unnamed variables.
Attention: This check should be activated only on source code that is compiled by jdk21 or higher; unnamed catch parameters came out as the first preview in Java 21.
- Since:
- 10.18.0
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate static final classMaintains information about the catch parameter.Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
AbstractAutomaticBean.OutputStreamOptions -
Field Summary
FieldsModifier and TypeFieldDescriptionKeeps track of the catch parameters in a block.private static final int[]Invalid parents of the catch parameter identifier.static final StringA key is pointing to the warning message text in "messages.properties" file. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidCalled before the starting to process a tree.int[]The configurable token set.int[]Returns the default token a check is interested in.int[]The tokens that this check must be registered for.private static booleanisCatchParameterIdentifierCandidate(DetailAST identifierAst) Visit ast of typeTokenTypes.IDENTand check if it is a candidate for a catch parameter identifier.private static booleanisLeftHandOfAssignment(DetailAST identAst) Check if the givenTokenTypes.IDENTis a left hand side value.private static booleanisMethodInvocation(DetailAST identAst) Check if the givenTokenTypes.IDENTis a child of a dot operator and is a candidate for catch parameter.voidleaveToken(DetailAST ast) Called after all the child nodes have been process.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheck
clearViolations, destroy, finishTree, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, 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_UNUSED_CATCH_PARAMETER
A key is pointing to the warning message text in "messages.properties" file.- See Also:
-
INVALID_CATCH_PARAM_IDENT_PARENTS
Invalid parents of the catch parameter identifier. -
catchParameters
Keeps track of the catch parameters in a block.
-
-
Constructor Details
-
UnusedCatchParameterShouldBeUnnamedCheck
-
-
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:
-
beginTree
Description copied from class:AbstractCheckCalled before the starting to process a tree. Ideal place to initialize information that is to be collected whilst processing a tree.- Overrides:
beginTreein classAbstractCheck- Parameters:
rootAST- the root of the tree
-
visitToken
Description copied from class:AbstractCheckCalled to process a token.- Overrides:
visitTokenin classAbstractCheck- Parameters:
ast- the token to process
-
leaveToken
Description copied from class:AbstractCheckCalled after all the child nodes have been process.- Overrides:
leaveTokenin classAbstractCheck- Parameters:
ast- the token leaving
-
isCatchParameterIdentifierCandidate
Visit ast of typeTokenTypes.IDENTand check if it is a candidate for a catch parameter identifier.- Parameters:
identifierAst- token representingTokenTypes.IDENT- Returns:
- true if the given
TokenTypes.IDENTcould be a catch parameter identifier
-
isMethodInvocation
Check if the givenTokenTypes.IDENTis a child of a dot operator and is a candidate for catch parameter.- Parameters:
identAst- token representingTokenTypes.IDENT- Returns:
- true if the given
TokenTypes.IDENTis a child of a dot operator and a candidate for catch parameter.
-
isLeftHandOfAssignment
Check if the givenTokenTypes.IDENTis a left hand side value.- Parameters:
identAst- token representingTokenTypes.IDENT- Returns:
- true if the given
TokenTypes.IDENTis a left hand side value.
-