diff --git a/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/ExhaustiveRefasterTypeMigration.java b/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/ExhaustiveRefasterTypeMigration.java index a7a7c90d85..18c512ed0a 100644 --- a/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/ExhaustiveRefasterTypeMigration.java +++ b/error-prone-contrib/src/main/java/tech/picnic/errorprone/bugpatterns/ExhaustiveRefasterTypeMigration.java @@ -44,6 +44,7 @@ import java.util.HashSet; import java.util.Map; import java.util.Set; +import java.util.function.Consumer; import javax.lang.model.element.AnnotationMirror; import javax.lang.model.element.AnnotationValue; import javax.lang.model.element.Modifier; @@ -71,7 +72,8 @@ @AutoService(BugChecker.class) @BugPattern( summary = - "The set of unmigrated methods listed by the `@TypeMigration` annotation must be minimal yet exhaustive", + "The set of unmigrated methods listed by the `@TypeMigration` annotation must be minimal " + + "yet exhaustive", link = BUG_PATTERNS_BASE_URL + "ExhaustiveRefasterTypeMigration", linkType = CUSTOM, severity = WARNING, @@ -201,30 +203,26 @@ private static Comparator signatureOrder(ImmutableList existingO */ private static void removeMethodsInvokedInBeforeTemplateMethods( ClassTree tree, Set candidates, VisitorState state) { - new TreeScanner<@Nullable Void, Boolean>() { + new TreeScanner<@Nullable Void, Consumer>() { @Override - public @Nullable Void visitMethod(MethodTree tree, Boolean inBeforeTemplate) { - return HAS_BEFORE_TEMPLATE.matches(tree, state) ? super.visitMethod(tree, true) : null; + public @Nullable Void visitMethod(MethodTree tree, Consumer sink) { + return HAS_BEFORE_TEMPLATE.matches(tree, state) + ? super.visitMethod(tree, candidates::remove) + : null; } @Override - public @Nullable Void visitNewClass(NewClassTree tree, Boolean inBeforeTemplate) { - if (inBeforeTemplate) { - candidates.remove(ASTHelpers.getSymbol(tree)); - } - - return super.visitNewClass(tree, inBeforeTemplate); + public @Nullable Void visitNewClass(NewClassTree tree, Consumer sink) { + sink.accept(ASTHelpers.getSymbol(tree)); + return super.visitNewClass(tree, sink); } @Override public @Nullable Void visitMethodInvocation( - MethodInvocationTree tree, Boolean inBeforeTemplate) { - if (inBeforeTemplate) { - candidates.remove(ASTHelpers.getSymbol(tree)); - } - - return super.visitMethodInvocation(tree, inBeforeTemplate); + MethodInvocationTree tree, Consumer sink) { + sink.accept(ASTHelpers.getSymbol(tree)); + return super.visitMethodInvocation(tree, sink); } - }.scan(tree, false); + }.scan(tree, s -> {}); } }