public final class InterfaceIsTypeCheck extends AbstractCheck
Implements Joshua Bloch, Effective Java, Item 17 - Use Interfaces only to define types.
According to Bloch, an interface should describe a type. It is therefore inappropriate to define an interface that does not contain any methods but only constants. The Standard interface javax.swing.SwingConstants is an example of an interface that would be flagged by this check.
The check can be configured to also disallow marker interfaces like java.io.Serializable,
that do not contain methods or constants at all.
allowMarkerInterfaces - Control whether marker interfaces
like Serializable are allowed.
Type is boolean.
Default value is true.
To configure the check:
<module name="InterfaceIsType"/>
Example:
public interface Test1 { // violation
int a = 3;
}
public interface Test2 { // OK
}
public interface Test3 { // OK
int a = 3;
void test();
}
To configure the check to report violation so that it doesn't allow Marker Interfaces:
<module name="InterfaceIsType"> <property name="allowMarkerInterfaces" value="false"/> </module>
Example:
public interface Test1 { // violation
int a = 3;
}
public interface Test2 { // violation
}
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation Message Keys:
interface.type
AutomaticBean.OutputStreamOptions| Modifier and Type | Field and Description |
|---|---|
private boolean |
allowMarkerInterfaces
Control whether marker interfaces like Serializable are allowed.
|
static java.lang.String |
MSG_KEY
A key is pointing to the warning message text in "messages.properties"
file.
|
| Constructor and Description |
|---|
InterfaceIsTypeCheck() |
| 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 |
setAllowMarkerInterfaces(boolean flag)
Setter to control whether marker interfaces like Serializable are allowed.
|
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 boolean allowMarkerInterfaces
public InterfaceIsTypeCheck()
public 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 setAllowMarkerInterfaces(boolean flag)
flag - whether to allow marker interfaces or notCopyright © 2001-2022. All Rights Reserved.