Class ImportOrderCheck
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.imports.ImportOrderCheck
- All Implemented Interfaces:
- Configurable,- Contextualizable
 Checks the ordering/grouping of imports. Features are:
 
 - groups type/static imports: ensures that groups of imports come in a specific order (e.g., java. comes first, javax. comes second, then everything else)
- adds a separation between type import groups : ensures that a blank line sit between each group
- type/static import groups aren't separated internally: ensures that each group aren't separated internally by blank line or comment
- sorts type/static imports inside each group: ensures that imports within each group are in lexicographic order
- sorts according to case: ensures that the comparison between imports is case-sensitive, in ASCII sort order
- arrange static imports: ensures the relative order between type imports and static imports (see ImportOrderOption)
- Since:
- 3.2
- 
Nested Class SummaryNested classes/interfaces inherited from class com.puppycrawl.tools.checkstyle.AbstractAutomaticBeanAbstractAutomaticBean.OutputStreamOptions
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate booleanWhether there were any imports.private booleanControl whether string comparison should be case-sensitive or not.private static final Pattern[]Empty array of pattern type needed to initialize check.private static final StringThe Forward slash.private String[]Specify list of type import groups.private Pattern[]Complied array of patterns for propertygroups.private intLast imported group.private StringName of last import.private intLine number of last import.private booleanIf last import was static.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 ImportOrderOptionSpecify policy on the relative order between type imports and static imports.private booleanControl whether type imports within each group should be sorted.private booleanControl whether type import groups should be separated by, at least, one blank line or comment and aren't separated internally.private booleanControl whether static import groups should be separated by, at least, one blank line or comment and aren't separated internally.private booleanControl whether static imports located at top or bottom are sorted within the group.private String[]Specify list of static import groups.private Pattern[]Complied array of patterns for propertystaticGroups.private booleanWhether static and type import groups should be split apart.private booleanControl whether to use container ordering (Eclipse IDE term) for static imports or not.private static final StringThe special wildcard that catches all remaining groups.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidCalled before the starting to process a tree.private static intCompares two strings.private static intcompareContainerOrder(String importName1, String importName2, boolean caseSensitive) Compares two import strings.private static Pattern[]compilePatterns(String... packageGroups) Compiles the list of package groups and the order they should occur in the file.private voiddoVisitToken(FullIdent ident, boolean isStatic, boolean previous, DetailAST ast) Shares processing...private voiddoVisitTokenInSameGroup(boolean isStatic, boolean previous, String name, DetailAST ast) Shares processing...int[]The configurable token set.int[]Returns the default token a check is interested in.private intgetGroupNumber(boolean isStatic, String name) Finds out what group the specified import belongs to.private static intgetGroupNumber(Pattern[] patterns, String name) Finds out what group the specified import belongs to.private static StringgetImportContainer(String qualifiedImportName) Extracts import container name from fully qualified import name.int[]The tokens that this check must be registered for.private booleanisSeparatorBeforeImport(int line) Checks whether there is any separator before current import.private booleanisSeparatorInGroup(int groupIdx, boolean isStatic, int line) Checks whether imports group separated internally.private booleanisWrongOrder(String name, boolean isStatic) Checks whether import name is in wrong order.private booleanneedSeparator(boolean isStatic) Checks whether import groups should be separated.voidsetCaseSensitive(boolean caseSensitive) Setter to control whether string comparison should be case-sensitive or not.voidSetter to specify list of type import groups.voidSetter to specify policy on the relative order between type imports and static imports.voidsetOrdered(boolean ordered) Setter to control whether type imports within each group should be sorted.voidsetSeparated(boolean separated) Setter to control whether type import groups should be separated by, at least, one blank line or comment and aren't separated internally.voidsetSeparatedStaticGroups(boolean separatedStaticGroups) Setter to control whether static import groups should be separated by, at least, one blank line or comment and aren't separated internally.voidsetSortStaticImportsAlphabetically(boolean sortAlphabetically) Setter to control whether static imports located at top or bottom are sorted within the group.voidsetStaticGroups(String... packageGroups) Setter to specify list of static import groups.voidsetUseContainerOrderingForStatic(boolean useContainerOrdering) Setter to control whether to use container ordering (Eclipse IDE term) for static imports or not.voidvisitToken(DetailAST ast) Called to process a token.Methods inherited from class com.puppycrawl.tools.checkstyle.api.AbstractCheckclearViolations, 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_SEPARATIONA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_ORDERINGA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
MSG_SEPARATED_IN_GROUPA key is pointing to the warning message text in "messages.properties" file.- See Also:
 
- 
WILDCARD_GROUP_NAMEThe special wildcard that catches all remaining groups.- See Also:
 
- 
FORWARD_SLASHThe Forward slash.- See Also:
 
