The purpose of this repository is to provide resources for maintaining consistent coding style. The resources in this repository are available for use by DuraSpace projects as well as any other individuals or projects interested in maintaining a coding style consistent with well established open source projects.
Checkstyle | Code Style Guide | IDE Support | License
Checkstyle is a development tool for Java, used to ensure that code standards are applied consistently.
Checkstyle can be enabled in Java projects with Maven using the Maven Checkstyle Plugin. Add the following into the section of your Maven POM.xml file:
<!-- Used to validate all code style rules in source code using Checkstyle -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-checkstyle-plugin</artifactId>
<version>3.0.0</version>
<executions>
<execution>
<id>verify-style</id>
<!-- Bind to verify so it runs after package & unit tests, but before install -->
<phase>verify</phase>
<goals>
<goal>check</goal>
</goals>
</execution>
</executions>
<configuration>
<configLocation>duraspace-checkstyle/checkstyle.xml</configLocation>
<suppressionsLocation>duraspace-checkstyle/checkstyle-suppressions.xml</suppressionsLocation>
<encoding>UTF-8</encoding>
<consoleOutput>true</consoleOutput>
<logViolationsToConsole>true</logViolationsToConsole>
<failOnViolation>true</failOnViolation>
<includeTestSourceDirectory>true</includeTestSourceDirectory>
</configuration>
<dependencies>
<dependency>
<groupId>org.duraspace</groupId>
<artifactId>codestyle</artifactId>
<version>${duraspace-codestyle.version}</version>
</dependency>
<!-- Override dependencies to use latest version of checkstyle -->
<dependency>
<groupId>com.puppycrawl.tools</groupId>
<artifactId>checkstyle</artifactId>
<version>8.18</version>
</dependency>
</dependencies>
</plugin>
Once this configuration is in place, executing a build on the project (mvn clean install
) will trigger checkstyle checks which will cause the build to fail if a style violation is encountered.
The following code guidelines are enforced by the checkstyle rules:
- 4-space indents for Java, and 2-space indents for XML. NO TABS ALLOWED.
- K&R style braces required. Braces are required on all blocks, e.g.
if (code) { // code } else { // code }
- Maximum length of lines is 120 characters (except for long URLs, packages or imports)
- No trailing spaces allowed
- Do not use wildcard imports (e.g.
import java.util.*
). Duplicated or unused imports are not allowed. - Write Javadocs for public methods and classes. Keep it short and to the point.
- Javadoc
@author
tags are optional, but should refer to an individual's name or handle (e.g. GitHub username) when included
- Javadoc
- Tokens should be surrounded by whitespace (details here)
- Each line of code can only include one statement. This also means each variable declaration must be on its own line, e.g.
// This is NOT valid. Three variables are declared on one line String first = "", second = "", third = ""; // This is valid. Each statement is on its own line String first = ""; String second = ""; String third = "";
- No empty "catch" blocks in try/catch. A "catch" block must minimally include a comment as to why the catch is empty, e.g.
try { // some code .. } catch (Exception e) { // ignore, this exception is not important }
- All "switch" statements must include a "default" clause. Also, each clause in a switch must include a "break", "return", "throw", "continue", or a
// fall through
comment// This is NOT valid. Switch doesn't include a "default" and is missing a "break" in first "case" switch (myVal) { case "one": // do something case "two": // do something else break; } // This is valid. Switch has all necessary breaks and includes a "default" clause switch (myVal) { case "one": // do something break; case "two": // do something else break; case "three": // do another thing // fall through default: // do nothing break; }
- Any "utility" classes (a utility class is one that just includes static methods or variables) should have non-public (i.e. private or protected) constructors, e.g.
// This is an example class of static constants public class Constants { public static final String DEFAULT_ENCODING = "UTF-8"; public static final String ANOTHER_CONSTANT = "Some value"; // As this is a utility class, it MUST have a constructor that is non-public. private Constants() { } }
- Import statements must be ordered alphabetically and grouped by matching packages. The groupings must be in the order:
- Static imports
- Standard java packages (java.* and javax.*)
- Third party packages
- No more than one consecutive blank line
- A blank line must follow each major code section (imports, class definitions, interface definitions, enum definitions, static initialization blocks, method definitions, constructor definitions)
Most major IDEs include plugins that support Checkstyle configurations. The plugin usually lets you import an existing checkstyle.xml configuration to configure your IDE to use and/or validate against that style.
Select an IDE from the list for more details on how to configure your IDE to use Checkstyle:
All resources in this repository are made available under the Apache 2 license.