aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/main/java/com/google/devtools/build/lib
diff options
context:
space:
mode:
authorGravatar Florian Weikert <fwe@google.com>2015-08-27 12:57:25 +0000
committerGravatar Philipp Wollermann <philwo@google.com>2015-08-27 14:45:32 +0000
commita37e86c720dcb4a18368b5594676faceb5050e2e (patch)
tree507de187e6d824892251a76a5aeb266ae39d112a /src/main/java/com/google/devtools/build/lib
parenteb4f2ad9bc2aa6efe788f8bf63f53c942a193a4b (diff)
EvalExceptionWithStackTrace does no longer remove non-EvalException exceptions from its cause.
-- MOS_MIGRATED_REVID=101673097
Diffstat (limited to 'src/main/java/com/google/devtools/build/lib')
-rw-r--r--src/main/java/com/google/devtools/build/lib/syntax/EvalExceptionWithStackTrace.java14
1 files changed, 12 insertions, 2 deletions
diff --git a/src/main/java/com/google/devtools/build/lib/syntax/EvalExceptionWithStackTrace.java b/src/main/java/com/google/devtools/build/lib/syntax/EvalExceptionWithStackTrace.java
index d1baabc5fd..686ccab083 100644
--- a/src/main/java/com/google/devtools/build/lib/syntax/EvalExceptionWithStackTrace.java
+++ b/src/main/java/com/google/devtools/build/lib/syntax/EvalExceptionWithStackTrace.java
@@ -23,14 +23,24 @@ import java.util.Deque;
import java.util.LinkedList;
/**
- * EvalException with a stack trace
+ * EvalException with a stack trace.
*/
public class EvalExceptionWithStackTrace extends EvalException {
private StackTraceElement mostRecentElement;
public EvalExceptionWithStackTrace(Exception original, Location callLocation) {
- super(callLocation, getNonEmptyMessage(original), original.getCause());
+ super(callLocation, getNonEmptyMessage(original), getCause(original));
+ }
+
+ /**
+ * Returns the "real" cause of this exception.
+ *
+ * <p>If the original exception is an EvalException, its cause is returned.
+ * Otherwise, the original exception itself is seen as the cause for this exception.
+ */
+ private static Throwable getCause(Exception ex) {
+ return (ex instanceof EvalException) ? ex.getCause() : ex;
}
/**