public class UnusedImportsCheck extends AbstractCheck
Checks for unused import statements. Checkstyle uses a simple but very reliable algorithm to report on unused import statements. An import statement is considered unused if:
import java.io.*;. Most IDE's provide very sophisticated
checks for imports that handle wild-card imports.
java.lang package. For example
importing java.lang.String.
java.util.List would be considered referenced with the Javadoc
comment {@link List}. The alternative to avoid introducing a compile
time dependency would be to write the Javadoc comment as {@link java.util.List}.
The main limitation of this check is handling the case where an imported type has the same name as a declaration, such as a member variable.
For example, in the following case the import java.awt.Component
will not be flagged as unused:
import java.awt.Component;
class FooBar {
private Object Component; // a bad practice in my opinion
...
}
processJavadoc - Control whether to process Javadoc comments.
Type is boolean.
Default value is true.
To configure the check:
<module name="UnusedImports"/>
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation Message Keys:
import.unused
| Modifier and Type | Class and Description |
|---|---|
private static class |
UnusedImportsCheck.Frame
Holds the names of referenced types and names of declared inner types.
|
AutomaticBean.OutputStreamOptions| Modifier and Type | Field and Description |
|---|---|
private static java.util.regex.Pattern |
ARGUMENT_NAME
Regex to match argument names.
|
private static java.util.regex.Pattern |
CLASS_NAME
Regex to match class names.
|
private boolean |
collect
Flag to indicate when time to start collecting references.
|
private UnusedImportsCheck.Frame |
currentFrame
The scope is being processed.
|
private static java.util.regex.Pattern |
FIRST_CLASS_NAME
Regex to match the first class name.
|
private java.util.Set<FullIdent> |
imports
Set of the imports.
|
private static java.util.regex.Pattern |
JAVA_LANG_PACKAGE_PATTERN
Regexp pattern to match java.lang package.
|
static java.lang.String |
MSG_KEY
A key is pointing to the warning message text in "messages.properties"
file.
|
private boolean |
processJavadoc
Control whether to process Javadoc comments.
|
private static java.lang.String |
STAR_IMPORT_SUFFIX
Suffix for the star import.
|
| Constructor and Description |
|---|
UnusedImportsCheck() |
| Modifier and Type | Method and Description |
|---|---|
void |
beginTree(DetailAST rootAST)
Called before the starting to process a tree.
|
private void |
collectReferencesFromJavadoc(DetailAST ast)
Collects references made in Javadoc comments.
|
private static java.util.Set<java.lang.String> |
collectReferencesFromJavadoc(TextBlock textBlock)
Process a javadoc
TextBlock and return the set of classes
referenced within. |
void |
finishTree(DetailAST rootAST)
Called after finished processing a tree.
|
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 static java.util.List<JavadocTag> |
getValidTags(TextBlock cmt,
JavadocUtil.JavadocTagType tagType)
Returns the list of valid tags found in a javadoc
TextBlock. |
private boolean |
isUnusedImport(java.lang.String imprt)
Checks whether an import is unused.
|
void |
leaveToken(DetailAST ast)
Called after all the child nodes have been process.
|
private static java.util.Set<java.lang.String> |
matchPattern(java.lang.String identifier,
java.util.regex.Pattern pattern)
Extracts a list of texts matching a
Pattern from a
String. |
private void |
processIdent(DetailAST ast)
Collects references made by IDENT.
|
private void |
processImport(DetailAST ast)
Collects the details of imports.
|
private static java.util.Set<java.lang.String> |
processJavadocTag(JavadocTag tag)
Returns a list of references found in a javadoc
JavadocTag. |
private void |
processStaticImport(DetailAST ast)
Collects the details of static imports.
|
void |
setProcessJavadoc(boolean value)
Setter to control whether to process Javadoc comments.
|
private static java.lang.String |
topLevelType(java.lang.String type)
If the given type string contains "." (e.g.
|
void |
visitToken(DetailAST ast)
Called to process a token.
|
clearViolations, destroy, getFileContents, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, 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.util.regex.Pattern CLASS_NAME
private static final java.util.regex.Pattern FIRST_CLASS_NAME
private static final java.util.regex.Pattern ARGUMENT_NAME
private static final java.util.regex.Pattern JAVA_LANG_PACKAGE_PATTERN
private static final java.lang.String STAR_IMPORT_SUFFIX
private boolean collect
private boolean processJavadoc
private UnusedImportsCheck.Frame currentFrame
public UnusedImportsCheck()
public void setProcessJavadoc(boolean value)
value - Flag for processing Javadoc comments.public void beginTree(DetailAST rootAST)
AbstractCheckbeginTree in class AbstractCheckrootAST - the root of the treepublic void finishTree(DetailAST rootAST)
AbstractCheckfinishTree in class AbstractCheckrootAST - the root of the treepublic int[] getDefaultTokens()
AbstractCheckgetDefaultTokens in class AbstractCheckTokenTypespublic int[] getRequiredTokens()
AbstractCheckgetRequiredTokens in class AbstractCheckTokenTypespublic int[] getAcceptableTokens()
AbstractCheckgetAcceptableTokens in class AbstractCheckTokenTypespublic void visitToken(DetailAST ast)
AbstractCheckvisitToken in class AbstractCheckast - the token to processpublic void leaveToken(DetailAST ast)
AbstractCheckleaveToken in class AbstractCheckast - the token leavingprivate boolean isUnusedImport(java.lang.String imprt)
imprt - an import.private void processIdent(DetailAST ast)
ast - the IDENT node to processprivate void processImport(DetailAST ast)
ast - node containing the import detailsprivate void processStaticImport(DetailAST ast)
ast - node containing the static import detailsprivate void collectReferencesFromJavadoc(DetailAST ast)
ast - node to inspect for Javadocprivate static java.util.Set<java.lang.String> collectReferencesFromJavadoc(TextBlock textBlock)
TextBlock and return the set of classes
referenced within.textBlock - The javadoc block to parseprivate static java.util.List<JavadocTag> getValidTags(TextBlock cmt, JavadocUtil.JavadocTagType tagType)
TextBlock.cmt - The javadoc block to parsetagType - The type of tags we're interested inprivate static java.util.Set<java.lang.String> processJavadocTag(JavadocTag tag)
JavadocTag.tag - The javadoc tag to parseprivate static java.util.Set<java.lang.String> matchPattern(java.lang.String identifier, java.util.regex.Pattern pattern)
Pattern from a
String.identifier - The String to match the pattern againstpattern - The Pattern used to extract the textsprivate static java.lang.String topLevelType(java.lang.String type)
type - A possibly qualified type nameCopyright © 2001-2022. All Rights Reserved.