From f3ba568fc59337b52cb5f3f1b6fb1fc734264929 Mon Sep 17 00:00:00 2001 From: Roman Salvador Date: Fri, 17 May 2024 10:04:23 -0700 Subject: [PATCH] Make patching API public MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit to be used by bazel’s error prone plugin: https://github.com/bazelbuild/bazel/pull/21640 Fixes #4318 FUTURE_COPYBARA_INTEGRATE_REVIEW=https://github.com/google/error-prone/pull/4318 from rsalvador:make-patching-api-public 905d6260b2870df5ba2b5e15ce3651a63bfa2dfd PiperOrigin-RevId: 634811351 --- .../BaseErrorProneJavaCompiler.java | 82 +------------------ .../google/errorprone/ErrorProneAnalyzer.java | 72 ++++++++++++++++ .../errorprone/RefactoringCollection.java | 2 +- 3 files changed, 77 insertions(+), 79 deletions(-) diff --git a/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java b/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java index 1747559e0b0..e39065b0420 100644 --- a/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java +++ b/check_api/src/main/java/com/google/errorprone/BaseErrorProneJavaCompiler.java @@ -19,24 +19,15 @@ import static com.google.common.base.StandardSystemProperty.JAVA_SPECIFICATION_VERSION; import com.google.common.collect.ImmutableList; -import com.google.common.collect.ImmutableSet; -import com.google.errorprone.RefactoringCollection.RefactoringResult; -import com.google.errorprone.scanner.ErrorProneScannerTransformer; import com.google.errorprone.scanner.ScannerSupplier; import com.sun.source.util.JavacTask; -import com.sun.source.util.TaskEvent; -import com.sun.source.util.TaskEvent.Kind; -import com.sun.source.util.TaskListener; import com.sun.tools.javac.api.BasicJavacTask; import com.sun.tools.javac.api.JavacTool; import com.sun.tools.javac.util.Context; import com.sun.tools.javac.util.JavacMessages; -import com.sun.tools.javac.util.Log; -import com.sun.tools.javac.util.Log.WriterKind; import com.sun.tools.javac.util.Options; import java.io.InputStream; import java.io.OutputStream; -import java.io.PrintWriter; import java.io.Writer; import java.nio.charset.Charset; import java.util.EnumSet; @@ -94,9 +85,11 @@ static void addTaskListener( setupMessageBundle(context); RefactoringCollection[] refactoringCollection = {null}; javacTask.addTaskListener( - createAnalyzer(scannerSupplier, errorProneOptions, context, refactoringCollection)); + ErrorProneAnalyzer.createAnalyzer( + scannerSupplier, errorProneOptions, context, refactoringCollection)); if (refactoringCollection[0] != null) { - javacTask.addTaskListener(new RefactoringTask(context, refactoringCollection[0])); + javacTask.addTaskListener( + new ErrorProneAnalyzer.RefactoringTask(context, refactoringCollection[0])); } } @@ -206,71 +199,4 @@ public static void setupMessageBundle(Context context) { ResourceBundle bundle = ResourceBundle.getBundle("com.google.errorprone.errors"); JavacMessages.instance(context).add(l -> bundle); } - - static ErrorProneAnalyzer createAnalyzer( - ScannerSupplier scannerSupplier, - ErrorProneOptions epOptions, - Context context, - RefactoringCollection[] refactoringCollection) { - if (!epOptions.patchingOptions().doRefactor()) { - return ErrorProneAnalyzer.createByScanningForPlugins(scannerSupplier, epOptions, context); - } - refactoringCollection[0] = RefactoringCollection.refactor(epOptions.patchingOptions(), context); - - // Refaster refactorer or using builtin checks - CodeTransformer codeTransformer = - epOptions - .patchingOptions() - .customRefactorer() - .or( - () -> { - ScannerSupplier toUse = ErrorPronePlugins.loadPlugins(scannerSupplier, context); - ImmutableSet namedCheckers = epOptions.patchingOptions().namedCheckers(); - if (!namedCheckers.isEmpty()) { - toUse = toUse.filter(bci -> namedCheckers.contains(bci.canonicalName())); - } else { - toUse = toUse.applyOverrides(epOptions); - } - return ErrorProneScannerTransformer.create(toUse.get()); - }) - .get(); - - return ErrorProneAnalyzer.createWithCustomDescriptionListener( - codeTransformer, epOptions, context, refactoringCollection[0]); - } - - static class RefactoringTask implements TaskListener { - - private final Context context; - private final RefactoringCollection refactoringCollection; - - public RefactoringTask(Context context, RefactoringCollection refactoringCollection) { - this.context = context; - this.refactoringCollection = refactoringCollection; - } - - @Override - public void started(TaskEvent event) {} - - @Override - public void finished(TaskEvent event) { - if (event.getKind() != Kind.GENERATE) { - return; - } - RefactoringResult refactoringResult; - try { - refactoringResult = refactoringCollection.applyChanges(event.getSourceFile().toUri()); - } catch (Exception e) { - PrintWriter out = Log.instance(context).getWriter(WriterKind.ERROR); - out.println(e.getMessage()); - out.flush(); - return; - } - if (refactoringResult.type() == RefactoringCollection.RefactoringResultType.CHANGED) { - PrintWriter out = Log.instance(context).getWriter(WriterKind.NOTICE); - out.println(refactoringResult.message()); - out.flush(); - } - } - } } diff --git a/check_api/src/main/java/com/google/errorprone/ErrorProneAnalyzer.java b/check_api/src/main/java/com/google/errorprone/ErrorProneAnalyzer.java index cddb1bec4c4..c59458442d0 100644 --- a/check_api/src/main/java/com/google/errorprone/ErrorProneAnalyzer.java +++ b/check_api/src/main/java/com/google/errorprone/ErrorProneAnalyzer.java @@ -22,7 +22,9 @@ import com.google.common.base.Supplier; import com.google.common.base.Suppliers; +import com.google.common.collect.ImmutableSet; import com.google.errorprone.BugPattern.SeverityLevel; +import com.google.errorprone.RefactoringCollection.RefactoringResult; import com.google.errorprone.scanner.ErrorProneScannerTransformer; import com.google.errorprone.scanner.ScannerSupplier; import com.google.errorprone.util.ASTHelpers; @@ -39,7 +41,9 @@ import com.sun.tools.javac.tree.JCTree.JCCompilationUnit; import com.sun.tools.javac.util.Context; import com.sun.tools.javac.util.Log; +import com.sun.tools.javac.util.Log.WriterKind; import com.sun.tools.javac.util.PropagatedException; +import java.io.PrintWriter; import java.util.HashSet; import java.util.Set; import java.util.regex.Pattern; @@ -57,6 +61,74 @@ public class ErrorProneAnalyzer implements TaskListener { private final Context context; private final DescriptionListener.Factory descriptionListenerFactory; + public static ErrorProneAnalyzer createAnalyzer( + ScannerSupplier scannerSupplier, + ErrorProneOptions epOptions, + Context context, + RefactoringCollection[] refactoringCollection) { + if (!epOptions.patchingOptions().doRefactor()) { + return createByScanningForPlugins(scannerSupplier, epOptions, context); + } + refactoringCollection[0] = RefactoringCollection.refactor(epOptions.patchingOptions(), context); + + // Refaster refactorer or using builtin checks + CodeTransformer codeTransformer = + epOptions + .patchingOptions() + .customRefactorer() + .or( + () -> { + ScannerSupplier toUse = ErrorPronePlugins.loadPlugins(scannerSupplier, context); + ImmutableSet namedCheckers = epOptions.patchingOptions().namedCheckers(); + if (!namedCheckers.isEmpty()) { + toUse = toUse.filter(bci -> namedCheckers.contains(bci.canonicalName())); + } else { + toUse = toUse.applyOverrides(epOptions); + } + return ErrorProneScannerTransformer.create(toUse.get()); + }) + .get(); + + return createWithCustomDescriptionListener( + codeTransformer, epOptions, context, refactoringCollection[0]); + } + + /** A {@link TaskListener} that performs refactorings. */ + public static class RefactoringTask implements TaskListener { + + private final Context context; + private final RefactoringCollection refactoringCollection; + + public RefactoringTask(Context context, RefactoringCollection refactoringCollection) { + this.context = context; + this.refactoringCollection = refactoringCollection; + } + + @Override + public void started(TaskEvent event) {} + + @Override + public void finished(TaskEvent event) { + if (event.getKind() != Kind.GENERATE) { + return; + } + RefactoringResult refactoringResult; + try { + refactoringResult = refactoringCollection.applyChanges(event.getSourceFile().toUri()); + } catch (Exception e) { + PrintWriter out = Log.instance(context).getWriter(WriterKind.ERROR); + out.println(e.getMessage()); + out.flush(); + return; + } + if (refactoringResult.type() == RefactoringCollection.RefactoringResultType.CHANGED) { + PrintWriter out = Log.instance(context).getWriter(WriterKind.NOTICE); + out.println(refactoringResult.message()); + out.flush(); + } + } + } + public static ErrorProneAnalyzer createByScanningForPlugins( ScannerSupplier scannerSupplier, ErrorProneOptions errorProneOptions, Context context) { return new ErrorProneAnalyzer( diff --git a/check_api/src/main/java/com/google/errorprone/RefactoringCollection.java b/check_api/src/main/java/com/google/errorprone/RefactoringCollection.java index ced2a69e834..ddec3fa26b0 100644 --- a/check_api/src/main/java/com/google/errorprone/RefactoringCollection.java +++ b/check_api/src/main/java/com/google/errorprone/RefactoringCollection.java @@ -50,7 +50,7 @@ import java.util.logging.Logger; /** A container of fixes that have been collected during a single compilation phase. */ -class RefactoringCollection implements DescriptionListener.Factory { +public class RefactoringCollection implements DescriptionListener.Factory { private static final Logger logger = Logger.getLogger(RefactoringCollection.class.getName());