Class SuppressWarningsCheck
- All Implemented Interfaces:
Configurable
,Contextualizable
@SuppressWarnings
is not allowed to suppress.
You can also specify a list of TokenTypes that
the configured warning(s) cannot be suppressed on.
Limitations: This check does not consider conditionals inside the @SuppressWarnings annotation.
For example:
@SuppressWarnings((false) ? (true) ? "unchecked" : "foo" : "unused")
.
According to the above example, the "unused" warning is being suppressed
not the "unchecked" or "foo" warnings. All of these warnings will be
considered and matched against regardless of what the conditional
evaluates to.
The check also does not support code like @SuppressWarnings("un" + "used")
,
@SuppressWarnings((String) "unused")
or
@SuppressWarnings({('u' + (char)'n') + (""+("used" + (String)"")),})
.
By default, any warning specified will be disallowed on all legal TokenTypes unless otherwise specified via the tokens property.
Also, by default warnings that are empty strings or all whitespace (regex: ^$|^\s+$) are flagged. By specifying, the format property these defaults no longer apply.
This check can be configured so that the "unchecked" and "unused" warnings cannot be suppressed on anything but variable and parameter declarations. See below of an example.
-
Property
format
- Specify the RegExp to match against warnings. Any warning being suppressed matching this pattern will be flagged. Type isjava.util.regex.Pattern
. Default value is"^\s*+$"
. -
Property
tokens
- tokens to check Type isjava.lang.String[]
. Validation type istokenSet
. Default value is: CLASS_DEF, INTERFACE_DEF, ENUM_DEF, ANNOTATION_DEF, ANNOTATION_FIELD_DEF, ENUM_CONSTANT_DEF, PARAMETER_DEF, VARIABLE_DEF, METHOD_DEF, CTOR_DEF, COMPACT_CTOR_DEF, RECORD_DEF, PATTERN_VARIABLE_DEF.
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation Message Keys:
-
suppressed.warning.not.allowed
- Since:
- 5.0
-
Nested Class Summary
Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
AbstractAutomaticBean.OutputStreamOptions
-
Field Summary
Modifier and TypeFieldDescriptionprivate Pattern
Specify the RegExp to match against warnings.private static final String
Fully-qualifiedSuppressWarnings
annotation name.static final String
A key is pointing to the warning message text in "messages.properties" file.private static final String
SuppressWarnings
annotation name. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprivate static DetailAST
findWarningsHolder
(DetailAST annotation) Find the parent (holder) of the of the warnings (Expr).final int[]
The configurable token set.private static DetailAST
getCondLeft
(DetailAST cond) Retrieves the left side of a conditional.private static DetailAST
getCondRight
(DetailAST cond) Retrieves the right side of a conditional.final int[]
Returns the default token a check is interested in.int[]
The tokens that this check must be registered for.private static DetailAST
Gets theSuppressWarnings
annotation that is annotating the AST.private void
This method looks for a warning that matches a configured expression.private static String
removeQuotes
(String warning) Strips a single double quote from the front and back of a string.final void
Setter to specify the RegExp to match against warnings.void
visitToken
(DetailAST ast) Called to process a token.private void
walkConditional
(DetailAST cond) Walks a conditional expression checking the left and right sides, checking for matches and logging violations.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, setTokens
Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
finishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverity
Methods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
configure, contextualize, getConfiguration, setupChild
-
Field Details
-
MSG_KEY_SUPPRESSED_WARNING_NOT_ALLOWED
A key is pointing to the warning message text in "messages.properties" file.- See Also:
-
SUPPRESS_WARNINGS
SuppressWarnings
annotation name.- See Also:
-
FQ_SUPPRESS_WARNINGS
Fully-qualifiedSuppressWarnings
annotation name.- See Also:
-
format
Specify the RegExp to match against warnings. Any warning being suppressed matching this pattern will be flagged.
-
-
Constructor Details
-
SuppressWarningsCheck
public SuppressWarningsCheck()
-
-
Method Details
-
setFormat
Setter to specify the RegExp to match against warnings. Any warning being suppressed matching this pattern will be flagged.- Parameters:
pattern
- the new pattern- Since:
- 5.0
-
getDefaultTokens
Description copied from class:AbstractCheck
Returns the default token a check is interested in. Only used if the configuration for a check does not define the tokens.- Specified by:
getDefaultTokens
in classAbstractCheck
- Returns:
- the default tokens
- See Also:
-
getAcceptableTokens
Description copied from class:AbstractCheck
The 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:
getAcceptableTokens
in classAbstractCheck
- Returns:
- the token set this check is designed for.
- See Also:
-
getRequiredTokens
Description copied from class:AbstractCheck
The tokens that this check must be registered for.- Specified by:
getRequiredTokens
in classAbstractCheck
- Returns:
- the token set this must be registered for.
- See Also:
-
visitToken
Description copied from class:AbstractCheck
Called to process a token.- Overrides:
visitToken
in classAbstractCheck
- Parameters:
ast
- the token to process
-
getSuppressWarnings
Gets theSuppressWarnings
annotation that is annotating the AST. If the annotation does not exist this method will returnnull
.- Parameters:
ast
- the AST- Returns:
- the
SuppressWarnings
annotation
-
logMatch
This method looks for a warning that matches a configured expression. If found it logs a violation at the given AST.- Parameters:
ast
- the location to place the violationwarningText
- the warning.
-
findWarningsHolder
Find the parent (holder) of the of the warnings (Expr).- Parameters:
annotation
- the annotation- Returns:
- a Token representing the expr.
-
removeQuotes
Strips a single double quote from the front and back of a string.For example:
Input String = "unchecked"
Output String = unchecked- Parameters:
warning
- the warning string- Returns:
- the string without two quotes
-
walkConditional
Walks a conditional expression checking the left and right sides, checking for matches and logging violations.- Parameters:
cond
- a Conditional typeQUESTION
-
getCondLeft
Retrieves the left side of a conditional.- Parameters:
cond
- cond a conditional typeQUESTION
- Returns:
- either the value or another conditional
-
getCondRight
Retrieves the right side of a conditional.- Parameters:
cond
- a conditional typeQUESTION
- Returns:
- either the value or another conditional
-