Runtime.java (_exit): Declare new package-private native.
authorBryce McKinlay <bryce@albatross.co.nz>
Mon, 12 Mar 2001 07:40:17 +0000 (07:40 +0000)
committerBryce McKinlay <bryce@gcc.gnu.org>
Mon, 12 Mar 2001 07:40:17 +0000 (07:40 +0000)
2001-03-12  Bryce McKinlay  <bryce@albatross.co.nz>

* java/lang/Runtime.java (_exit): Declare new package-private native.
* java/lang/natRuntime.cc (_exit): Implemented. Same as exit() but
without a security manager check.
(exit): Call _exit after security check.
* prims.cc (JvRunMain): Call Runtime._exit to shutdown the runtime
"naturally".
* java/lang/System.java (setSecurityManager): If a security manager
is already in place, call checkPermission.
* java/lang/ThreadGroup.java (uncaughtException): If printStackTrace()
throws an exception, try to deal with it gracefully.
* java/lang/ExceptionInInitializerError.java (printStackTrace):
Only try to print the subordinate stack trace if "exception" is set.
Print our class name first.

From-SVN: r40401

libjava/ChangeLog
libjava/java/lang/ExceptionInInitializerError.java
libjava/java/lang/Runtime.java
libjava/java/lang/System.java
libjava/java/lang/ThreadGroup.java
libjava/java/lang/natRuntime.cc
libjava/prims.cc

index ce7250e71cb4271e1de0613f6e58c189d1820463..44a3bd830af43beb0c2226ca306621b0dd3f3a7c 100644 (file)
@@ -1,3 +1,19 @@
+2001-03-12  Bryce McKinlay  <bryce@albatross.co.nz>
+
+       * java/lang/Runtime.java (_exit): Declare new package-private native.
+       * java/lang/natRuntime.cc (_exit): Implemented. Same as exit() but
+       without a security manager check.
+       (exit): Call _exit after security check.
+       * prims.cc (JvRunMain): Call Runtime._exit to shutdown the runtime
+       "naturally".
+       * java/lang/System.java (setSecurityManager): If a security manager
+       is already in place, call checkPermission. 
+       * java/lang/ThreadGroup.java (uncaughtException): If printStackTrace()
+       throws an exception, try to deal with it gracefully.
+       * java/lang/ExceptionInInitializerError.java (printStackTrace):
+       Only try to print the subordinate stack trace if "exception" is set.
+       Print our class name first.
+
 2001-03-08  Tom Tromey  <tromey@redhat.com>
 
        * java/io/ObjectStreamClass.java (setUID): Don't write interface
index 0aad2fc89eaf200c67b9accaf257904db22173c5..95b4311c1742239aa8574426c703d78d49af6dc7 100644 (file)
@@ -1,6 +1,6 @@
 // ExceptionInInitializerError.java
 
-/* Copyright (C) 1998, 1999, 2000  Free Software Foundation
+/* Copyright (C) 1998, 1999, 2000, 2001  Free Software Foundation
 
    This file is part of libgcj.
 
@@ -38,7 +38,7 @@ public class ExceptionInInitializerError extends LinkageError
 
   public ExceptionInInitializerError (Throwable e)
   {
-    super ();
+    super (e.toString());
     exception = e;
   }
 
@@ -49,17 +49,35 @@ public class ExceptionInInitializerError extends LinkageError
 
   public void printStackTrace ()
   {
-    exception.printStackTrace ();
+    if (exception != null)
+      {
+       System.err.print (this.getClass() + ": ");
+       exception.printStackTrace ();
+      }
+    else
+      super.printStackTrace ();
   }
 
   public void printStackTrace (PrintStream ps)
   {
-    exception.printStackTrace (ps);
+    if (exception != null)
+      {
+       ps.print (this.getClass() + ": ");
+       exception.printStackTrace (ps);
+      }
+    else
+      super.printStackTrace (ps);
   }
 
   public void printStackTrace (PrintWriter pw)
   {
-    exception.printStackTrace (pw);
+    if (exception != null)
+      {
+       pw.print (this.getClass() + ": ");
+       exception.printStackTrace (pw);
+      }
+    else
+      super.printStackTrace (pw);
   }
 
   // The exception that caused this error.
index e746c60b384f455adae119a55728ba267f1920ad..28befc26d19404a2bc6597ee9b831a7767d3bdde 100644 (file)
@@ -1,6 +1,6 @@
 // Runtime.java - Runtime class.
 
-/* Copyright (C) 1998, 1999, 2000  Free Software Foundation
+/* Copyright (C) 1998, 1999, 2000, 2001  Free Software Foundation
 
    This file is part of libgcj.
 
@@ -63,6 +63,10 @@ public class Runtime
   }
 
   public native void exit (int status);
+  
+  // Shutdown the runtime without a SecurityManager check. libgcj uses this 
+  // exit function internally.
+  final native void _exit (int status);
 
   public native long freeMemory ();
   public native void gc ();
index 162bc1f21eb31fc56944f91e96a5001fbea2d7c9..0f7bd7ba8b742782dcf40a0305307efd89ade25d 100644 (file)
@@ -230,7 +230,7 @@ public final class System
   public static void setSecurityManager (SecurityManager s)
   {
     if (secman != null)
-      throw new SecurityException ();
+      secman.checkPermission(new RuntimePermission("setSecurityManager"));
     secman = s;
   }
 
index e8b444682bb213aa09b7b04d7bbb1e11b14837b5..bdf37f9ec9cd7961ef269e6e78bba2e05dfec8f0 100644 (file)
@@ -511,7 +511,19 @@ public class ThreadGroup
       {
         if (thread != null)
           System.out.print("Exception in thread \"" + thread.getName() + "\" ");
-       t.printStackTrace();
+       try
+         {
+           t.printStackTrace();
+         }
+       catch (Throwable x)
+         {
+           // This means that something is badly screwed up with the runtime,
+           // or perhaps someone is messing with the SecurityManager. In any
+           // case, try to deal with it gracefully.
+           System.out.println(t);
+           System.err.println("*** Got " + x.toString() + 
+                              " while trying to print stack trace");
+         }
        had_uncaught_exception = true;
       }
   }
index 5ff7d2edacf02aef20c06c474686134a3dff921e..3f1a0b335fc139818330963a414989a5b73e1e34 100644 (file)
@@ -1,6 +1,6 @@
 // natRuntime.cc - Implementation of native side of Runtime class.
 
-/* Copyright (C) 1998, 1999, 2000  Free Software Foundation
+/* Copyright (C) 1998, 1999, 2000, 2001  Free Software Foundation
 
    This file is part of libgcj.
 
@@ -78,7 +78,12 @@ void
 java::lang::Runtime::exit (jint status)
 {
   checkExit (status);
+  _exit (status);
+}
 
+void
+java::lang::Runtime::_exit (jint status)
+{
   // Make status right for Unix.  This is perhaps strange.
   if (status < 0 || status > 255)
     status = 255;
index 85264bb2cce00fc7f7442a57503275ae0b7558d1..f68b2f049baebc514288087c21b4030810df65f8 100644 (file)
@@ -850,7 +850,7 @@ JvRunMain (jclass klass, int argc, const char **argv)
 
   int status = (int) java::lang::ThreadGroup::had_uncaught_exception;
     
-  java::lang::Runtime::getRuntime ()->exit (status);
+  java::lang::Runtime::getRuntime ()->_exit (status);
 }
 
 void