- 
EMPTY_PATTERN_ARRAYEmpty array of pattern type needed to initialize check.
- 
groupsSpecify list of type import groups. Every group identified either by a common prefix string, or by a regular expression enclosed in forward slashes (e.g./regexp/). If an import matches two or more groups, the best match is selected (closest to the start, and the longest match). All type imports, which does not match any group, falls into an additional group, located at the end. Thus, the empty list of type groups (the default value) means one group for all type imports.
- 
staticGroupsSpecify list of static import groups. Every group identified either by a common prefix string, or by a regular expression enclosed in forward slashes (e.g./regexp/). If an import matches two or more groups, the best match is selected (closest to the start, and the longest match). All static imports, which does not match any group, fall into an additional group, located at the end. Thus, the empty list of static groups (the default value) means one group for all static imports. This property has effect only when the propertyoptionis set totoporbottom.
- 
separatedControl whether type import groups should be separated by, at least, one blank line or comment and aren't separated internally. It doesn't affect separations for static imports.
- 
separatedStaticGroupsControl whether static import groups should be separated by, at least, one blank line or comment and aren't separated internally. This property has effect only when the propertyoptionis set totoporbottomand when propertystaticGroupsis enabled.
- 
orderedControl whether type imports within each group should be sorted. It doesn't affect sorting for static imports.
- 
caseSensitiveControl whether string comparison should be case-sensitive or not. Case-sensitive sorting is in ASCII sort order. It affects both type imports and static imports.
- 
lastGroupLast imported group.
- 
lastImportLineLine number of last import.
- 
lastImportName of last import.
- 
lastImportStaticIf last import was static.
- 
beforeFirstImportWhether there were any imports.
- 
staticImportsApartWhether static and type import groups should be split apart. When theoptionproperty is set toINFLOW,ABOVEorUNDER, both the type and static imports use the propertiesgroupsandseparated. When theoptionproperty is set toTOPorBOTTOM, static imports uses the propertiesstaticGroupsandseparatedStaticGroups.
- 
sortStaticImportsAlphabeticallyControl whether static imports located at top or bottom are sorted within the group.
- 
useContainerOrderingForStaticControl whether to use container ordering (Eclipse IDE term) for static imports or not.
- 
optionSpecify policy on the relative order between type imports and static imports.
- 
groupsRegComplied array of patterns for propertygroups.
- 
staticGroupsRegComplied array of patterns for propertystaticGroups.
 
- 
- 
Constructor Details- 
ImportOrderCheckpublic ImportOrderCheck()
 
- 
- 
Method Details- 
setOptionSetter to specify policy on the relative order between type imports and static imports.- Parameters:
- optionStr- string to decode option from
- Throws:
- IllegalArgumentException- if unable to decode
- Since:
- 5.0
 
- 
setGroupsSetter to specify list of type import groups. Every group identified either by a common prefix string, or by a regular expression enclosed in forward slashes (e.g./regexp/). If an import matches two or more groups, the best match is selected (closest to the start, and the longest match). All type imports, which does not match any group, falls into an additional group, located at the end. Thus, the empty list of type groups (the default value) means one group for all type imports.- Parameters:
- packageGroups- a comma-separated list of package names/prefixes.
- Since:
- 3.2
 
- 
setStaticGroupsSetter to specify list of static import groups. Every group identified either by a common prefix string, or by a regular expression enclosed in forward slashes (e.g./regexp/). If an import matches two or more groups, the best match is selected (closest to the start, and the longest match). All static imports, which does not match any group, fall into an additional group, located at the end. Thus, the empty list of static groups (the default value) means one group for all static imports. This property has effect only when the propertyoptionis set totoporbottom.- Parameters:
- packageGroups- a comma-separated list of package names/prefixes.
- Since:
- 8.12
 
- 
setOrderedSetter to control whether type imports within each group should be sorted. It doesn't affect sorting for static imports.- Parameters:
- ordered- whether lexicographic ordering of imports within a group required or not.
- Since:
- 3.2
 
- 
setSeparatedSetter to control whether type import groups should be separated by, at least, one blank line or comment and aren't separated internally. It doesn't affect separations for static imports.- Parameters:
- separated- whether groups should be separated by one blank line or comment.
- Since:
- 3.2
 
- 
setSeparatedStaticGroupsSetter to control whether static import groups should be separated by, at least, one blank line or comment and aren't separated internally. This property has effect only when the propertyoptionis set totoporbottomand when propertystaticGroupsis enabled.- Parameters:
- separatedStaticGroups- whether groups should be separated by one blank line or comment.
- Since:
- 8.12
 
