aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/core/lombok/javac/JavacResolution.java46
-rw-r--r--src/core/lombok/javac/handlers/HandleVal.java4
2 files changed, 44 insertions, 6 deletions
diff --git a/src/core/lombok/javac/JavacResolution.java b/src/core/lombok/javac/JavacResolution.java
index 7361de90..a116b503 100644
--- a/src/core/lombok/javac/JavacResolution.java
+++ b/src/core/lombok/javac/JavacResolution.java
@@ -5,7 +5,9 @@ import java.io.OutputStream;
import java.io.PrintWriter;
import java.lang.reflect.Field;
import java.util.ArrayDeque;
+import java.util.LinkedList;
import java.util.Map;
+import java.util.Queue;
import javax.lang.model.type.TypeKind;
import javax.tools.DiagnosticListener;
@@ -13,10 +15,10 @@ import javax.tools.DiagnosticListener;
import com.sun.tools.javac.code.BoundKind;
import com.sun.tools.javac.code.Symbol.TypeSymbol;
import com.sun.tools.javac.code.Symtab;
+import com.sun.tools.javac.code.Type;
import com.sun.tools.javac.code.Type.ArrayType;
import com.sun.tools.javac.code.Type.CapturedType;
import com.sun.tools.javac.code.Type.ClassType;
-import com.sun.tools.javac.code.Type;
import com.sun.tools.javac.code.Type.WildcardType;
import com.sun.tools.javac.code.TypeTags;
import com.sun.tools.javac.code.Types;
@@ -53,6 +55,7 @@ public class JavacResolution {
private static final class LogDisabler {
private final Log log;
private static final Field errWriterField, warnWriterField, noticeWriterField, dumpOnErrorField, promptOnErrorField, diagnosticListenerField;
+ private static final Field deferDiagnosticsField, deferredDiagnosticsField;
private PrintWriter errWriter, warnWriter, noticeWriter;
private Boolean dumpOnError, promptOnError;
private DiagnosticListener<?> contextDiagnosticListener, logDiagnosticListener;
@@ -61,9 +64,11 @@ public class JavacResolution {
// If this is true, the fields changed. Better to print weird error messages than to fail outright.
private static final boolean dontBother;
+ private static final ThreadLocal<Queue<?>> queueCache = new ThreadLocal<Queue<?>>();
+
static {
boolean z;
- Field a = null, b = null, c = null, d = null, e = null, f = null;
+ Field a = null, b = null, c = null, d = null, e = null, f = null, g = null, h = null;
try {
a = Log.class.getDeclaredField("errWriter");
b = Log.class.getDeclaredField("warnWriter");
@@ -82,12 +87,22 @@ public class JavacResolution {
z = true;
}
+ try {
+ g = Log.class.getDeclaredField("deferDiagnostics");
+ h = Log.class.getDeclaredField("deferredDiagnostics");
+ g.setAccessible(true);
+ h.setAccessible(true);
+ } catch (Exception x) {
+ }
+
errWriterField = a;
warnWriterField = b;
noticeWriterField = c;
dumpOnErrorField = d;
promptOnErrorField = e;
diagnosticListenerField = f;
+ deferDiagnosticsField = g;
+ deferredDiagnosticsField = h;
dontBother = z;
}
@@ -108,6 +123,14 @@ public class JavacResolution {
}
});
+ if (deferDiagnosticsField != null) try {
+ if (Boolean.TRUE.equals(deferDiagnosticsField.get(log))) {
+ queueCache.set((Queue<?>) deferredDiagnosticsField.get(log));
+ Queue<?> empty = new LinkedList<Object>();
+ deferredDiagnosticsField.set(log, empty);
+ }
+ } catch (Exception e) {}
+
if (!dontBotherInstance) try {
errWriter = (PrintWriter) errWriterField.get(log);
errWriterField.set(log, dummyWriter);
@@ -159,6 +182,7 @@ public class JavacResolution {
context.put(DiagnosticListener.class, contextDiagnosticListener);
contextDiagnosticListener = null;
}
+
if (errWriter != null) try {
errWriterField.set(log, errWriter);
errWriter = null;
@@ -188,6 +212,11 @@ public class JavacResolution {
diagnosticListenerField.set(log, logDiagnosticListener);
logDiagnosticListener = null;
} catch (Exception e) {}
+
+ if (deferDiagnosticsField != null && queueCache.get() != null) try {
+ deferredDiagnosticsField.set(log, queueCache.get());
+ queueCache.set(null);
+ } catch (Exception e) {}
}
}
@@ -217,8 +246,17 @@ public class JavacResolution {
@Override public void visitClassDef(JCClassDecl tree) {
if (copyAt != null) return;
- // The commented out one leaves the 'lint' field unset, which causes NPEs during attrib. So, we use the other one.
- //env = enter.classEnv((JCClassDecl) tree, env);
+ // The commented out stuff requires reflection tricks to avoid leaving lint unset which causes NPEs during attrib. So, we use the other one, much less code.
+// env = enter.classEnv((JCClassDecl) tree, env);
+// try {
+// Field f = env.info.getClass().getDeclaredField("lint");
+// f.setAccessible(true);
+// Constructor<?> c = Lint.class.getDeclaredConstructor(Lint.class);
+// c.setAccessible(true);
+// f.set(env.info, c.newInstance(lint));
+// } catch (Exception e) {
+// throw Lombok.sneakyThrow(e);
+// }
env = enter.getClassEnv(tree.sym);
}
diff --git a/src/core/lombok/javac/handlers/HandleVal.java b/src/core/lombok/javac/handlers/HandleVal.java
index 4dafa360..bc70899d 100644
--- a/src/core/lombok/javac/handlers/HandleVal.java
+++ b/src/core/lombok/javac/handlers/HandleVal.java
@@ -72,7 +72,7 @@ public class HandleVal extends JavacASTAdapter {
return;
}
- JavacHandlerUtil.deleteImportFromCompilationUnit(localNode, "lombok.val");
+ if (localNode.shouldDeleteLombokAnnotations()) JavacHandlerUtil.deleteImportFromCompilationUnit(localNode, "lombok.val");
local.mods.flags |= Flags.FINAL;
@@ -115,7 +115,7 @@ public class HandleVal extends JavacASTAdapter {
if (replacement != null) {
local.vartype = replacement;
} else {
- local.vartype = JavacResolution.createJavaLangObject(localNode.getTreeMaker(), localNode.getAst());;
+ local.vartype = JavacResolution.createJavaLangObject(localNode.getTreeMaker(), localNode.getAst());
}
localNode.getAst().setChanged();
} catch (JavacResolution.TypeNotConvertibleException e) {