diff options
-rw-r--r-- | src/core/lombok/core/debug/DebugSnapshot.java | 18 | ||||
-rw-r--r-- | src/core/lombok/core/debug/DebugSnapshotStore.java | 30 |
2 files changed, 42 insertions, 6 deletions
diff --git a/src/core/lombok/core/debug/DebugSnapshot.java b/src/core/lombok/core/debug/DebugSnapshot.java index 3982539e..42bb62fe 100644 --- a/src/core/lombok/core/debug/DebugSnapshot.java +++ b/src/core/lombok/core/debug/DebugSnapshot.java @@ -22,9 +22,13 @@ public class DebugSnapshot implements Comparable<DebugSnapshot> { public DebugSnapshot(CompilationUnitDeclaration owner, int stackHiding, String message, Object... params) { this.when = System.currentTimeMillis(); this.bits = owner.bits; - StackTraceElement[] stackTrace = new Throwable().getStackTrace(); - this.trace = new ArrayList<StackTraceElement>(Math.max(0, stackTrace.length - stackHiding - 1)); - for (int i = 1 + stackHiding; i < stackTrace.length; i++) trace.add(stackTrace[i]); + if (stackHiding < 0) { + this.trace = null; + } else { + StackTraceElement[] stackTrace = new Throwable().getStackTrace(); + this.trace = new ArrayList<StackTraceElement>(Math.max(0, stackTrace.length - stackHiding - 1)); + for (int i = 1 + stackHiding; i < stackTrace.length; i++) trace.add(stackTrace[i]); + } this.threadName = Thread.currentThread().getName(); this.message = message; this.params = params == null ? new Object[0] : params; @@ -53,8 +57,12 @@ public class DebugSnapshot implements Comparable<DebugSnapshot> { @Override public String toString() { StringBuilder out = new StringBuilder(); out.append(shortToString()).append("\n"); - for (StackTraceElement elem : trace) { - out.append(" ").append(elem.toString()).append("\n"); + if (trace == null) { + out.append(" Stack Omitted"); + } else { + for (StackTraceElement elem : trace) { + out.append(" ").append(elem.toString()).append("\n"); + } } return out.toString(); } diff --git a/src/core/lombok/core/debug/DebugSnapshotStore.java b/src/core/lombok/core/debug/DebugSnapshotStore.java index 7abfc07c..64c91473 100644 --- a/src/core/lombok/core/debug/DebugSnapshotStore.java +++ b/src/core/lombok/core/debug/DebugSnapshotStore.java @@ -13,11 +13,13 @@ import org.eclipse.jdt.internal.compiler.ast.CompilationUnitDeclaration; public class DebugSnapshotStore { public static final DebugSnapshotStore INSTANCE = new DebugSnapshotStore(); + public static boolean GLOBAL_DSS_DISABLE_SWITCH = true; private final Map<CompilationUnitDeclaration, List<DebugSnapshot>> map = new WeakHashMap<CompilationUnitDeclaration, List<DebugSnapshot>>(); public void snapshot(CompilationUnitDeclaration owner, String message, Object... params) { + if (GLOBAL_DSS_DISABLE_SWITCH) return; DebugSnapshot snapshot = new DebugSnapshot(owner, 1, message, params); List<DebugSnapshot> list; @@ -26,18 +28,44 @@ public class DebugSnapshotStore { if (list == null) { list = new ArrayList<DebugSnapshot>(); map.put(owner, list); + list.add(snapshot); + } else if (!list.isEmpty()) { + list.add(snapshot); + } else { + // An empty list is an indicator that we no longer care about that particular CUD. + } + } + } + + public void log(CompilationUnitDeclaration owner, String message, Object... params) { + if (GLOBAL_DSS_DISABLE_SWITCH) return; + DebugSnapshot snapshot = new DebugSnapshot(owner, -1, message, params); + List<DebugSnapshot> list; + + synchronized (map) { + list = map.get(owner); + if (list == null) { + list = new ArrayList<DebugSnapshot>(); + map.put(owner, list); + list.add(snapshot); + } else if (!list.isEmpty()) { + list.add(snapshot); + } else { + // An empty list is an indicator that we no longer care about that particular CUD. } - list.add(snapshot); } } public String print(CompilationUnitDeclaration owner, String message, Object... params) { + if (GLOBAL_DSS_DISABLE_SWITCH) return null; List<DebugSnapshot> list; synchronized (map) { snapshot(owner, message == null ? "Printing" : message, params); list = new ArrayList<DebugSnapshot>(); list.addAll(map.get(owner)); + if (list.isEmpty()) return null; // An empty list is an indicator that we no longer care about that particular CUD. + map.get(owner).clear(); } Collections.sort(list); |