Clone this repo:
  1. 00d4c36 Recognize nested `{@code ...}` tags as valid. by cpovirk · 3 hours ago master
  2. 831da36 Fixes #5553 : Skip UnnecessaryOptionalGet when lambda parameter is unnamed by Mirko Alicastro · 6 hours ago
  3. 7c4b040 Retain explicit types on LambdaExpressionTrees that are not assignments. by Kurt Alfred Kluever · 3 days ago
  4. 47bb523 Provide a better error message for empty test inputs by Liam Miller-Cushon · 3 days ago
  5. 570ac28 Discourage references to private member classes from non-private APIs by Liam Miller-Cushon · 3 days ago

Error Prone

Error Prone is a static analysis tool for Java that catches common programming mistakes at compile-time.

public class ShortSet {
  public static void main (String[] args) {
    Set<Short> s = new HashSet<>();
    for (short i = 0; i < 100; i++) {
      s.add(i);
      s.remove(i - 1);
    }
    System.out.println(s.size());
  }
}
error: [CollectionIncompatibleType] Argument 'i - 1' should not be passed to this method;
its type int is not compatible with its collection's type argument Short
      s.remove(i - 1);
              ^
    (see https://errorprone.info/bugpattern/CollectionIncompatibleType)
1 error

Getting Started

Our documentation is at errorprone.info.

Error Prone works with Bazel, Maven, Ant, and Gradle. See our installation instructions for details.

Developing Error Prone

Developing and building Error Prone is documented on the wiki.

Links