public class AvoidStaticImportCheck extends AbstractCheck
Checks that there are no static import statements.
Rationale: Importing static members can lead to naming conflicts between class' members. It may lead to poor code readability since it may no longer be clear what class a member resides in (without looking at the import statement).
If you exclude a starred import on a class this automatically excludes each member individually.
For example: Excluding java.lang.Math.*. will allow the import
of each static member in the Math class individually like
java.lang.Math.PI, java.lang.Math.cos, ....
excludes - Control whether to allow for certain classes via
a star notation to be excluded such as java.lang.Math.* or specific
static members to be excluded like java.lang.System.out for a variable
or java.lang.Math.random for a method. See notes section for details.
Type is java.lang.String[].
Default value is "".
To configure the check:
<module name="AvoidStaticImport"/>
Example:
import static java.lang.Math.pow; // violation import static java.lang.System.*; // violation import java.io.File; // OK import java.util.*; // OK
To configure the check so that the java.lang.System.out member and all
members from java.lang.Math are allowed:
<module name="AvoidStaticImport"> <property name="excludes" value="java.lang.System.out,java.lang.Math.*"/> </module>
Example:
import static java.lang.Math.*; // OK import static java.lang.System.out; // OK import static java.lang.Integer.parseInt; // violation import java.io.*; // OK import java.util.*; // OK
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation Message Keys:
import.avoidStatic
AutomaticBean.OutputStreamOptions| Modifier and Type | Field and Description |
|---|---|
private java.lang.String[] |
excludes
Control whether to allow for certain classes via a star notation to be
excluded such as
java.lang.Math.* or specific static members
to be excluded like java.lang.System.out for a variable or
java.lang.Math.random for a method. |
static java.lang.String |
MSG_KEY
A key is pointing to the warning message text in "messages.properties"
file.
|
| Constructor and Description |
|---|
AvoidStaticImportCheck() |
| 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.
|
private boolean |
isExempt(java.lang.String classOrStaticMember)
Checks if a class or static member is exempt from known excludes.
|
private static boolean |
isStarImportOfPackage(java.lang.String classOrStaticMember,
java.lang.String exclude)
Returns true if classOrStaticMember is a starred name of package,
not just member name.
|
void |
setExcludes(java.lang.String... excludes)
Setter to control whether to allow for certain classes via a star notation
to be excluded such as
java.lang.Math.* or specific static members
to be excluded like java.lang.System.out for a variable or
java.lang.Math.random for a 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 java.lang.String[] excludes
java.lang.Math.* or specific static members
to be excluded like java.lang.System.out for a variable or
java.lang.Math.random for a method. See notes section for details.public AvoidStaticImportCheck()
public int[] getDefaultTokens()
AbstractCheckgetDefaultTokens in class AbstractCheckTokenTypespublic int[] getAcceptableTokens()
AbstractCheckgetAcceptableTokens in class AbstractCheckTokenTypespublic int[] getRequiredTokens()
AbstractCheckgetRequiredTokens in class AbstractCheckTokenTypespublic void setExcludes(java.lang.String... excludes)
java.lang.Math.* or specific static members
to be excluded like java.lang.System.out for a variable or
java.lang.Math.random for a method. See notes section for details.excludes - a list of fully-qualified class names/specific
static members where static imports are okpublic void visitToken(DetailAST ast)
AbstractCheckvisitToken in class AbstractCheckast - the token to processprivate boolean isExempt(java.lang.String classOrStaticMember)
classOrStaticMember - the class or static memberprivate static boolean isStarImportOfPackage(java.lang.String classOrStaticMember, java.lang.String exclude)
classOrStaticMember - - full name of memberexclude - - current exclusionCopyright © 2001-2022. All Rights Reserved.