Clone this repo:
  1. bc9618a [IfChainToSwitch] when safe mode is enabled, don't reorder cases because this can change program semantics. Update docs accordingly. by markbrady · 20 hours ago master
  2. 6cbafd3 Remove the `TypeCompatibility:UseCapture` flag. by ghm · 20 hours ago
  3. 2b5284f [IfChainToSwitch] Add new flag for safe mode, and emit null-handling logic when it is enabled by markbrady · 21 hours ago
  4. 7d8cdfe Prepare for javac API changes to AST end positions by Liam Miller-Cushon · 27 hours ago
  5. bd5f6ca PUBLIC: Add obsolete APIs from Apache's `IOUtils` to `JdkObsolete`. by Kurt Alfred Kluever · 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