Class EqualsAvoidNullCheck
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.EqualsAvoidNullCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Checks that any combination of String literals
 is on the left side of an 
 equals() comparison.
 Also checks for String literals assigned to some field
 (such as someString.equals(anotherString = "text")).
 Rationale: Calling the equals() method on String literals
 will avoid a potential NullPointerException. Also, it is
 pretty common to see null checks right before equals comparisons
 but following this rule such checks are not required.
 
- Since:
- 5.0
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprivate static final classHolds the names of fields of a type.Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate EqualsAvoidNullCheck.FieldFrameStack of sets of field names, one for each class of a set of nested classes.private static final StringMethod name for comparison.private booleanControl whether to ignoreString.equalsIgnoreCase(String)invocations.private static final StringCurly for comparison.static final StringA key is pointing to the warning message text in "messages.properties" file.static final StringA key is pointing to the warning message text in "messages.properties" file.private static final StringType name for comparison.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprivate static booleanastTypeIsClassOrEnumOrRecordDef(int tokenType) Verify that a token is either CLASS_DEF, RECORD_DEF, or ENUM_DEF.voidCalled before the starting to process a tree.private voidcheckMethodCall(DetailAST methodCall) Check whether the method call should be violated.private static booleanLooks for all "safe" Token combinations in the argument expression branch.private static booleancontainsOneArgument(DetailAST methodCall) Verify that method call has one argument.voidfinishTree(DetailAST ast) Called after finished processing a tree.int[]The configurable token set.int[]Returns the default token a check is interested in.private static StringgetFieldType(DetailAST field) Get field type.private static EqualsAvoidNullCheck.FieldFrameGet the nearest parent frame which is CLASS_DEF, ENUM_DEF or ENUM_CONST_DEF.int[]The tokens that this check must be registered for.private booleanisCalledOnStringFieldOrVariable(DetailAST objCalledOn) Determine, whether equals method is called on a field of String type.private booleanisStringFieldOrVariable(DetailAST objCalledOn) Whether the field or the variable is of String type.private booleanisStringFieldOrVariableFromClass(DetailAST objCalledOn, String className) Whether the field or the variable from the specified class is of String type.private booleanisStringFieldOrVariableFromThisInstance(DetailAST objCalledOn) Whether the field or the variable from THIS instance is of String type.private voidleaveLiteralNew(DetailAST ast) Determine whether LITERAL_NEW is an anonymous class definition and leave the frame it is in.private voidleaveSlist(DetailAST ast) Determine whether SLIST begins a block, determined by braces.voidleaveToken(DetailAST ast) Called after all the child nodes have been process.private voidprocessFrame(DetailAST ast) Process CLASS_DEF, METHOD_DEF, LITERAL_IF, LITERAL_FOR, LITERAL_WHILE, LITERAL_DO, LITERAL_CATCH, LITERAL_TRY, CTOR_DEF, ENUM_DEF, ENUM_CONSTANT_DEF.private voidDetermine whether LITERAL_NEW is an anonymous class definition and add it as a frame in this case.private voidprocessMethodCall(DetailAST methodCall) Add the method call to the current frame if it should be processed.private voidprocessSlist(DetailAST ast) Determine whether SLIST begins a block, determined by braces, and add it as a frame in this case.voidsetIgnoreEqualsIgnoreCase(boolean newValue) Setter to control whether to ignoreString.equalsIgnoreCase(String)invocations.private static DetailASTskipVariableAssign(DetailAST currentAST) Skips over an inner assign portion of an argument expression.private voidTraverse the tree of the field frames to check all equals method calls.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckclearViolations, destroy, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, 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_EQUALS_AVOID_NULLA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_EQUALS_IGNORE_CASE_AVOID_NULLA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
EQUALSMethod name for comparison.- See Also:
 
- 
STRINGType name for comparison.- See Also:
 
- 
LEFT_CURLYCurly for comparison.- See Also:
 
- 
ignoreEqualsIgnoreCaseControl whether to ignoreString.equalsIgnoreCase(String)invocations.
- 
currentFrameStack of sets of field names, one for each class of a set of nested classes.
 
- 
- 
Constructor Details- 
EqualsAvoidNullCheckpublic EqualsAvoidNullCheck()
 
- 
- 
Method Details- 
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:
 
