Jump to content

Checkstyle

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by 217.154.243.205 (talk) at 18:02, 3 February 2010 (→‎Advantages and limits). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

Checkstyle is a static code analysis tool used in software development for checking if a Java source code complies with coding rules.

Advantages and limits

The programming style adopted by a software development project can help to comply with good programming practices which improve the code quality, readability, re-usability, and reduce the cost of development. The performed checks mainly limit themselves to the presentation and don't analyze content, and do not confirm the correctness or completeness of the program. In practice, it can be fastidious to comply with all the style constraints, some of which could possibly harm the programming stages' dynamic; so, it may be useful to determine which level of check is needed for a certain type of program.

Examples of available modules

Checkstyle defines a set of available modules, each of which provides rules checking with a configurable level of strictness (mandatory, optional...). Each rule can raise notifications, warnings, and errors.

It permits to check for instance:

  • Javadoc comments for classes, attributes and methods;
  • Naming conventions of attributes and methods;
  • Limit of the number of function parameters, line lengths;
  • Presence of mandatory headers;
  • The use of packets imports, of classes, of scope modifiers and of instructions blocks;
  • The spaces between some characters;
  • The good practices of class construction;
  • The duplicated code sections;
  • Multiple complexity measurements, among which expressions.

Usage

Checkstyle is built in a JAR file which can run inside a Java VM or as an Apache Ant task. It can also integrate into an IDE or other tools.

A Checkstyle plug-in can provide new functionnalities, like:

  • overload syntax coloring or decorations in code editor;
  • decorate the project explorer to highlight problem-posing resources;
  • add warnings and errors outputs to the outputs.

Thus, the developer can directly access to the code parts highlighted by Checkstyle.

History

Checkstyle, originally developed by Oliver Burn back in 2001, is maintained by a team of several developers around the world.

The current stable release is 5.0 which is targeted towards the Java 5 language.