Source Code Checking with PMD
PMD is a Java source code checker which reads the Java source code
in your project looking for patterns that indicate errors or suboptimal
practices. Because it reads the source code, it can find stylistic
omissions that other tools like FindBugs cannot, such as leaving off
parenthesis around the body of an if
statement:
if (a < 0) System.err.printf("Value of 'a' is %d but may not be negative%n", a);
There is nothing functionally wrong with this code, but it's bad
style. Sun's Java Coding Style document (http://java.sun.com/docs/codeconv) says to always use curly
braces around the body of an if
statement or a loop. And sure enough, somebody is going to come along and,
under time pressure, insert an additional debugging printout betwixt the
if
and the printf
, assuming from their indentation that the
new statement and the printf
will both
be controlled by the if
. Java isn't
Python, so that doesn't work, and the program will fail, printing the
diagnostic even when the datum being tested is valid. But if you use PMD,
you'll know it's a problem long before it gets into production.
The PMD project offers a very large set of rules, and we'll only cover a few of them here. The project maintains a complete list (http://pmd.sourceforge.net/rules/index.html) of almost 220 rules in almost 30 categories; a copy is also included in the documentation that ships with PMD. Each rule has a name, a short description that shows up by default, and a longer explanation that ...
Get Checking Java Programs now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.