Class VariableDeclarationUsageDistanceCheck
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.VariableDeclarationUsageDistanceCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Checks the distance between declaration of variable and its first usage.
 Note: Any additional variables declared or initialized between the declaration and
  the first usage of the said variable are not counted when calculating the distance.
 
- Since:
- 5.8
- 
Nested Class SummaryNested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate intSpecify the maximum distance between a variable's declaration and its first usage.private static final intDefault value of distance between declaration of variable and its first usage.private booleanAllow to ignore variables with a 'final' modifier.private PatternDefine RegExp to ignore distance calculation for variables listed in this pattern.static final StringWarning message key.static final StringWarning message key.private booleanAllow to calculate the distance between a variable's declaration and its first usage across different scopes.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptioncalculateDistanceBetweenScopes(DetailAST ast, DetailAST variable) Calculates distance between declaration of variable and its first usage in multiple scopes.calculateDistanceInSingleScope(DetailAST semicolonAst, DetailAST variableIdentAst) Calculates distance between declaration of variable and its first usage in single scope.int[]The configurable token set.int[]Returns the default token a check is interested in.private static intgetDistToVariableUsageInChildNode(DetailAST childNode, int currentDistToVarUsage) Returns the distance to variable usage for in the child node.private static DetailASTgetFirstNodeInsideForWhileDoWhileBlocks(DetailAST block, DetailAST variable) Gets first Ast node inside FOR, WHILE or DO-WHILE blocks if variable usage is met only inside the block (not in its declaration!).private static DetailASTgetFirstNodeInsideIfBlock(DetailAST block, DetailAST variable) Gets first Ast node inside IF block if variable usage is met only inside the block (not in its declaration!).private static DetailASTgetFirstNodeInsideSwitchBlock(DetailAST block, DetailAST variable) Gets first Ast node inside SWITCH block if variable usage is met only inside the block (not in its declaration!).private static DetailASTgetFirstNodeInsideTryCatchFinallyBlocks(DetailAST block, DetailAST variable) Gets first Ast node inside TRY-CATCH-FINALLY blocks if variable usage is met only inside the block (not in its declaration!).private static StringgetInstanceName(DetailAST methodCallAst) Get name of instance whose method is called.int[]The tokens that this check must be registered for.getVariableUsageExpressionsInsideSwitchBlock(DetailAST block, DetailAST variable) Helper method for getFirstNodeInsideSwitchBlock to return all variable usage expressions inside a given switch block.private static booleanChecks if Ast node contains given element.private static booleanisInitializationSequence(DetailAST variableUsageAst, String variableName) Processes statements until usage of variable to detect sequence of initialization methods.private static booleanisVariableInOperatorExpr(DetailAST operator, DetailAST variable) Checks if variable is in operator declaration.private booleanisVariableMatchesIgnorePattern(String variable) Checks if entrance variable is contained in ignored pattern.private static booleanisZeroDistanceToken(int type) Check if the token should be ignored for distance counting.searchVariableUsageExpressions(DetailAST variableAst, DetailAST statementAst) Searches variable usages starting from specified statement.voidsetAllowedDistance(int allowedDistance) Setter to specify the maximum distance between a variable's declaration and its first usage.voidsetIgnoreFinal(boolean ignoreFinal) Setter to allow to ignore variables with a 'final' modifier.voidsetIgnoreVariablePattern(Pattern pattern) Setter to define RegExp to ignore distance calculation for variables listed in this pattern.voidsetValidateBetweenScopes(boolean validateBetweenScopes) Setter to allow to calculate the distance between a variable's declaration and its first usage across different scopes.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckbeginTree, 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.AbstractViolationReporterfinishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanconfigure, contextualize, getConfiguration, setupChild
- 
Field Details- 
MSG_KEYWarning message key.- See Also:
 
- 
MSG_KEY_EXTWarning message key.- See Also:
 
