Clone this repo:
  1. 6c7ce38 Detect conflicts between record components and explicit accessor methods by Liam Miller-Cushon · 90 minutes ago master
  2. f73eb27 Recognize when `join(Iterable)` calls `toString()` on arrays, etc. by cpovirk · 19 hours ago
  3. 734fe12 Include the `link` from `@RestrictedApi` in the diagnostic message. by Error Prone Team · 34 hours ago
  4. 13bec96 Create a JUnit3 -> JUnit4 migration tool. by Kurt Alfred Kluever · 2 days ago
  5. 1750134 Forbid "complex" statements in `AssertThrowsMultipleStatements`. by cpovirk · 2 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