Since Checkstyle 3.2
Checks the ordering/grouping of imports. Features are:
name | description | type | default value | since |
---|---|---|---|---|
caseSensitive | 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. | boolean | true |
3.3 |
groups | 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/ ). 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. |
Pattern[] | {} |
3.2 |
option | Specify policy on the relative order between type imports and static imports. | ImportOrderOption | under |
5.0 |
ordered | Control whether type imports within each group should be sorted. It doesn't affect sorting for static imports. | boolean | true |
3.2 |
separated | 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. | boolean | false |
3.2 |
separatedStaticGroups | 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 property option is set to top or bottom and when property staticGroups is enabled. |
boolean | false |
8.12 |
sortStaticImportsAlphabetically | Control whether static imports located at top or bottom are sorted within the group. | boolean | false |
6.5 |
staticGroups | 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/ ). 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 property option is set to top or bottom . |
Pattern[] | {} |
8.12 |
useContainerOrderingForStatic | Control whether to use container ordering (Eclipse IDE term) for static imports or not. | boolean | false |
7.1 |
To configure the check:
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"/> </module> </module>
Example:
import java.io.IOException; import java.net.URL; import java.io.IOException; // violation, extra separation before import // and wrong order, comes before 'java.net.URL'. import javax.net.ssl.TrustManager; // violation, extra separation due to above comment import javax.swing.JComponent; import org.apache.http.conn.ClientConnectionManager; // OK import java.util.Set; // violation, wrong order, 'java' should not come after 'org' imports import com.neurologic.http.HttpClient; // violation, wrong order, 'com' imports comes at top import com.neurologic.http.impl.ApacheHttpClient; // OK public class SomeClass { }
To configure the check so that it matches default Eclipse formatter configuration (tested on Kepler and Luna releases):
Notes:
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="groups" value="/^java\./,javax,org"/> <property name="ordered" value="true"/> <property name="separated" value="true"/> <property name="option" value="above"/> <property name="sortStaticImportsAlphabetically" value="true"/> </module> </module> </module>
Example:
import static java.lang.System.out; import static java.lang.Math; // violation, alphabetical case-sensitive ASCII order, 'M' < 'S' import java.io.IOException; import java.net.URL; // violation, extra separation before import import java.security.KeyManagementException; import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; // violation, groups should not be separated internally import org.apache.http.conn.ClientConnectionManager; public class SomeClass { }
To configure the check so that it matches default Eclipse formatter configuration (tested on Mars release):
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="groups" value="/^java\./,javax,org,com"/> <property name="ordered" value="true"/> <property name="separated" value="true"/> <property name="option" value="above"/> <property name="sortStaticImportsAlphabetically" value="true"/> </module> </module> </module>
Example:
import static java.io.File.createTempFile; import static java.lang.Math.abs; // OK, alphabetical case-sensitive ASCII order, 'i' < 'l' import java.lang.Math.sqrt; // OK, follows property 'Option' value 'above' import java.io.File; // violation, alphabetical case-sensitive ASCII order, 'i' < 'l' import java.io.IOException; // violation, extra separation in 'java' import group import org.albedo.*; import static javax.WindowConstants.*; // violation, wrong order, 'javax' comes before 'org' import javax.swing.JComponent; import org.apache.http.ClientConnectionManager; // violation, must separate from previous import import org.linux.apache.server.SoapServer; // OK import com.neurologic.http.HttpClient; // OK import com.neurologic.http.impl.ApacheHttpClient; // OK public class SomeClass { }
To configure the check so that it matches default IntelliJ IDEA formatter configuration (tested on v2018.2):
Note: a suppression xpath single filter is needed because IDEA has no blank line between "javax" and "java". ImportOrder has a limitation by design to enforce an empty line between groups ("java", "javax"). There is no flexibility to enforce empty lines between some groups and no empty lines between other groups.
Note: "separated" option is disabled because IDEA default has blank line between "java" and static imports, and no blank line between "javax" and "java".
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="groups" value="*,javax,java"/> <property name="ordered" value="true"/> <property name="separated" value="false"/> <property name="option" value="bottom"/> <property name="sortStaticImportsAlphabetically" value="true"/> </module> <module name="SuppressionXpathSingleFilter"> <property name="checks" value="ImportOrder"/> <property name="message" value="^'java\..*'.*"/> </module> </module> </module>
Example:
import com.neurologic.http.impl.ApacheHttpClient; // OK import static java.awt.Button.A; import javax.swing.JComponent; // violation, wrong order, caused by above static import // all static imports comes at bottom import java.net.URL; // violation, extra separation in import group import java.security.KeyManagementException; import javax.swing.JComponent; // violation, wrong order, 'javax' should be above 'java' imports import com.neurologic.http.HttpClient; // violation, wrong order, 'com' imports should be at top public class TestClass { }
To configure the check so that it matches default NetBeans formatter configuration (tested on v8):
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="option" value="inflow"/> </module> </module> </module>
Example:
import static java.io.File.createTempFile; import java.lang.Math.sqrt; import javax.swing.JComponent; // violation, extra separation in import group import static javax.windowConstants.*; // OK // all static imports are processed like non static imports. public class SomeClass { }
Group descriptions enclosed in slashes are interpreted as regular expressions. If multiple groups match, the one matching a longer substring of the imported name will take precedence, with ties broken first in favor of earlier matches and finally in favor of the first matching group.
There is always a wildcard group to which everything not in a named group
belongs. If an import does not match a named group, the group belongs to
this wildcard group. The wildcard group position can be specified using the
*
character.
Check also has on option making it more flexible: sortStaticImportsAlphabetically - sets whether static imports grouped by top or bottom option should be sorted alphabetically or not, default value is false. It is applied to static imports grouped with top or bottom options. This option is helping in reconciling of this Check and other tools like Eclipse's Organize Imports feature.
To configure the Check allows static imports grouped to the top being sorted alphabetically:
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="sortStaticImportsAlphabetically" value="true"/> <property name="option" value="top"/> </module> </module> </module>
Example:
import static java.lang.Math.PI; import static java.lang.Math.abs; // OK, alphabetical case-sensitive ASCII order, 'P' < 'a' import static org.abego.treelayout.Configuration.AlignmentInLevel; // OK, alphabetical order import java.util.Set; // violation, extra separation in import group import static java.lang.Math.abs; // violation, wrong order, all static imports comes at 'top' import org.abego.*; public class SomeClass { }
To configure the Check with groups of static imports:
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="staticGroups" value="org,java"/> <property name="sortStaticImportsAlphabetically" value="true"/> <property name="option" value="top"/> </module> </module> </module>
Example:
import static org.abego.treelayout.Configuration.AlignmentInLevel; // Group 1 import static java.lang.Math.abs; // Group 2 import static java.lang.String.format; // Group 2 import static com.google.common.primitives.Doubles.BYTES; // Group "everything else" public class SomeClass { }
The following example shows the idea of 'useContainerOrderingForStatic' option that is useful for Eclipse IDE users to match ordering validation. This is how the import comparison works for static imports: we first compare the container of the static import, container is the type enclosing the static element being imported. When the result of the comparison is 0 (containers are equal), we compare the fully qualified import names.
For e.g. this is what is considered to be container names for the given example:
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 should come after HttpHeaders.
Example for useContainerOrderingForStatic=true
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="useContainerOrderingForStatic" value="true"/> <property name="ordered" value="true"/> <property name="option" value="top"/> <property name="caseSensitive" value="false"/> <property name="sortStaticImportsAlphabetically" value="true"/> </module> </module> </module>
Example:
import static io.netty.handler.codec.http.HttpConstants.COLON; import static io.netty.handler.codec.http.HttpHeaders.addHeader; import static io.netty.handler.codec.http.HttpHeaders.setHeader; import static io.netty.handler.codec.http.HttpHeaders.Names.DATE; public class InputEclipseStaticImportsOrder { }
Example for useContainerOrderingForStatic=false
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="useContainerOrderingForStatic" value="false"/> <property name="ordered" value="true"/> <property name="option" value="top"/> <property name="caseSensitive" value="false"/> <property name="sortStaticImportsAlphabetically" value="true"/> </module> </module> </module>
Example:
import static io.netty.handler.codec.http.HttpConstants.COLON; import static io.netty.handler.codec.http.HttpHeaders.addHeader; import static io.netty.handler.codec.http.HttpHeaders.setHeader; import static io.netty.handler.codec.http.HttpHeaders.Names.DATE; // violation public class InputEclipseStaticImportsOrder { }
To configure the check to enforce static import group separation
Example for separatedStaticGroups=true
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="staticGroups" value="*,java,javax,org"/> <property name="option" value="top"/> <property name="separatedStaticGroups" value="true"/> </module> </module> </module>
Example:
import static java.lang.Math.PI; import static java.io.File.createTempFile; import static javax.swing.JComponent; // violation, should be separated from previous imports import static javax.WindowConstants.*; // OK import java.net.URL; public class SomeClass { }
To configure the Check with groups of static imports when staticGroups="" represents all imports as {@code everything else} group:
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="staticGroups" value=""/> <property name="option" value="top"/> </module> </module> </module>
Example:
import static java.io.File.listRoots; // OK import static javax.swing.WindowConstants.*; // OK import static java.io.File.createTempFile; // OK import static com.puppycrawl.tools.checkstyle; // OK public class SomeClass { }
To configure the Check with groups of static imports when
staticGroups="java, javax" represents three groups i.e java*, javax*
and * (everything else). In below example the static imports com...
should be in last group:
<module name="Checker"> <module name="TreeWalker"> <module name="ImportOrder"> <property name="staticGroups" value="java, javax"/> <property name="option" value="top"/> </module> </module> </module>
Example:
import static java.io.File.listRoots; // OK import static javax.swing.WindowConstants.*; // OK import static java.io.File.createTempFile; // violation should be before javax import static com.puppycrawl.tools.checkstyle; // OK public class SomeClass { }
All messages can be customized if the default message doesn't suit you. Please see the documentation to learn how to.
com.puppycrawl.tools.checkstyle.checks.imports