- 
DEFAULT_DISTANCEDefault value of distance between declaration of variable and its first usage.- See Also:
 
- 
allowedDistanceSpecify the maximum distance between a variable's declaration and its first usage. Value should be greater than 0.
- 
ignoreVariablePatternDefine RegExp to ignore distance calculation for variables listed in this pattern.
- 
validateBetweenScopesAllow to calculate the distance between a variable's declaration and its first usage across different scopes.
- 
ignoreFinalAllow to ignore variables with a 'final' modifier.
 
- 
- 
Constructor Details- 
VariableDeclarationUsageDistanceCheck
 
- 
- 
Method Details- 
setAllowedDistanceSetter to specify the maximum distance between a variable's declaration and its first usage. Value should be greater than 0.- Parameters:
- allowedDistance- Allowed distance between declaration of variable and its first usage.
- Since:
- 5.8
 
- 
setIgnoreVariablePatternSetter to define RegExp to ignore distance calculation for variables listed in this pattern.- Parameters:
- pattern- a pattern.
- Since:
- 5.8
 
- 
setValidateBetweenScopesSetter to allow to calculate the distance between a variable's declaration and its first usage across different scopes.- Parameters:
- validateBetweenScopes- Defines if allow to calculate distance between declaration of variable and its first usage in different scopes or not.
- Since:
- 5.8
 
- 
setIgnoreFinalSetter to allow to ignore variables with a 'final' modifier.- Parameters:
- ignoreFinal- Defines if ignore variables with 'final' modifier or not.
- Since:
- 5.8
 
- 
getDefaultTokensDescription 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 class- AbstractCheck
- Returns:
- the default tokens
- See Also:
 
- 
getAcceptableTokensDescription 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 class- AbstractCheck
- Returns:
- the token set this check is designed for.
- See Also:
 
- 
getRequiredTokensDescription copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
- getRequiredTokensin class- AbstractCheck
- Returns:
- the token set this must be registered for.
- See Also:
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
getInstanceNameGet name of instance whose method is called.- Parameters:
- methodCallAst- DetailAST of METHOD_CALL.
- Returns:
- name of instance.
 
- 
isInitializationSequenceProcesses statements until usage of variable to detect sequence of initialization methods.- Parameters:
- variableUsageAst- DetailAST of expression that uses variable named variableName.
- variableName- name of considered variable.
- Returns:
- true if statements between declaration and usage of variable are initialization methods.
 
- 
calculateDistanceInSingleScopeprivate static Map.Entry<DetailAST,Integer> calculateDistanceInSingleScope(DetailAST semicolonAst, DetailAST variableIdentAst) Calculates distance between declaration of variable and its first usage in single scope.- Parameters:
- semicolonAst- Regular node of Ast which is checked for content of checking variable.
- variableIdentAst- Variable which distance is calculated for.
- Returns:
- entry which contains expression with variable usage and distance. If variable usage is not found, then the expression node is null, although the distance can be greater than zero.
 
- 
getDistToVariableUsageInChildNodeprivate static int getDistToVariableUsageInChildNode(DetailAST childNode, int currentDistToVarUsage) Returns the distance to variable usage for in the child node.- Parameters:
- childNode- child node.
- currentDistToVarUsage- current distance to the variable usage.
- Returns:
- the distance to variable usage for in the child node.
 
- 
calculateDistanceBetweenScopesprivate static Map.Entry<DetailAST,Integer> calculateDistanceBetweenScopes(DetailAST ast, DetailAST variable) Calculates distance between declaration of variable and its first usage in multiple scopes.- Parameters:
- ast- Regular node of Ast which is checked for content of checking variable.
- variable- Variable which distance is calculated for.
- Returns:
- entry which contains expression with variable usage and distance.
 
