public class ParameterNumberCheck extends AbstractCheck
Checks the number of parameters of a method or constructor.
max - Specify the maximum number of parameters allowed.
Type is int.
Default value is 7.
ignoreOverriddenMethods - Ignore number of parameters for
methods with @Override annotation.
Type is boolean.
Default value is false.
tokens - tokens to check
Type is java.lang.String[].
Validation type is tokenSet.
Default value is:
METHOD_DEF,
CTOR_DEF.
To configure the check:
<module name="ParameterNumber"/>
To configure the check to allow 10 parameters for a method:
<module name="ParameterNumber"> <property name="max" value="10"/> <property name="tokens" value="METHOD_DEF"/> </module>
To configure the check to ignore number of parameters for methods with
@Override or @java.lang.Override annotation.
Rationale: developer may need to override method with many parameters from 3-rd party library. In this case developer has no control over number of parameters.
<module name="ParameterNumber"> <property name="ignoreOverriddenMethods" value="true"/> </module>
Java code example:
@Override
public void needsLotsOfParameters(int a,
int b, int c, int d, int e, int f, int g, int h) {
...
}
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation Message Keys:
maxParam
AutomaticBean.OutputStreamOptions| Modifier and Type | Field and Description |
|---|---|
private static java.lang.String |
CANONICAL_OVERRIDE
Canonical
Override annotation name. |
private static int |
DEFAULT_MAX_PARAMETERS
Default maximum number of allowed parameters.
|
private boolean |
ignoreOverriddenMethods
Ignore number of parameters for methods with
@Override annotation. |
private int |
max
Specify the maximum number of parameters allowed.
|
static java.lang.String |
MSG_KEY
A key is pointing to the warning message text in "messages.properties"
file.
|
private static java.lang.String |
OVERRIDE
Override annotation name. |
| Constructor and Description |
|---|
ParameterNumberCheck() |
| Modifier and Type | Method and Description |
|---|---|
int[] |
getAcceptableTokens()
The configurable token set.
|
int[] |
getDefaultTokens()
Returns the default token a check is interested in.
|
int[] |
getRequiredTokens()
The tokens that this check must be registered for.
|
void |
setIgnoreOverriddenMethods(boolean ignoreOverriddenMethods)
Setter to ignore number of parameters for methods with
@Override annotation. |
void |
setMax(int max)
Setter to specify the maximum number of parameters allowed.
|
private boolean |
shouldIgnoreNumberOfParameters(DetailAST ast)
Determine whether to ignore number of parameters for the method.
|
void |
visitToken(DetailAST ast)
Called to process a token.
|
beginTree, clearViolations, destroy, finishTree, getFileContents, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, leaveToken, log, log, log, setFileContents, setTabWidth, setTokensfinishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityconfigure, contextualize, getConfiguration, setupChildpublic static final java.lang.String MSG_KEY
private static final java.lang.String OVERRIDE
Override annotation name.private static final java.lang.String CANONICAL_OVERRIDE
Override annotation name.private static final int DEFAULT_MAX_PARAMETERS
private int max
private boolean ignoreOverriddenMethods
@Override annotation.public ParameterNumberCheck()
public void setMax(int max)
max - the max allowed parameterspublic void setIgnoreOverriddenMethods(boolean ignoreOverriddenMethods)
@Override annotation.ignoreOverriddenMethods - set ignore overridden methodspublic int[] getDefaultTokens()
AbstractCheckgetDefaultTokens in class AbstractCheckTokenTypespublic int[] getAcceptableTokens()
AbstractCheckgetAcceptableTokens in class AbstractCheckTokenTypespublic int[] getRequiredTokens()
AbstractCheckgetRequiredTokens in class AbstractCheckTokenTypespublic void visitToken(DetailAST ast)
AbstractCheckvisitToken in class AbstractCheckast - the token to processprivate boolean shouldIgnoreNumberOfParameters(DetailAST ast)
ast - the token to processCopyright © 2001-2022. All Rights Reserved.