Class IndentationCheck
- java.lang.Object
-
- com.puppycrawl.tools.checkstyle.api.AutomaticBean
-
- com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
-
- com.puppycrawl.tools.checkstyle.api.AbstractCheck
-
- com.puppycrawl.tools.checkstyle.checks.indentation.IndentationCheck
-
- All Implemented Interfaces:
Configurable,Contextualizable
public class IndentationCheck extends AbstractCheck
Checks correct indentation of Java code.
The idea behind this is that while pretty printers are sometimes convenient for bulk reformats of legacy code, they often either aren't configurable enough or just can't anticipate how format should be done. Sometimes this is personal preference, other times it is practical experience. In any case, this check should just ensure that a minimal set of indentation rules is followed.
Basic offset indentation is used for indentation inside code blocks. For any lines that span more than 1, line wrapping indentation is used for those lines after the first. Brace adjustment, case, and throws indentations are all used only if those specific identifiers start the line. If, for example, a brace is used in the middle of the line, its indentation will not take effect. All indentations have an accumulative/recursive effect when they are triggered. If during a line wrapping, another code block is found and it doesn't end on that same line, then the subsequent lines afterwards, in that new code block, are increased on top of the line wrap and any indentations above it.
Example:
if ((condition1 && condition2) || (condition3 && condition4) // line wrap with bigger indentation ||!(condition5 && condition6)) { // line wrap with bigger indentation field.doSomething() // basic offset .doSomething() // line wrap .doSomething( c -> { // line wrap return c.doSome(); // basic offset }); }-
Property
basicOffset- Specify how far new indentation level should be indented when on the next line. Type isint. Default value is4. -
Property
braceAdjustment- Specify how far a braces should be indented when on the next line. Type isint. Default value is0. -
Property
caseIndent- Specify how far a case label should be indented when on next line. Type isint. Default value is4. -
Property
throwsIndent- Specify how far a throws clause should be indented when on next line. Type isint. Default value is4. -
Property
arrayInitIndent- Specify how far an array initialisation should be indented when on next line. Type isint. Default value is4. -
Property
lineWrappingIndentation- Specify how far continuation line should be indented when line-wrapping is present. Type isint. Default value is4. -
Property
forceStrictCondition- Force strict indent level in line wrapping case. If value is true, line wrap indent have to be same as lineWrappingIndentation parameter. If value is false, line wrap indent could be bigger on any value user would like. Type isboolean. Default value isfalse.
To configure the default check:
<module name="Indentation"/>
Example of Compliant code for default configuration (in comment name of property that controls indentations):
class Test { String field; // basicOffset int[] arr = { // basicOffset 5, // arrayInitIndent 6 }; // arrayInitIndent void bar() throws Exception // basicOffset { // braceAdjustment foo(); // basicOffset } // braceAdjustment void foo() { // basicOffset if ((cond1 && cond2) // basicOffset || (cond3 && cond4) // lineWrappingIndentation, forceStrictCondition ||!(cond5 && cond6)) { // lineWrappingIndentation, forceStrictCondition field.doSomething() // basicOffset .doSomething() // lineWrappingIndentation and forceStrictCondition .doSomething( c -> { // lineWrappingIndentation and forceStrictCondition return c.doSome(); // basicOffset }); } } void fooCase() // basicOffset throws Exception { // throwsIndent switch (field) { // basicOffset case "value" : bar(); // caseIndent } } }To configure the check to enforce the indentation style recommended by Oracle:
<module name="Indentation"> <property name="caseIndent" value="0"/> </module>
Example of Compliant code for default configuration (in comment name of property that controls indentation):
void fooCase() { // basicOffset switch (field) { // basicOffset case "value" : bar(); // caseIndent } }To configure the Check to enforce strict condition in line-wrapping validation.
<module name="Indentation"> <property name="forceStrictCondition" value="true"/> </module>
Such config doesn't allow next cases even code is aligned further to the right for better reading:
void foo(String aFooString, int aFooInt) { // indent:8 ; expected: 4; violation, because 8 != 4 if (cond1 || cond2) { field.doSomething() .doSomething(); } if ((cond1 && cond2) || (cond3 && cond4) // violation ||!(cond5 && cond6)) { // violation field.doSomething() .doSomething() // violation .doSomething( c -> { // violation return c.doSome(); }); } }But if forceStrictCondition = false, this code is valid:
void foo(String aFooString, int aFooInt) { // indent:8 ; expected: > 4; ok, because 8 > 4 if (cond1 || cond2) { field.doSomething() .doSomething(); } if ((cond1 && cond2) || (cond3 && cond4) ||!(cond5 && cond6)) { field.doSomething() .doSomething() .doSomething( c -> { return c.doSome(); }); } }Parent is
com.puppycrawl.tools.checkstyle.TreeWalkerViolation Message Keys:
-
indentation.child.error -
indentation.child.error.multi -
indentation.error -
indentation.error.multi
- Since:
- 3.1
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.api.AutomaticBean
AutomaticBean.OutputStreamOptions
-
-
Field Summary
Fields Modifier and Type Field Description static java.lang.StringMSG_CHILD_ERRORA key is pointing to the warning message text in "messages.properties" file.static java.lang.StringMSG_CHILD_ERROR_MULTIA key is pointing to the warning message text in "messages.properties" file.static java.lang.StringMSG_ERRORA key is pointing to the warning message text in "messages.properties" file.static java.lang.StringMSG_ERROR_MULTIA key is pointing to the warning message text in "messages.properties" file.
-
Constructor Summary
Constructors Constructor Description IndentationCheck()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidbeginTree(DetailAST ast)Called before the starting to process a tree.int[]getAcceptableTokens()The configurable token set.intgetArrayInitIndent()Getter to query how far an array initialisation should be indented when on next line.intgetBasicOffset()Getter to query how far new indentation level should be indented when on the next line.intgetBraceAdjustment()Getter to query how far a braces should be indented when on the next line.intgetCaseIndent()Getter to query how far a case label should be indented when on next line.int[]getDefaultTokens()Returns the default token a check is interested in.HandlerFactorygetHandlerFactory()Accessor for the handler factory.intgetIndentationTabWidth()Get the width of a tab.LineWrappingHandlergetLineWrappingHandler()Accessor for the line wrapping handler.intgetLineWrappingIndentation()Getter to query how far continuation line should be indented when line-wrapping is present.int[]getRequiredTokens()The tokens that this check must be registered for.intgetThrowsIndent()Getter to query how far a throws clause should be indented when on next line.voidindentationLog(DetailAST ast, java.lang.String key, java.lang.Object... args)Log a violation message.booleanisForceStrictCondition()Getter to query strict indent level in line wrapping case.voidleaveToken(DetailAST ast)Called after all the child nodes have been process.voidsetArrayInitIndent(int arrayInitIndent)Setter to specify how far an array initialisation should be indented when on next line.voidsetBasicOffset(int basicOffset)Setter to specify how far new indentation level should be indented when on the next line.voidsetBraceAdjustment(int adjustmentAmount)Setter to specify how far a braces should be indented when on the next line.voidsetCaseIndent(int amount)Setter to specify how far a case label should be indented when on next line.voidsetForceStrictCondition(boolean value)Setter to force strict indent level in line wrapping case.voidsetLineWrappingIndentation(int lineWrappingIndentation)Setter to specify how far continuation line should be indented when line-wrapping is present.voidsetThrowsIndent(int throwsIndent)Setter to specify how far a throws clause should be indented when on next line.voidvisitToken(DetailAST ast)Called to process a token.-
Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheck
clearMessages, destroy, finishTree, getFileContents, getLine, getLines, getMessages, getTabWidth, getTokenNames, init, isCommentNodesRequired, log, log, log, setFileContents, setTabWidth, setTokens
-
Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
finishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverity
-
Methods inherited from class com.puppycrawl.tools.checkstyle.api.AutomaticBean
configure, contextualize, getConfiguration, setupChild
-
-
-
-
Field Detail
-
MSG_ERROR
public static final java.lang.String MSG_ERROR
A key is pointing to the warning message text in "messages.properties" file.- See Also:
- Constant Field Values
-
MSG_ERROR_MULTI
public static final java.lang.String MSG_ERROR_MULTI
A key is pointing to the warning message text in "messages.properties" file.- See Also:
- Constant Field Values
-
MSG_CHILD_ERROR
public static final java.lang.String MSG_CHILD_ERROR
A key is pointing to the warning message text in "messages.properties" file.- See Also:
- Constant Field Values
-
MSG_CHILD_ERROR_MULTI
public static final java.lang.String MSG_CHILD_ERROR_MULTI
A key is pointing to the warning message text in "messages.properties" file.- See Also:
- Constant Field Values
-
-
Method Detail
-
isForceStrictCondition
public boolean isForceStrictCondition()
Getter to query strict indent level in line wrapping case. If value is true, line wrap indent have to be same as lineWrappingIndentation parameter. If value is false, line wrap indent could be bigger on any value user would like.- Returns:
- forceStrictCondition value.
-
setForceStrictCondition
public void setForceStrictCondition(boolean value)
Setter to force strict indent level in line wrapping case. If value is true, line wrap indent have to be same as lineWrappingIndentation parameter. If value is false, line wrap indent could be bigger on any value user would like.- Parameters:
value- user's value of forceStrictCondition.
-
setBasicOffset
public void setBasicOffset(int basicOffset)
Setter to specify how far new indentation level should be indented when on the next line.- Parameters:
basicOffset- the number of tabs or spaces to indent
-
getBasicOffset
public int getBasicOffset()
Getter to query how far new indentation level should be indented when on the next line.- Returns:
- the number of tabs or spaces to indent
-
setBraceAdjustment
public void setBraceAdjustment(int adjustmentAmount)
Setter to specify how far a braces should be indented when on the next line.- Parameters:
adjustmentAmount- the brace offset
-
getBraceAdjustment
public int getBraceAdjustment()
Getter to query how far a braces should be indented when on the next line.- Returns:
- the positive offset to adjust braces
-
setCaseIndent
public void setCaseIndent(int amount)
Setter to specify how far a case label should be indented when on next line.- Parameters:
amount- the case indentation level
-
getCaseIndent
public int getCaseIndent()
Getter to query how far a case label should be indented when on next line.- Returns:
- the case indentation level
-
setThrowsIndent
public void setThrowsIndent(int throwsIndent)
Setter to specify how far a throws clause should be indented when on next line.- Parameters:
throwsIndent- the throws indentation level
-
getThrowsIndent
public int getThrowsIndent()
Getter to query how far a throws clause should be indented when on next line.- Returns:
- the throws indentation level
-
setArrayInitIndent
public void setArrayInitIndent(int arrayInitIndent)
Setter to specify how far an array initialisation should be indented when on next line.- Parameters:
arrayInitIndent- the array initialisation indentation level
-
getArrayInitIndent
public int getArrayInitIndent()
Getter to query how far an array initialisation should be indented when on next line.- Returns:
- the initialisation indentation level
-
getLineWrappingIndentation
public int getLineWrappingIndentation()
Getter to query how far continuation line should be indented when line-wrapping is present.- Returns:
- the line-wrapping indentation level
-
setLineWrappingIndentation
public void setLineWrappingIndentation(int lineWrappingIndentation)
Setter to specify how far continuation line should be indented when line-wrapping is present.- Parameters:
lineWrappingIndentation- the line-wrapping indentation level
-
indentationLog
public void indentationLog(DetailAST ast, java.lang.String key, java.lang.Object... args)
Log a violation message.- Parameters:
ast- the ast for which error to be loggedkey- the message that describes the violationargs- the details of the message- See Also:
MessageFormat
-
getIndentationTabWidth
public int getIndentationTabWidth()
Get the width of a tab.- Returns:
- the width of a tab
-
getDefaultTokens
public int[] getDefaultTokens()
Description 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 classAbstractCheck- Returns:
- the default tokens
- See Also:
TokenTypes
-
getAcceptableTokens
public int[] getAcceptableTokens()
Description 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 classAbstractCheck- Returns:
- the token set this check is designed for.
- See Also:
TokenTypes
-
getRequiredTokens
public int[] getRequiredTokens()
Description copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
getRequiredTokensin classAbstractCheck- Returns:
- the token set this must be registered for.
- See Also:
TokenTypes
-
beginTree
public void beginTree(DetailAST ast)
Description 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 classAbstractCheck- Parameters:
ast- the root of the tree
-
visitToken
public void visitToken(DetailAST ast)
Description copied from class:AbstractCheckCalled to process a token.- Overrides:
visitTokenin classAbstractCheck- Parameters:
ast- the token to process
-
leaveToken
public void leaveToken(DetailAST ast)
Description copied from class:AbstractCheckCalled after all the child nodes have been process.- Overrides:
leaveTokenin classAbstractCheck- Parameters:
ast- the token leaving
-
getLineWrappingHandler
public LineWrappingHandler getLineWrappingHandler()
Accessor for the line wrapping handler.- Returns:
- the line wrapping handler
-
getHandlerFactory
public final HandlerFactory getHandlerFactory()
Accessor for the handler factory.- Returns:
- the handler factory
-
-