- 
setCaseSensitiveSetter to control whether string comparison should be case-sensitive or not. Case-sensitive sorting is in ASCII sort order. It affects both type imports and static imports.- Parameters:
- caseSensitive- whether string comparison should be case-sensitive.
- Since:
- 3.3
 
- 
setSortStaticImportsAlphabeticallySetter to control whether static imports located at top or bottom are sorted within the group.- Parameters:
- sortAlphabetically- true or false.
- Since:
- 6.5
 
- 
setUseContainerOrderingForStaticSetter to control whether to use container ordering (Eclipse IDE term) for static imports or not.- Parameters:
- useContainerOrdering- whether to use container ordering for static imports or not.
- Since:
- 7.1
 
- 
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:
 
- 
beginTreeDescription 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 class- AbstractCheck
- Parameters:
- rootAST- the root of the tree
 
- 
visitTokenDescription copied from class:AbstractCheckCalled to process a token.- Overrides:
- visitTokenin class- AbstractCheck
- Parameters:
- ast- the token to process
 
- 
doVisitTokenShares processing...- Parameters:
- ident- the import to process.
- isStatic- whether the token is static or not.
- previous- previous non-static but current is static (above), or previous static but current is non-static (under).
- ast- node of the AST.
 
- 
needSeparatorChecks whether import groups should be separated.- Parameters:
- isStatic- whether the token is static or not.
- Returns:
- true if imports groups should be separated.
 
- 
isSeparatorInGroupChecks whether imports group separated internally.- Parameters:
- groupIdx- group number.
- isStatic- whether the token is static or not.
- line- the line of the current import.
- Returns:
- true if imports group are separated internally.
 
- 
isSeparatorBeforeImportChecks whether there is any separator before current import.- Parameters:
- line- the line of the current import.
- Returns:
- true if there is separator before current import which isn't the first import.
 
- 
doVisitTokenInSameGroupprivate void doVisitTokenInSameGroup(boolean isStatic, boolean previous, String name, DetailAST ast) Shares processing...- Parameters:
- isStatic- whether the token is static or not.
- previous- previous non-static but current is static (above), or previous static but current is non-static (under).
- name- the name of the current import.
- ast- node of the AST.
 
- 
isWrongOrderChecks whether import name is in wrong order.- Parameters:
- name- import name.
- isStatic- whether it is a static import name.
- Returns:
- true if import name is in wrong order.
 
- 
compareContainerOrderprivate static int compareContainerOrder(String importName1, String importName2, boolean caseSensitive) Compares two import strings. We first compare the container of the static import, container being the type enclosing the static element being imported. When this returns 0, we compare the qualified import name. For e.g. this is what is considered to be container names:import static HttpConstants.COLON => HttpConstants import static HttpHeaders.addHeader => HttpHeaders import static HttpHeaders.setHeader => HttpHeaders import static HttpHeaders.Names.DATE => HttpHeaders.Names According to this logic, HttpHeaders.Names would come after HttpHeaders. For more details, see static imports comparison method in Eclipse. - Parameters:
- importName1- first import name
- importName2- second import name
- caseSensitive- whether the comparison of fully qualified import names is case-sensitive
- Returns:
- the value 0if str1 is equal to str2; a value less than0if str is less than the str2 (container order or lexicographical); and a value greater than0if str1 is greater than str2 (container order or lexicographically)
 
- 
getImportContainerExtracts import container name from fully qualified import name. An import container name is the type which encloses the static element being imported. For example, HttpConstants, HttpHeaders, HttpHeaders.Names are import container names:import static HttpConstants.COLON => HttpConstants import static HttpHeaders.addHeader => HttpHeaders import static HttpHeaders.setHeader => HttpHeaders import static HttpHeaders.Names.DATE => HttpHeaders.Names - Parameters:
- qualifiedImportName- fully qualified import name.
- Returns:
- import container name.
 
- 
getGroupNumberFinds out what group the specified import belongs to.- Parameters:
- isStatic- whether the token is static or not.
- name- the import name to find.
- Returns:
- group number for given import name.
 
- 
getGroupNumberFinds out what group the specified import belongs to.- Parameters:
- patterns- groups to check.
- name- the import name to find.
- Returns:
- group number for given import name.
 
- 
compareCompares two strings.- Parameters:
- string1- the first string
- string2- the second string
- caseSensitive- whether the comparison is case-sensitive
- Returns:
- the value 0if string1 is equal to string2; a value less than0if string1 is lexicographically less than the string2; and a value greater than0if string1 is lexicographically greater than string2
 
- 
compilePatternsCompiles the list of package groups and the order they should occur in the file.- Parameters:
- packageGroups- a comma-separated list of package names/prefixes.
- Returns:
- array of compiled patterns.
- Throws:
- IllegalArgumentException- if any of the package groups are not valid.
 
 
-