2002-12-19 Andrew Haley <aph@redhat.com>
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 20 Dec 2002 02:06:21 +0000 (02:06 +0000)
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 20 Dec 2002 02:06:21 +0000 (02:06 +0000)
* java/util/natResourceBundle.cc: Include
ArrayIndexOutOfBoundsException.h.
(getCallingClassLoader): Don't put upper bound on stack search.
Catch ArrayIndexOutOfBoundsException.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@60348 138bc75d-0d04-0410-961f-82ee72b054a4

libjava/ChangeLog
libjava/java/util/natResourceBundle.cc

index 64c58d0..75c44a4 100644 (file)
@@ -1,3 +1,10 @@
+2002-12-19  Andrew Haley  <aph@redhat.com>
+
+       * java/util/natResourceBundle.cc: Include
+       ArrayIndexOutOfBoundsException.h.
+       (getCallingClassLoader): Don't put upper bound on stack search.
+       Catch ArrayIndexOutOfBoundsException.
+
 2002-12-19  Tom Tromey  <tromey@redhat.com>
 
        * libtool-version: Increased `current'.
index 21a9565..adb83f9 100644 (file)
@@ -16,17 +16,24 @@ details.  */
 #include <java/lang/SecurityManager.h>
 #include <java/lang/ClassLoader.h>
 #include <java/lang/Class.h>
+#include <java/lang/ArrayIndexOutOfBoundsException.h>
 #include <gnu/gcj/runtime/StackTrace.h>
 
 java::lang::ClassLoader *
 java::util::ResourceBundle::getCallingClassLoader ()
 {
   gnu::gcj::runtime::StackTrace *t = new gnu::gcj::runtime::StackTrace(6);
-  for (int i = 3; i < 6; ++i)
+  try
+    {
+      for (int i = 3; ; ++i)
+       {
+         jclass klass = t->classAt(i);
+         if (klass != NULL)
+           return klass->getClassLoaderInternal();
+       }
+    }
+  catch (::java::lang::ArrayIndexOutOfBoundsException *e)
     {
-      jclass klass = t->classAt(i);
-      if (klass != NULL)
-       return klass->getClassLoaderInternal();
     }
   return NULL;
 }