Class IndentationCheck
- All Implemented Interfaces:
Configurable,Contextualizable
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
arrayInitIndent- Specify how far an array initialization should be indented when on next line. Type isint. Default value is4. -
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
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. -
Property
lineWrappingIndentation- Specify how far continuation line should be indented when line-wrapping is present. 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.
Parent is com.puppycrawl.tools.checkstyle.TreeWalker
Violation 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.AbstractAutomaticBean
AbstractAutomaticBean.OutputStreamOptions -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate intSpecify how far an array initialization should be indented when on next line.private intSpecify how far new indentation level should be indented when on the next line.private intSpecify how far a braces should be indented when on the next line.private intSpecify how far a case label should be indented when on next line.private static final intDefault indentation amount - based on Sun.private booleanForce strict indent level in line wrapping case.private final HandlerFactoryFactory from which handlers are distributed.private final Deque<AbstractExpressionHandler>Handlers currently in use.Lines logged as having incorrect indentation.private final LineWrappingHandlerInstance of line wrapping handler to use.private intSpecify how far continuation line should be indented when line-wrapping is present.static final StringA key is pointing to the warning message text in "messages.properties" file.static final StringA key is pointing to the warning message text in "messages.properties" file.static final StringA key is pointing to the warning message text in "messages.properties" file.static final StringA key is pointing to the warning message text in "messages.properties" file.private intSpecify how far a throws clause should be indented when on next line. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidCalled before the starting to process a tree.int[]The configurable token set.intGetter to query how far an array initialization should be indented when on next line.intGetter to query how far new indentation level should be indented when on the next line.intGetter to query how far a braces should be indented when on the next line.intGetter to query how far a case label should be indented when on next line.int[]Returns the default token a check is interested in.final HandlerFactoryAccessor for the handler factory.intGet the width of a tab.Accessor for the line wrapping handler.intGetter to query how far continuation line should be indented when line-wrapping is present.int[]The tokens that this check must be registered for.intGetter to query how far a throws clause should be indented when on next line.voidindentationLog(DetailAST ast, String key, Object... args) Log a violation message.booleanGetter 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 initialization 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
clearViolations, destroy, finishTree, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, log, log, log, setFileContents, setTabWidth, setTokensMethods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
finishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
configure, contextualize, getConfiguration, setupChild
-
Field Details
-
MSG_ERROR
A key is pointing to the warning message text in "messages.properties" file.- See Also:
-
MSG_ERROR_MULTI
A key is pointing to the warning message text in "messages.properties" file.- See Also:
-
MSG_CHILD_ERROR
A key is pointing to the warning message text in "messages.properties" file.- See Also:
-
MSG_CHILD_ERROR_MULTI
A key is pointing to the warning message text in "messages.properties" file.- See Also:
-
DEFAULT_INDENTATION
Default indentation amount - based on Sun.- See Also:
-
handlers
Handlers currently in use. -
lineWrappingHandler
Instance of line wrapping handler to use. -
handlerFactory
Factory from which handlers are distributed. -
incorrectIndentationLines
Lines logged as having incorrect indentation. -
basicOffset
Specify how far new indentation level should be indented when on the next line. -
caseIndent
Specify how far a case label should be indented when on next line. -
braceAdjustment
Specify how far a braces should be indented when on the next line. -
throwsIndent
Specify how far a throws clause should be indented when on next line. -
arrayInitIndent
Specify how far an array initialization should be indented when on next line. -
lineWrappingIndentation
Specify how far continuation line should be indented when line-wrapping is present. -
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.
-
-
Constructor Details
-
IndentationCheck
public IndentationCheck()
-
-
Method Details
-
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
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.- Since:
- 6.3
-
setBasicOffset
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- Since:
- 3.1
-
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
Setter to specify how far a braces should be indented when on the next line.- Parameters:
adjustmentAmount- the brace offset- Since:
- 3.1
-
getBraceAdjustment
Getter to query how far a braces should be indented when on the next line.- Returns:
- the positive offset to adjust braces
-
setCaseIndent
Setter to specify how far a case label should be indented when on next line.- Parameters:
amount- the case indentation level- Since:
- 3.1
-
getCaseIndent
Getter to query how far a case label should be indented when on next line.- Returns:
- the case indentation level
-
setThrowsIndent
Setter to specify how far a throws clause should be indented when on next line.- Parameters:
throwsIndent- the throws indentation level- Since:
- 5.7
-
getThrowsIndent
Getter to query how far a throws clause should be indented when on next line.- Returns:
- the throws indentation level
-
setArrayInitIndent
Setter to specify how far an array initialization should be indented when on next line.- Parameters:
arrayInitIndent- the array initialization indentation level- Since:
- 5.8
-
getArrayInitIndent
Getter to query how far an array initialization should be indented when on next line.- Returns:
- the initialization indentation level
-
getLineWrappingIndentation
Getter to query how far continuation line should be indented when line-wrapping is present.- Returns:
- the line-wrapping indentation level
-
setLineWrappingIndentation
Setter to specify how far continuation line should be indented when line-wrapping is present.- Parameters:
lineWrappingIndentation- the line-wrapping indentation level- Since:
- 5.9
-
indentationLog
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:
-
getIndentationTabWidth
Get the width of a tab.- Returns:
- the width of a tab
-
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:
-
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:
-
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:
-
beginTree
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
Description copied from class:AbstractCheckCalled to process a token.- Overrides:
visitTokenin classAbstractCheck- Parameters:
ast- the token to process
-
leaveToken
Description copied from class:AbstractCheckCalled after all the child nodes have been process.- Overrides:
leaveTokenin classAbstractCheck- Parameters:
ast- the token leaving
-
getLineWrappingHandler
Accessor for the line wrapping handler.- Returns:
- the line wrapping handler
-
getHandlerFactory
Accessor for the handler factory.- Returns:
- the handler factory
-