public class DefaultComesLastCheck extends AbstractCheck
Check that the default is after all the cases in a switch statement.
Rationale: Java allows default anywhere within the
switch statement. But it is more readable if it comes after the last case.
skipIfLastAndSharedWithCase - Control whether to allow default
along with case if they are not last.
Type is boolean.
Default value is false.
To configure the check:
<module name="DefaultComesLast"/>
Example:
switch (i) {
case 1:
break;
case 2:
break;
default: // OK
break;
}
switch (i) {
case 1:
break;
case 2:
break; // OK, no default
}
switch (i) {
case 1:
break;
default: // violation, 'default' before 'case'
break;
case 2:
break;
}
switch (i) {
case 1:
default: // violation, 'default' before 'case'
break;
case 2:
break;
}
To configure the check to allow default label to be not last if it is shared with case:
<module name="DefaultComesLast"> <property name="skipIfLastAndSharedWithCase" value="true"/> </module>
Example:
switch (i) {
case 1:
break;
case 2:
default: // OK
break;
case 3:
break;
}
switch (i) {
case 1:
break;
default: // violation
case 2:
break;
}
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation Message Keys:
default.comes.last
default.comes.last.in.casegroup
AutomaticBean.OutputStreamOptions| Modifier and Type | Field and Description |
|---|---|
static String |
MSG_KEY
A key is pointing to the warning message text in "messages.properties"
file.
|
static String |
MSG_KEY_SKIP_IF_LAST_AND_SHARED_WITH_CASE
A key is pointing to the warning message text in "messages.properties"
file.
|
| Constructor and Description |
|---|
DefaultComesLastCheck() |
| 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 |
setSkipIfLastAndSharedWithCase(boolean newValue)
Setter to control whether to allow
default along with
case if they are not last. |
void |
visitToken(DetailAST ast)
Called to process a token.
|
beginTree, clearMessages, destroy, finishTree, getFileContents, getLine, getLines, getMessages, getTabWidth, getTokenNames, init, isCommentNodesRequired, leaveToken, log, log, log, setFileContents, setTabWidth, setTokensfinishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityconfigure, contextualize, getConfiguration, setupChildpublic static final String MSG_KEY
public static final String MSG_KEY_SKIP_IF_LAST_AND_SHARED_WITH_CASE
public DefaultComesLastCheck()
public int[] getAcceptableTokens()
AbstractCheckgetAcceptableTokens in class AbstractCheckTokenTypespublic int[] getDefaultTokens()
AbstractCheckgetDefaultTokens in class AbstractCheckTokenTypespublic int[] getRequiredTokens()
AbstractCheckgetRequiredTokens in class AbstractCheckTokenTypespublic void setSkipIfLastAndSharedWithCase(boolean newValue)
default along with
case if they are not last.newValue - whether to ignore checking.public void visitToken(DetailAST ast)
AbstractCheckvisitToken in class AbstractCheckast - the token to processCopyright © 2001–2020. All rights reserved.