From a3033e64df5fbd480ae845d45457f8da24f5a761 Mon Sep 17 00:00:00 2001 From: Stephan Schroevers Date: Thu, 19 Oct 2017 22:38:14 +0200 Subject: [PATCH] Collect Refaster rules across all provided files Fixes google/error-prone#552 --- .../refaster/RefasterRuleCompilerAnalyzer.java | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/refaster/src/main/java/com/google/errorprone/refaster/RefasterRuleCompilerAnalyzer.java b/refaster/src/main/java/com/google/errorprone/refaster/RefasterRuleCompilerAnalyzer.java index df7261cacb5..cd3e137fef6 100644 --- a/refaster/src/main/java/com/google/errorprone/refaster/RefasterRuleCompilerAnalyzer.java +++ b/refaster/src/main/java/com/google/errorprone/refaster/RefasterRuleCompilerAnalyzer.java @@ -29,6 +29,7 @@ import java.nio.file.Files; import java.nio.file.Path; import java.util.ArrayList; +import java.util.Collections; import java.util.List; /** @@ -36,6 +37,7 @@ * to the specified path. */ public class RefasterRuleCompilerAnalyzer implements TaskListener { + private final List allRules = Collections.synchronizedList(new ArrayList<>()); private final Context context; private final Path destinationPath; @@ -46,6 +48,10 @@ public class RefasterRuleCompilerAnalyzer implements TaskListener { @Override public void finished(TaskEvent taskEvent) { + if (taskEvent.getKind() == Kind.COMPILATION) { + persist(); + return; + } if (taskEvent.getKind() != Kind.ANALYZE) { return; } @@ -67,9 +73,13 @@ public Void visitClass(ClassTree node, Context context) { if (rules.isEmpty()) { throw new IllegalArgumentException("Did not find any Refaster templates"); } + allRules.addAll(rules); + } + + private void persist() { try (ObjectOutputStream output = new ObjectOutputStream(Files.newOutputStream(destinationPath))) { - output.writeObject(CompositeCodeTransformer.compose(rules)); + output.writeObject(CompositeCodeTransformer.compose(allRules)); } catch (IOException e) { throw new RuntimeException(e); }