Catch Simple Java Mistakes in Compile Time » Gofore
What is Error Prone
All Java developers should be familiar with the Java programming language compiler a.k.a javac. It reads class and interface definitions and produces bytecode class files. If syntax or static type checking has issues, a compilation error is raised. Error Prone does all this, but in addition to this it checks for common mistakes that could be present in the source code and forces them to be fixed at compile time. It does this without interfering a developer’s basic development cycle and without any significant performance impact (9.0% time overhead [3]).
How Does it Work?
Since the release of JSR 199 (Java Compiler API) it has been possible to compile Java inside a Java program. The different compilation phases are exposed in JavaCompiler class and Error Prone actually extends this class in order to insert hooks into the compilation pipeline. To be more specific, it adds custom error checking after the flow phase of the default compiler. It uses AST (Abstract Syntax Tree) related APIs such as TreeScanner to visit the AST nodes and with each node, it runs proper validation code depending on the node type.
Below is an example of a bug checker that ensures that the codebase does not contain a division by integer literal zero:
What Kind of Errors Are Actually Caught?
Instead of writing a sample code snippet myself, I think it is more interesting to see what Error Prone finds in real software projects. I picked Elasticsearch [4] as it is an active open source project with a large contributor pool. A cloned the project and replaced the compiler configuration to the following in the pom.xml in order to active Error Prone:
<plugin> | |
<groupId>org.apache.maven.plugins</groupId> | |
<artifactId>maven-compiler-plugin</artifactId> | |
<version>3.2</version> | |
<configuration> | |
<compilerId>javac-with-errorprone</compilerId> | |
<forceJavacCompilerUse>true</forceJavacCompilerUse> | |
<source>1.7</source> | |
<target>1.7</target> | |
</configuration> | |
<dependencies> | |
<dependency> | |
<groupId>com.google.errorprone</groupId> | |
<artifactId>error_prone_core</artifactId> | |
<version>1.1.2</version> | |
</dependency> | |
<dependency> | |
<groupId>org.codehaus.plexus</groupId> | |
<artifactId>plexus-compiler-javac</artifactId> | |
<version>2.3</version> | |
</dependency> | |
<dependency> | |
<groupId>org.codehaus.plexus</groupId> | |
<artifactId>plexus-compiler-javac-errorprone</artifactId> | |
<version>2.3</version> | |
</dependency> | |
</dependencies> | |
</plugin> |
Read full article from Catch Simple Java Mistakes in Compile Time » Gofore
No comments:
Post a Comment