corda/classpath/java/lang/Throwable.java

116 lines
2.5 KiB
Java
Raw Normal View History

package java.lang;
2007-07-28 19:29:01 -06:00
import java.io.PrintStream;
import java.io.PrintWriter;
2007-07-28 20:15:45 -06:00
import java.io.IOException;
2007-07-28 19:29:01 -06:00
public class Throwable {
private String message;
private Object trace;
private Throwable cause;
public Throwable(String message, Throwable cause) {
this.message = message;
this.trace = trace(1);
this.cause = cause;
}
public Throwable(String message) {
this(message, null);
}
public Throwable(Throwable cause) {
this(null, cause);
}
public Throwable() {
this(null, null);
}
2007-07-21 14:44:39 -06:00
public Throwable getCause() {
return cause;
}
2007-09-11 20:56:02 -06:00
public void initCause(Throwable e) {
if (cause == null) {
cause = e;
} else {
throw new IllegalStateException();
}
}
2007-07-26 20:39:53 -06:00
public String getMessage() {
return message;
}
2007-08-14 07:27:10 -06:00
public String toString() {
2007-08-19 20:57:32 -06:00
StringBuilder sb = new StringBuilder();
sb.append(getClass().getName());
if (message != null) {
sb.append(": ").append(message);
}
return sb.toString();
2007-08-14 07:27:10 -06:00
}
private static native Object trace(int skipCount);
private static native StackTraceElement[] resolveTrace(Object trace);
private StackTraceElement[] resolveTrace() {
if (! (trace instanceof StackTraceElement[])) {
trace = resolveTrace(trace);
}
return (StackTraceElement[]) trace;
}
public StackTraceElement[] getStackTrace() {
return resolveTrace();
}
2007-07-28 19:29:01 -06:00
public void printStackTrace(PrintStream out) {
StringBuilder sb = new StringBuilder();
printStackTrace(sb, System.getProperty("line.separator"));
2007-07-28 19:29:01 -06:00
out.print(sb.toString());
out.flush();
2007-07-28 19:29:01 -06:00
}
public void printStackTrace(PrintWriter out) {
StringBuilder sb = new StringBuilder();
printStackTrace(sb, System.getProperty("line.separator"));
out.print(sb.toString());
out.flush();
2007-07-28 19:29:01 -06:00
}
public void printStackTrace() {
printStackTrace(System.err);
}
private void printStackTrace(StringBuilder sb, String nl) {
2007-08-19 20:57:32 -06:00
sb.append(toString()).append(nl);
StackTraceElement[] trace = resolveTrace();
for (int i = 0; i < trace.length; ++i) {
sb.append(" at ")
.append(trace[i].getClassName())
.append(".")
.append(trace[i].getMethodName());
if (trace[i].isNativeMethod()) {
sb.append(" (native)");
} else {
int line = trace[i].getLineNumber();
if (line >= 0) {
sb.append(" (line ").append(line).append(")");
}
}
sb.append(nl);
}
if (cause != null) {
sb.append("caused by: ");
cause.printStackTrace(sb, nl);
}
}
}