- 
setIgnoreEqualsIgnoreCaseSetter to control whether to ignoreString.equalsIgnoreCase(String)invocations.- Parameters:
- newValue- whether to ignore checking- String.equalsIgnoreCase(String).
- Since:
- 5.4
 
- 
beginTreeDescription 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 class- AbstractCheck
- Parameters:
- rootAST- the root of the tree
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
leaveTokenDescription copied from class:AbstractCheckCalled after all the child nodes have been process.- Overrides:
- leaveTokenin class- AbstractCheck
- Parameters:
- ast- the token leaving
 
- 
finishTreeDescription copied from class:AbstractCheckCalled after finished processing a tree. Ideal place to report on information collected whilst processing a tree.- Overrides:
- finishTreein class- AbstractCheck
- Parameters:
- ast- the root of the tree
 
- 
processSlistDetermine whether SLIST begins a block, determined by braces, and add it as a frame in this case.- Parameters:
- ast- SLIST ast.
 
- 
leaveSlistDetermine whether SLIST begins a block, determined by braces.- Parameters:
- ast- SLIST ast.
 
- 
processFrameProcess CLASS_DEF, METHOD_DEF, LITERAL_IF, LITERAL_FOR, LITERAL_WHILE, LITERAL_DO, LITERAL_CATCH, LITERAL_TRY, CTOR_DEF, ENUM_DEF, ENUM_CONSTANT_DEF.- Parameters:
- ast- processed ast.
 
- 
processMethodCallAdd the method call to the current frame if it should be processed.- Parameters:
- methodCall- METHOD_CALL ast.
 
- 
processLiteralNewDetermine whether LITERAL_NEW is an anonymous class definition and add it as a frame in this case.- Parameters:
- ast- LITERAL_NEW ast.
 
- 
leaveLiteralNewDetermine whether LITERAL_NEW is an anonymous class definition and leave the frame it is in.- Parameters:
- ast- LITERAL_NEW ast.
 
- 
traverseFieldFrameTreeTraverse the tree of the field frames to check all equals method calls.- Parameters:
- frame- to check method calls in.
 
- 
checkMethodCallCheck whether the method call should be violated.- Parameters:
- methodCall- method call to check.
 
- 
containsOneArgumentVerify that method call has one argument.- Parameters:
- methodCall- METHOD_CALL DetailAST
- Returns:
- true if method call has one argument.
 
- 
containsAllSafeTokensLooks for all "safe" Token combinations in the argument expression branch.- Parameters:
- expr- the argument expression
- Returns:
- - true if any child matches the set of tokens, false if not
 
- 
skipVariableAssignSkips over an inner assign portion of an argument expression.- Parameters:
- currentAST- current token in the argument expression
- Returns:
- the next relevant token
 
- 
isCalledOnStringFieldOrVariableDetermine, whether equals method is called on a field of String type.- Parameters:
- objCalledOn- object ast.
- Returns:
- true if the object is of String type.
 
- 
isStringFieldOrVariableWhether the field or the variable is of String type.- Parameters:
- objCalledOn- the field or the variable to check.
- Returns:
- true if the field or the variable is of String type.
 
- 
isStringFieldOrVariableFromThisInstanceWhether the field or the variable from THIS instance is of String type.- Parameters:
- objCalledOn- the field or the variable from THIS instance to check.
- Returns:
- true if the field or the variable from THIS instance is of String type.
 
- 
isStringFieldOrVariableFromClassWhether the field or the variable from the specified class is of String type.- Parameters:
- objCalledOn- the field or the variable from the specified class to check.
- className- the name of the class to check in.
- Returns:
- true if the field or the variable from the specified class is of String type.
 
- 
getObjectFrameprivate static EqualsAvoidNullCheck.FieldFrame getObjectFrame(EqualsAvoidNullCheck.FieldFrame frame) Get the nearest parent frame which is CLASS_DEF, ENUM_DEF or ENUM_CONST_DEF.- Parameters:
- frame- to start the search from.
- Returns:
- the nearest parent frame which is CLASS_DEF, ENUM_DEF or ENUM_CONST_DEF.
 
- 
getFieldTypeGet field type.- Parameters:
- field- to get the type from.
- Returns:
- type of the field.
 
- 
astTypeIsClassOrEnumOrRecordDefVerify that a token is either CLASS_DEF, RECORD_DEF, or ENUM_DEF.- Parameters:
- tokenType- the type of token
- Returns:
- true if token is of specified type.
 
 
-