don't try to print null exception trace in printTrace

It is possible to create an Exception with no stack trace by
overriding Throwable.fillInStackTrace, so we can't assume any given
instance will have one.
This commit is contained in:
Joel Dice 2011-03-04 15:58:10 -07:00
parent 4db79b9be6
commit 8fb9523de5

View File

@ -3904,6 +3904,7 @@ printTrace(Thread* t, object exception)
} }
object trace = throwableTrace(t, e); object trace = throwableTrace(t, e);
if (trace) {
for (unsigned i = 0; i < objectArrayLength(t, trace); ++i) { for (unsigned i = 0; i < objectArrayLength(t, trace); ++i) {
object e = objectArrayBody(t, trace, i); object e = objectArrayBody(t, trace, i);
const int8_t* class_ = &byteArrayBody const int8_t* class_ = &byteArrayBody
@ -3926,6 +3927,7 @@ printTrace(Thread* t, object exception)
fprintf(stderr, "(line %d)\n", line); fprintf(stderr, "(line %d)\n", line);
} }
} }
}
if (e == throwableCause(t, e)) { if (e == throwableCause(t, e)) {
break; break;