From 70b5277fba58001922c35b0bcdd07de7b8e25d3c Mon Sep 17 00:00:00 2001 From: Anton Sviridov Date: Fri, 30 Jun 2023 10:33:36 +0100 Subject: [PATCH 1/5] Special handling of Bazel with source generators - Handle path with filename separated by : - Detect javac' source generation root - Not include semanticdb files for auto-generated files --- .../SemanticdbJavacOptions.java | 28 ++++++--- .../semanticdb_javac/SemanticdbReporter.java | 63 ++++++++++++------- .../SemanticdbTaskListener.java | 41 ++++++++---- .../semanticdb_javac/TargetPaths.java | 13 ++++ 4 files changed, 99 insertions(+), 46 deletions(-) create mode 100644 semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/TargetPaths.java diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java index bea1f043..7c001d6a 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java @@ -12,6 +12,7 @@ import com.sun.tools.javac.util.Context; import static javax.tools.StandardLocation.CLASS_OUTPUT; +import static javax.tools.StandardLocation.SOURCE_OUTPUT; /** Settings that can be configured alongside the -Xplugin compiler option. */ public class SemanticdbJavacOptions { @@ -25,6 +26,7 @@ public class SemanticdbJavacOptions { public final ArrayList errors; public boolean alreadyReportedErrors = false; public UriScheme uriScheme = UriScheme.DEFAULT; + public Path generatedTargetRoot; public static String stubClassName = "META-INF-semanticdb-stub"; @@ -49,7 +51,7 @@ public static SemanticdbJavacOptions parse(String[] args, Context ctx) { String argValue = arg.substring("-targetroot:".length()); if (argValue.equals(JAVAC_CLASSES_DIR_ARG)) { useJavacClassesDir = true; - result.targetroot = getJavacClassesDir(result, ctx); + result.targetroot = getJavacClassesDir(result, ctx).classes; } else { result.targetroot = Paths.get(argValue); } @@ -60,7 +62,9 @@ public static SemanticdbJavacOptions parse(String[] args, Context ctx) { } else if (arg.equals("-build-tool:bazel")) { result.uriScheme = UriScheme.BAZEL; useJavacClassesDir = true; - result.targetroot = getJavacClassesDir(result, ctx); + TargetPaths paths = getJavacClassesDir(result, ctx); + result.targetroot = paths.classes; + result.generatedTargetRoot = paths.sources; } else if (arg.equals("-text:on")) { result.includeText = true; } else if (arg.equals("-text:off")) { @@ -79,9 +83,11 @@ public static SemanticdbJavacOptions parse(String[] args, Context ctx) { result.errors.add(missingRequiredDirectoryOption("targetroot")); } if (!isSourcerootDefined(result)) { - // When using -build-tool:bazel, the sourceroot is automatically inferred from the first + // When using -build-tool:bazel, the sourceroot is automatically inferred from + // the first // compilation unit. - // See `SemanticdbTaskListener.inferBazelSourceroot()` for the method that infers the + // See `SemanticdbTaskListener.inferBazelSourceroot()` for the method that + // infers the // sourceroot. result.errors.add(missingRequiredDirectoryOption("sourceroot")); } @@ -95,14 +101,18 @@ private static boolean isSourcerootDefined(SemanticdbJavacOptions options) { return options.sourceroot != null; } - private static Path getJavacClassesDir(SemanticdbJavacOptions result, Context ctx) { + private static TargetPaths getJavacClassesDir(SemanticdbJavacOptions result, Context ctx) { // I'm not aware of a better way to get the class output directory from javac - Path outputDir = null; + Path classOutputDir = null; + Path sourceOutputDir = null; try { JavaFileManager fm = ctx.get(JavaFileManager.class); - FileObject outputDirStub = + FileObject sourceOutputDirStub = + fm.getJavaFileForOutput(SOURCE_OUTPUT, stubClassName, JavaFileObject.Kind.SOURCE, null); + FileObject clasSOutputDirStub = fm.getJavaFileForOutput(CLASS_OUTPUT, stubClassName, JavaFileObject.Kind.CLASS, null); - outputDir = Paths.get(outputDirStub.toUri()).toAbsolutePath().getParent(); + classOutputDir = Paths.get(clasSOutputDirStub.toUri()).toAbsolutePath().getParent(); + sourceOutputDir = Paths.get(sourceOutputDirStub.toUri()).toAbsolutePath().getParent(); } catch (Exception e) { ByteArrayOutputStream out = new ByteArrayOutputStream(); e.printStackTrace(new PrintStream(out)); @@ -112,6 +122,6 @@ private static Path getJavacClassesDir(SemanticdbJavacOptions result, Context ct JAVAC_CLASSES_DIR_ARG, out.toString()); result.errors.add(errorMsg); } - return outputDir; + return new TargetPaths(classOutputDir, sourceOutputDir); } } diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java index 3ca71fdb..ce2af880 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java @@ -3,6 +3,7 @@ import com.sun.source.tree.CompilationUnitTree; import com.sun.source.tree.Tree; import com.sun.source.util.Trees; +import com.sun.source.util.TaskEvent; import javax.tools.Diagnostic; import java.io.ByteArrayOutputStream; @@ -11,30 +12,44 @@ /** * Utilities to report error messages. * - *

NOTE(olafur): this class exists because I couldn't find compiler APIs to report diagnostics. - * This class can be removed if the Java compiler has APIs to report info/warning/error messages. + *

+ * NOTE(olafur): this class exists because I couldn't find compiler APIs to + * report diagnostics. This class can be removed if the Java compiler has APIs + * to report info/warning/error messages. */ public class SemanticdbReporter { - private final Trees trees; - - public SemanticdbReporter(Trees trees) { - this.trees = trees; - } - - public void exception(Throwable e, Tree tree, CompilationUnitTree root) { - ByteArrayOutputStream baos = new ByteArrayOutputStream(); - PrintWriter writer = new PrintWriter(baos); - e.printStackTrace(writer); - writer.println( - "Please report a bug to https://github.com/sourcegraph/semanticdb-java with the stack trace above."); - trees.printMessage(Diagnostic.Kind.ERROR, baos.toString(), tree, root); - } - - public void error(String message, Tree tree, CompilationUnitTree root) { - // NOTE(olafur): ideally, this message should be reported as a compiler diagnostic, but I dind't - // find - // the reporter API so the message goes to stderr instead for now. - trees.printMessage( - Diagnostic.Kind.ERROR, String.format("semanticdb-javac: %s", message), tree, root); - } + private final Trees trees; + + public SemanticdbReporter(Trees trees) { + this.trees = trees; + } + + public void exception(Throwable e, Tree tree, CompilationUnitTree root) { + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + PrintWriter writer = new PrintWriter(baos); + e.printStackTrace(writer); + writer.println( + "Please report a bug to https://github.com/sourcegraph/semanticdb-java with the stack trace above."); + trees.printMessage(Diagnostic.Kind.ERROR, baos.toString(), tree, root); + } + + private void info(String message, TaskEvent e) { + trees.printMessage(Diagnostic.Kind.NOTE, "semanticdb-javac: " + message, e.getCompilationUnit(), + e.getCompilationUnit()); + } + + public void error(String message, TaskEvent e) { + trees.printMessage(Diagnostic.Kind.ERROR, "semanticdb-javac: " + message, e.getCompilationUnit(), + e.getCompilationUnit()); + } + + } + + public void error(String message, Tree tree, CompilationUnitTree root) { + // NOTE(olafur): ideally, this message should be reported as a compiler + // diagnostic, but I dind't + // find + // the reporter API so the message goes to stderr instead for now. + trees.printMessage(Diagnostic.Kind.ERROR, String.format("semanticdb-javac: %s", message), tree, root); + } } diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java index 96e64590..7ff1d130 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java @@ -50,11 +50,7 @@ public void finished(TaskEvent e) { if (!options.alreadyReportedErrors) { options.alreadyReportedErrors = true; for (String error : options.errors) { - trees.printMessage( - Diagnostic.Kind.ERROR, - "semanticdb-javac: " + error, - e.getCompilationUnit(), - e.getCompilationUnit()); + reporter.error(error, e); } } return; @@ -79,13 +75,15 @@ public void finished(TaskEvent e) { private void onFinishedAnalyze(TaskEvent e) { Result path = semanticdbOutputPath(options, e); - if (path.isOk()) { - Semanticdb.TextDocument textDocument = - new SemanticdbVisitor(task, globals, e, options, javacTypes) - .buildTextDocument(e.getCompilationUnit()); - writeSemanticdb(e, path.getOrThrow(), textDocument); - } else { - reporter.error(path.getErrorOrThrow(), e.getCompilationUnit(), e.getCompilationUnit()); + if (path != null) { + if (path.isOk()) { + Semanticdb.TextDocument textDocument = + new SemanticdbVisitor(task, globals, e, options, javacTypes) + .buildTextDocument(e.getCompilationUnit()); + writeSemanticdb(e, path.getOrThrow(), textDocument); + } else { + reporter.error(path.getErrorOrThrow(), e) + } } } @@ -112,12 +110,12 @@ public static Path absolutePathFromUri(SemanticdbJavacOptions options, JavaFileO throw new IllegalArgumentException("unsupported URI: " + uri); } } else if (options.uriScheme == UriScheme.BAZEL) { - String toString = file.toString(); // This solution is hacky, and it would be very nice to use a dedicated API instead. // The Bazel Java compiler constructs `SimpleFileObject/DirectoryFileObject` with a // "user-friendly" name that points to the original source file and an underlying/actual // file path in a temporary directory. We're constrained by having to use only public APIs of // the Java compiler and `toString()` seems to be the only way to access the user-friendly + String toString = file.toString().replace(":", "/"); // path. String[] knownBazelToStringPatterns = new String[] {"SimpleFileObject[", "DirectoryFileObject["}; @@ -184,6 +182,23 @@ private Result semanticdbOutputPath(SemanticdbJavacOptions options .resolveSibling(filename); return Result.ok(semanticdbOutputPath); } else { + + if (options.uriScheme == UriScheme.BAZEL && options.generatedTargetRoot != null) { + try { + if (absolutePath.toRealPath().startsWith(options.generatedTargetRoot)) { + reporter.info( + String.format( + "Path '%s' belongs to the root for generated source files, " + + "as reported by javac ('%s'), therefore a SemanticDB file for it won't be generated", + absolutePath, options.generatedTargetRoot), + e); + + return null; + } + } catch (IOException ioe) { + // TODO: + } + } return Result.error( String.format( "sourceroot '%s does not contain path '%s'. To fix this problem, update the -sourceroot flag to " diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/TargetPaths.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/TargetPaths.java new file mode 100644 index 00000000..c523e353 --- /dev/null +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/TargetPaths.java @@ -0,0 +1,13 @@ +package com.sourcegraph.semanticdb_javac; + +import java.nio.file.Path; + +public class TargetPaths { + public Path classes; + public Path sources; + + public TargetPaths(Path classesDir, Path sourcesDir) { + classes = classesDir; + sources = sourcesDir; + } +} From 2e6cabc44c8d0c4142a3aaf859f6a3a82a340dfc Mon Sep 17 00:00:00 2001 From: Anton Sviridov Date: Fri, 30 Jun 2023 10:44:50 +0100 Subject: [PATCH 2/5] chore: formatting --- .../SemanticdbJavacOptions.java | 3 +- .../SemanticdbTaskListener.java | 31 ++++++++++++------- 2 files changed, 22 insertions(+), 12 deletions(-) diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java index 7c001d6a..c73aba4e 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java @@ -45,6 +45,7 @@ public static String missingRequiredDirectoryOption(String option) { public static SemanticdbJavacOptions parse(String[] args, Context ctx) { SemanticdbJavacOptions result = new SemanticdbJavacOptions(); + boolean useJavacClassesDir = false; for (String arg : args) { if (arg.startsWith("-targetroot:")) { @@ -122,6 +123,6 @@ private static TargetPaths getJavacClassesDir(SemanticdbJavacOptions result, Con JAVAC_CLASSES_DIR_ARG, out.toString()); result.errors.add(errorMsg); } - return new TargetPaths(classOutputDir, sourceOutputDir); + return (new TargetPaths(classOutputDir, sourceOutputDir)); } } diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java index 7ff1d130..f6025c68 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java @@ -59,9 +59,12 @@ public void finished(TaskEvent e) { try { onFinishedAnalyze(e); } catch (Throwable ex) { - // Catch exceptions because we don't want to stop the compilation even if this plugin has a - // bug. We report the full stack trace because it's helpful for bug reports. Exceptions - // should only happen in *exceptional* situations and they should be reported upstream. + // Catch exceptions because we don't want to stop the compilation even if this + // plugin has a + // bug. We report the full stack trace because it's helpful for bug reports. + // Exceptions + // should only happen in *exceptional* situations and they should be reported + // upstream. Throwable throwable = ex; if (e.getSourceFile() != null) { throwable = @@ -110,12 +113,17 @@ public static Path absolutePathFromUri(SemanticdbJavacOptions options, JavaFileO throw new IllegalArgumentException("unsupported URI: " + uri); } } else if (options.uriScheme == UriScheme.BAZEL) { - // This solution is hacky, and it would be very nice to use a dedicated API instead. - // The Bazel Java compiler constructs `SimpleFileObject/DirectoryFileObject` with a - // "user-friendly" name that points to the original source file and an underlying/actual - // file path in a temporary directory. We're constrained by having to use only public APIs of - // the Java compiler and `toString()` seems to be the only way to access the user-friendly String toString = file.toString().replace(":", "/"); + // This solution is hacky, and it would be very nice to use a dedicated API + // instead. + // The Bazel Java compiler constructs `SimpleFileObject/DirectoryFileObject` + // with a + // "user-friendly" name that points to the original source file and an + // underlying/actual + // file path in a temporary directory. We're constrained by having to use only + // public APIs of + // the Java compiler and `toString()` seems to be the only way to access the + // user-friendly // path. String[] knownBazelToStringPatterns = new String[] {"SimpleFileObject[", "DirectoryFileObject["}; @@ -144,11 +152,11 @@ private void inferBazelSourceroot(JavaFileObject file) { // /private/var/tmp/com/example/Hello.java // // We infer sourceroot by iterating the names of both files in reverse order - // and stop at the first entry where the two paths are different. For the + // and stop at the first entry where the two paths are different. For the // example above, we compare "Hello.java", then "example", then "com", and // when we reach "repo" != "tmp" then we guess that "/home/repo" is the - // sourceroot. This logic is brittle and it would be nice to use more - // dedicated APIs, but Bazel actively makes an effort to sandbox + // sourceroot. This logic is brittle and it would be nice to use more + // dedicated APIs, but Bazel actively makes an effort to sandbox // compilation and hide access to the original workspace, which is why we // resort to solutions like this. int relativePathDepth = 0; @@ -199,6 +207,7 @@ private Result semanticdbOutputPath(SemanticdbJavacOptions options // TODO: } } + return Result.error( String.format( "sourceroot '%s does not contain path '%s'. To fix this problem, update the -sourceroot flag to " From 1df5eded86a4da3ec1b3d71cda0d752100bcbafd Mon Sep 17 00:00:00 2001 From: Anton Sviridov Date: Fri, 30 Jun 2023 10:49:34 +0100 Subject: [PATCH 3/5] fix dodgy commit --- .../semanticdb_javac/SemanticdbReporter.java | 79 ++++++++++--------- .../SemanticdbTaskListener.java | 2 +- 2 files changed, 42 insertions(+), 39 deletions(-) diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java index ce2af880..60663bc1 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java @@ -12,44 +12,47 @@ /** * Utilities to report error messages. * - *

- * NOTE(olafur): this class exists because I couldn't find compiler APIs to - * report diagnostics. This class can be removed if the Java compiler has APIs - * to report info/warning/error messages. + *

NOTE(olafur): this class exists because I couldn't find compiler APIs to report diagnostics. + * This class can be removed if the Java compiler has APIs to report info/warning/error messages. */ public class SemanticdbReporter { - private final Trees trees; - - public SemanticdbReporter(Trees trees) { - this.trees = trees; - } - - public void exception(Throwable e, Tree tree, CompilationUnitTree root) { - ByteArrayOutputStream baos = new ByteArrayOutputStream(); - PrintWriter writer = new PrintWriter(baos); - e.printStackTrace(writer); - writer.println( - "Please report a bug to https://github.com/sourcegraph/semanticdb-java with the stack trace above."); - trees.printMessage(Diagnostic.Kind.ERROR, baos.toString(), tree, root); - } - - private void info(String message, TaskEvent e) { - trees.printMessage(Diagnostic.Kind.NOTE, "semanticdb-javac: " + message, e.getCompilationUnit(), - e.getCompilationUnit()); - } - - public void error(String message, TaskEvent e) { - trees.printMessage(Diagnostic.Kind.ERROR, "semanticdb-javac: " + message, e.getCompilationUnit(), - e.getCompilationUnit()); - } - - } - - public void error(String message, Tree tree, CompilationUnitTree root) { - // NOTE(olafur): ideally, this message should be reported as a compiler - // diagnostic, but I dind't - // find - // the reporter API so the message goes to stderr instead for now. - trees.printMessage(Diagnostic.Kind.ERROR, String.format("semanticdb-javac: %s", message), tree, root); - } + private final Trees trees; + + public SemanticdbReporter(Trees trees) { + this.trees = trees; + } + + public void exception(Throwable e, Tree tree, CompilationUnitTree root) { + ByteArrayOutputStream baos = new ByteArrayOutputStream(); + PrintWriter writer = new PrintWriter(baos); + e.printStackTrace(writer); + writer.println( + "Please report a bug to https://github.com/sourcegraph/semanticdb-java with the stack trace above."); + trees.printMessage(Diagnostic.Kind.ERROR, baos.toString(), tree, root); + } + + public void info(String message, TaskEvent e) { + trees.printMessage( + Diagnostic.Kind.NOTE, + "semanticdb-javac: " + message, + e.getCompilationUnit(), + e.getCompilationUnit()); + } + + public void error(String message, TaskEvent e) { + trees.printMessage( + Diagnostic.Kind.ERROR, + "semanticdb-javac: " + message, + e.getCompilationUnit(), + e.getCompilationUnit()); + } + + public void error(String message, Tree tree, CompilationUnitTree root) { + // NOTE(olafur): ideally, this message should be reported as a compiler + // diagnostic, but I dind't + // find + // the reporter API so the message goes to stderr instead for now. + trees.printMessage( + Diagnostic.Kind.ERROR, String.format("semanticdb-javac: %s", message), tree, root); + } } diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java index f6025c68..1b618476 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java @@ -85,7 +85,7 @@ private void onFinishedAnalyze(TaskEvent e) { .buildTextDocument(e.getCompilationUnit()); writeSemanticdb(e, path.getOrThrow(), textDocument); } else { - reporter.error(path.getErrorOrThrow(), e) + reporter.error(path.getErrorOrThrow(), e); } } } From 1479eea8df7e46378b5b929ebfee0b22b487034b Mon Sep 17 00:00:00 2001 From: Anton Sviridov Date: Mon, 3 Jul 2023 14:02:49 +0100 Subject: [PATCH 4/5] Add a Bazel example with source generator --- examples/bazel-example/WORKSPACE | 4 ++- .../java/source-generator-example/Animal.java | 12 +++++++ .../main/java/source-generator-example/BUILD | 34 +++++++++++++++++++ 3 files changed, 49 insertions(+), 1 deletion(-) create mode 100644 examples/bazel-example/src/main/java/source-generator-example/Animal.java create mode 100644 examples/bazel-example/src/main/java/source-generator-example/BUILD diff --git a/examples/bazel-example/WORKSPACE b/examples/bazel-example/WORKSPACE index f2b84534..3296b34e 100644 --- a/examples/bazel-example/WORKSPACE +++ b/examples/bazel-example/WORKSPACE @@ -69,7 +69,9 @@ maven_install( artifacts = [ "com.google.protobuf:protobuf-java:3.15.6", # Required dependency by scip-java. "com.google.protobuf:protobuf-java-util:3.15.6", # Required dependency by scip-java. - "com.google.guava:guava:31.0-jre", # Not required dependency, only used by tests. + # These dependencies are only required for the tests + "com.google.guava:guava:31.0-jre", + "com.google.auto.value:auto-value:1.5.3", ], repositories = [ "https://repo1.maven.org/maven2", diff --git a/examples/bazel-example/src/main/java/source-generator-example/Animal.java b/examples/bazel-example/src/main/java/source-generator-example/Animal.java new file mode 100644 index 00000000..575666d1 --- /dev/null +++ b/examples/bazel-example/src/main/java/source-generator-example/Animal.java @@ -0,0 +1,12 @@ + +import com.google.auto.value.AutoValue; + +@AutoValue +abstract class Animal { + static Animal create(String name, int numberOfLegs) { + return new AutoValue_Animal(name, numberOfLegs); + } + + abstract String name(); + abstract int numberOfLegs(); +} diff --git a/examples/bazel-example/src/main/java/source-generator-example/BUILD b/examples/bazel-example/src/main/java/source-generator-example/BUILD new file mode 100644 index 00000000..c02d0062 --- /dev/null +++ b/examples/bazel-example/src/main/java/source-generator-example/BUILD @@ -0,0 +1,34 @@ +load("@scip_java//semanticdb-javac:defs.bzl", "java_library") +load("@rules_java//java:defs.bzl", "java_plugin") + +package( + default_visibility = ["//visibility:public"], +) + +java_library( + name = "animal", + srcs = ["Animal.java"], + deps = [ + ":autovalue", + ], +) + +java_plugin( + name = "autovalue_plugin", + processor_class = "com.google.auto.value.processor.AutoValueProcessor", + deps = [ + "@maven//:com_google_auto_value_auto_value", + ], +) + +java_library( + name = "autovalue", + exported_plugins = [ + ":autovalue_plugin", + ], + neverlink = 1, + exports = [ + "@maven//:com_google_auto_value_auto_value", + ], +) + From ad2e52f8c263b1a476335642d1bb017d12faba95 Mon Sep 17 00:00:00 2001 From: Anton Sviridov Date: Tue, 4 Jul 2023 10:00:36 +0100 Subject: [PATCH 5/5] Only log message about source generators once --- .../SemanticdbJavacOptions.java | 2 +- .../semanticdb_javac/SemanticdbReporter.java | 4 ++++ .../SemanticdbTaskListener.java | 19 +++++++++++-------- 3 files changed, 16 insertions(+), 9 deletions(-) diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java index c73aba4e..e6ed2c16 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbJavacOptions.java @@ -123,6 +123,6 @@ private static TargetPaths getJavacClassesDir(SemanticdbJavacOptions result, Con JAVAC_CLASSES_DIR_ARG, out.toString()); result.errors.add(errorMsg); } - return (new TargetPaths(classOutputDir, sourceOutputDir)); + return new TargetPaths(classOutputDir, sourceOutputDir); } } diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java index 60663bc1..e083b2ee 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbReporter.java @@ -31,6 +31,10 @@ public void exception(Throwable e, Tree tree, CompilationUnitTree root) { trees.printMessage(Diagnostic.Kind.ERROR, baos.toString(), tree, root); } + public void exception(Throwable e, TaskEvent task) { + this.exception(e, task.getCompilationUnit(), task.getCompilationUnit()); + } + public void info(String message, TaskEvent e) { trees.printMessage( Diagnostic.Kind.NOTE, diff --git a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java index 1b618476..f46df649 100644 --- a/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java +++ b/semanticdb-javac/src/main/java/com/sourcegraph/semanticdb_javac/SemanticdbTaskListener.java @@ -25,6 +25,7 @@ public final class SemanticdbTaskListener implements TaskListener { private final SemanticdbReporter reporter; private final JavacTypes javacTypes; private final Trees trees; + private boolean sourceGeneratorsMessageIsLogged = false; public SemanticdbTaskListener( SemanticdbJavacOptions options, @@ -194,17 +195,19 @@ private Result semanticdbOutputPath(SemanticdbJavacOptions options if (options.uriScheme == UriScheme.BAZEL && options.generatedTargetRoot != null) { try { if (absolutePath.toRealPath().startsWith(options.generatedTargetRoot)) { - reporter.info( - String.format( - "Path '%s' belongs to the root for generated source files, " - + "as reported by javac ('%s'), therefore a SemanticDB file for it won't be generated", - absolutePath, options.generatedTargetRoot), - e); + if (!sourceGeneratorsMessageIsLogged) { + sourceGeneratorsMessageIsLogged = true; + reporter.info( + "Usage of source generators detected - scip-java does not produce SemanticDB files for generated files.\n" + + "This message is logged only once", + e); + } return null; } - } catch (IOException ioe) { - // TODO: + } catch (IOException exc) { + reporter.exception(exc, e); + return null; } }