Skip to content

Commit

Permalink
Make ASTHelpers.getSymbol(MethodInvocationTree) and friends throw i…
Browse files Browse the repository at this point in the history
…nstead of return `null`.

Fixes #2882

PiperOrigin-RevId: 423780239
  • Loading branch information
cpovirk authored and Error Prone Team committed Jan 25, 2022
1 parent 4698c8e commit 142f625
Showing 1 changed file with 11 additions and 3 deletions.
14 changes: 11 additions & 3 deletions check_api/src/main/java/com/google/errorprone/util/ASTHelpers.java
Original file line number Diff line number Diff line change
Expand Up @@ -300,7 +300,11 @@ public static MethodSymbol getSymbol(MethodTree tree) {
@Nullable
public static MethodSymbol getSymbol(NewClassTree tree) {
Symbol sym = ((JCNewClass) tree).constructor;
return sym instanceof MethodSymbol ? (MethodSymbol) sym : null;
if (!(sym instanceof MethodSymbol)) {
// Defensive. Would only occur if there are errors in the AST.
throw new IllegalArgumentException(tree.toString());
}
return (MethodSymbol) sym;
}

/** Gets the symbol for a variable. */
Expand All @@ -314,7 +318,7 @@ public static MethodSymbol getSymbol(MethodInvocationTree tree) {
Symbol sym = ASTHelpers.getSymbol(tree.getMethodSelect());
if (!(sym instanceof MethodSymbol)) {
// Defensive. Would only occur if there are errors in the AST.
return null;
throw new IllegalArgumentException(tree.toString());
}
return (MethodSymbol) sym;
}
Expand All @@ -323,7 +327,11 @@ public static MethodSymbol getSymbol(MethodInvocationTree tree) {
@Nullable
public static MethodSymbol getSymbol(MemberReferenceTree tree) {
Symbol sym = ((JCMemberReference) tree).sym;
return sym instanceof MethodSymbol ? (MethodSymbol) sym : null;
if (!(sym instanceof MethodSymbol)) {
// Defensive. Would only occur if there are errors in the AST.
throw new IllegalArgumentException(tree.toString());
}
return (MethodSymbol) sym;
}

/* Checks whether an expression requires parentheses. */
Expand Down

0 comments on commit 142f625

Please sign in to comment.