From 86a42a5f2443414d63765a4bc84df0530bc32557 Mon Sep 17 00:00:00 2001 From: Bryce McKinlay Date: Fri, 22 Dec 2000 06:19:24 +0000 Subject: [PATCH] Throwable.java (trace_enabled): New static field. * java/lang/Throwable.java (trace_enabled): New static field. * java/lang/natThrowable.cc (fillInStackTrace): Do nothing if trace_enabled not set. * prims.cc (main_init): Turn off trace_enabled while creating default exception objects. From-SVN: r38442 --- libjava/ChangeLog | 8 ++++++++ libjava/java/lang/Throwable.java | 2 ++ libjava/java/lang/natThrowable.cc | 2 ++ libjava/prims.cc | 6 ++++++ 4 files changed, 18 insertions(+) diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 34b917512eb..f7ce1f3f29d 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,11 @@ +2000-12-22 Bryce McKinlay + + * java/lang/Throwable.java (trace_enabled): New static field. + * java/lang/natThrowable.cc (fillInStackTrace): Do nothing if + trace_enabled not set. + * prims.cc (main_init): Turn off trace_enabled while creating + default exception objects. + 2000-12-21 Tom Tromey * java/beans/PropertyChangeListener.java: Extends EventListener. diff --git a/libjava/java/lang/Throwable.java b/libjava/java/lang/Throwable.java index 610a499a2cb..4aa21399c5a 100644 --- a/libjava/java/lang/Throwable.java +++ b/libjava/java/lang/Throwable.java @@ -164,6 +164,8 @@ public class Throwable implements Serializable // Name of this field comes from serialization spec. private String detailMessage; + // Setting this flag to false prevents fillInStackTrace() from running. + static boolean trace_enabled = true; private transient byte stackTrace[]; private static final long serialVersionUID = -3042686055658047285L; } diff --git a/libjava/java/lang/natThrowable.cc b/libjava/java/lang/natThrowable.cc index c7f19bec09d..dab3ba6387a 100644 --- a/libjava/java/lang/natThrowable.cc +++ b/libjava/java/lang/natThrowable.cc @@ -50,6 +50,8 @@ extern "C" int __ia64_backtrace (void **array, int size); java::lang::Throwable * java::lang::Throwable::fillInStackTrace (void) { + if (! trace_enabled) + return this; #if defined (HAVE_BACKTRACE) || defined (__ia64__) void *p[128]; diff --git a/libjava/prims.cc b/libjava/prims.cc index c6b8d2030e1..06585749c5f 100644 --- a/libjava/prims.cc +++ b/libjava/prims.cc @@ -687,6 +687,10 @@ win32_exception_handler (LPEXCEPTION_POINTERS e) static void main_init () { + // Turn stack trace generation off while creating exception objects. + _Jv_InitClass (&java::lang::Throwable::class$); + java::lang::Throwable::trace_enabled = 0; + INIT_SEGV; #ifdef HANDLE_FPE INIT_FPE; @@ -697,6 +701,8 @@ main_init () no_memory = new java::lang::OutOfMemoryError; + java::lang::Throwable::trace_enabled = 1; + #ifdef USE_LTDL LTDL_SET_PRELOADED_SYMBOLS (); #endif -- 2.30.2