Class ModifierOrderCheck
java.lang.Object
com.puppycrawl.tools.checkstyle.AbstractAutomaticBean
com.puppycrawl.tools.checkstyle.api.AbstractViolationReporter
com.puppycrawl.tools.checkstyle.api.AbstractCheck
com.puppycrawl.tools.checkstyle.checks.modifier.ModifierOrderCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Checks that the order of modifiers conforms to the suggestions in the
 
 Java Language specification, § 8.1.1, 8.3.1, 8.4.3 and
 9.4.
 The correct order is:
 
 -  public
-  protected
-  private
-  abstract
-  default
-  static
-  sealed
-  non-sealed
-  final
-  transient
-  volatile
-  synchronized
-  native
-  strictfp
In additional, modifiers are checked to ensure all annotations are declared before all other modifiers.
Rationale: Code is easier to read if everybody follows a standard.
ATTENTION: We skip type annotations from validation.
- Since:
- 3.0
- 
Nested Class SummaryNested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate static final String[]The order of modifiers as suggested in sections 8.1.1, 8.3.1 and 8.4.3 of the JLS.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.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionprivate static DetailASTcheckOrderSuggestedByJls(List<DetailAST> modifiers) Checks if the modifiers were added in the order suggested in the Java language specification.int[]The configurable token set.int[]Returns the default token a check is interested in.int[]The tokens that this check must be registered for.private static booleanisAnnotationOnType(DetailAST modifier) Checks whether annotation on type takes place.private static DetailASTskipAnnotations(Iterator<DetailAST> modifierIterator) Skip all annotations in modifier block.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckbeginTree, clearViolations, destroy, finishTree, getFileContents, getFilePath, getLine, getLineCodePoints, getLines, getTabWidth, getTokenNames, getViolations, init, isCommentNodesRequired, leaveToken, log, log, log, setFileContents, setTabWidth, setTokensMethods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractViolationReporterfinishLocalSetup, getCustomMessages, getId, getMessageBundle, getSeverity, getSeverityLevel, setId, setSeverityMethods inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanconfigure, contextualize, getConfiguration, setupChild
- 
Field Details- 
MSG_ANNOTATION_ORDERA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_MODIFIER_ORDERA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
JLS_ORDERThe order of modifiers as suggested in sections 8.1.1, 8.3.1 and 8.4.3 of the JLS.
 
- 
- 
Constructor Details- 
ModifierOrderCheckpublic ModifierOrderCheck()
 
- 
- 
Method Details- 
getDefaultTokensDescription 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 class- AbstractCheck
- Returns:
- the default tokens
- See Also:
 
- 
getAcceptableTokensDescription 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 class- AbstractCheck
- Returns:
- the token set this check is designed for.
- See Also:
 
- 
getRequiredTokensDescription copied from class:AbstractCheckThe tokens that this check must be registered for.- Specified by:
- getRequiredTokensin class- AbstractCheck
- Returns:
- the token set this must be registered for.
- See Also:
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
checkOrderSuggestedByJlsChecks if the modifiers were added in the order suggested in the Java language specification.- Parameters:
- modifiers- list of modifier AST tokens
- Returns:
- null if the order is correct, otherwise returns the offending modifier AST.
 
- 
skipAnnotationsSkip all annotations in modifier block.- Parameters:
- modifierIterator- iterator for collection of modifiers
- Returns:
- modifier next to last annotation
 
- 
isAnnotationOnTypeChecks whether annotation on type takes place.- Parameters:
- modifier- modifier token.
- Returns:
- true if annotation on type takes place.
 
 
-