- 
searchVariableUsageExpressionsprivate static Map.Entry<List<DetailAST>,Integer> searchVariableUsageExpressions(DetailAST variableAst, DetailAST statementAst) Searches variable usages starting from specified statement.- Parameters:
- variableAst- Variable that is used.
- statementAst- DetailAST to start searching from.
- Returns:
- entry which contains list with found expressions that use the variable and distance from specified statement to first found expression.
 
- 
getFirstNodeInsideForWhileDoWhileBlocksprivate static DetailAST getFirstNodeInsideForWhileDoWhileBlocks(DetailAST block, DetailAST variable) Gets first Ast node inside FOR, WHILE or DO-WHILE blocks if variable usage is met only inside the block (not in its declaration!).- Parameters:
- block- Ast node represents FOR, WHILE or DO-WHILE block.
- variable- Variable which is checked for content in block.
- Returns:
- If variable usage is met only inside the block (not in its declaration!) then return the first Ast node of this block, otherwise - null.
 
- 
getFirstNodeInsideIfBlockGets first Ast node inside IF block if variable usage is met only inside the block (not in its declaration!).- Parameters:
- block- Ast node represents IF block.
- variable- Variable which is checked for content in block.
- Returns:
- If variable usage is met only inside the block (not in its declaration!) then return the first Ast node of this block, otherwise - null.
 
- 
getFirstNodeInsideSwitchBlockGets first Ast node inside SWITCH block if variable usage is met only inside the block (not in its declaration!).- Parameters:
- block- Ast node represents SWITCH block.
- variable- Variable which is checked for content in block.
- Returns:
- If variable usage is met only inside the block (not in its declaration!) then return the first Ast node of this block, otherwise - null.
 
- 
getVariableUsageExpressionsInsideSwitchBlockprivate static List<DetailAST> getVariableUsageExpressionsInsideSwitchBlock(DetailAST block, DetailAST variable) Helper method for getFirstNodeInsideSwitchBlock to return all variable usage expressions inside a given switch block.- Parameters:
- block- the switch block to check.
- variable- variable which is checked for in switch block.
- Returns:
- List of usages or empty list if none are found.
 
- 
getFirstNodeInsideTryCatchFinallyBlocksprivate static DetailAST getFirstNodeInsideTryCatchFinallyBlocks(DetailAST block, DetailAST variable) Gets first Ast node inside TRY-CATCH-FINALLY blocks if variable usage is met only inside the block (not in its declaration!).- Parameters:
- block- Ast node represents TRY-CATCH-FINALLY block.
- variable- Variable which is checked for content in block.
- Returns:
- If variable usage is met only inside the block (not in its declaration!) then return the first Ast node of this block, otherwise - null.
 
- 
isVariableInOperatorExprChecks if variable is in operator declaration. For instance:boolean b = true; if (b) {...}Variable 'b' is in declaration of operator IF.- Parameters:
- operator- Ast node which represents operator.
- variable- Variable which is checked for content in operator.
- Returns:
- true if operator contains variable in its declaration, otherwise - false.
 
- 
isChildChecks if Ast node contains given element.- Parameters:
- parent- Node of AST.
- ast- Ast element which is checked for content in Ast node.
- Returns:
- true if Ast element was found in Ast node, otherwise - false.
 
- 
isVariableMatchesIgnorePatternChecks if entrance variable is contained in ignored pattern.- Parameters:
- variable- Variable which is checked for content in ignored pattern.
- Returns:
- true if variable was found, otherwise - false.
 
- 
isZeroDistanceTokenCheck if the token should be ignored for distance counting. For example,try (final AutoCloseable t = new java.io.StringReader(a);) { }final is a zero-distance token and should be ignored for distance counting.class Table implements Comparator<Integer>{ }An inner class may be defined. Both tokens implements and extends are zero-distance tokens.public int method(Object b){ }public is a modifier and zero-distance token. int is a type and zero-distance token.- Parameters:
- type- Token type of the ast node.
- Returns:
- true if it should be ignored for distance counting, otherwise false.
 
 
-