Clone this repo:
  1. bd5f6ca PUBLIC: Add obsolete APIs from Apache's `IOUtils` to `JdkObsolete`. by Kurt Alfred Kluever · 16 hours ago master
  2. 19dddd8 PUBLIC: Flag obsolete `Scanner` constructors in `JdkObsolete`. by Kurt Alfred Kluever · 17 hours ago
  3. ab4e7bd Improve diagnostic message for unused parameters that are reassigned. by ghm · 19 hours ago
  4. 0aaf576 Clean up VariableNameSameAsType by Liam Miller-Cushon · 2 days ago
  5. 795015f PUBLIC: add `Formatter` and `Properties` APIs that use a `String` to represent a `Charset` to `JdkObsolete`. by Kurt Alfred Kluever · 5 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