natClassLoader.cc (_Jv_NewClass): Use _Jv_RegisterInitiatingLoader to register array...
authorBryce McKinlay <mckinlay@redhat.com>
Thu, 19 May 2005 22:24:26 +0000 (22:24 +0000)
committerBryce McKinlay <bryce@gcc.gnu.org>
Thu, 19 May 2005 22:24:26 +0000 (23:24 +0100)
* java/lang/natClassLoader.cc (_Jv_NewClass): Use
_Jv_RegisterInitiatingLoader to register array classes, not
_Jv_RegisterClass.
(_Jv_RegisterInitiatingLoader): Give up if called very early during
bootstrapping. Add a FIXME to handle this case better.

From-SVN: r99993

libjava/ChangeLog
libjava/java/lang/natClassLoader.cc

index d99537cf5cabf313bac676bff13748c933a54d23..738b017e5f0d9d32a3562046d3581fe6c1f31080 100644 (file)
@@ -1,3 +1,11 @@
+2005-05-19  Bryce McKinlay  <mckinlay@redhat.com>
+
+       * java/lang/natClassLoader.cc (_Jv_NewClass): Use
+       _Jv_RegisterInitiatingLoader to register array classes, not 
+       _Jv_RegisterClass.
+       (_Jv_RegisterInitiatingLoader): Give up if called very early during
+       bootstrapping. Add a FIXME to handle this case better.
+
 2005-05-19  Bryce McKinlay  <mckinlay@redhat.com>
 
        * Makefile.am (libgcj0_convenience_la): Removed. Don't build a libgcj
index 2fa3f49ef1b30359733a79e36f283c2dea8db9ae..fb3515b5a78914b12715b99cadf70c933c890f9e 100644 (file)
@@ -127,6 +127,14 @@ _Jv_RegisterInitiatingLoader (jclass klass, java::lang::ClassLoader *loader)
 {
   if (! loader)
     loader = java::lang::VMClassLoader::bootLoader;
+  if (! loader)
+    {
+      // Very early in the bootstrap process, the Bootstrap classloader may 
+      // not exist yet.
+      // FIXME: We could maintain a list of these and come back and register
+      // them later.
+      return;
+    }
   loader->loadedClasses->put(klass->name->toString(), klass);
 }
 
@@ -346,7 +354,7 @@ _Jv_NewClass (_Jv_Utf8Const *name, jclass superclass,
   ret->superclass = superclass;
   ret->loader = loader;
 
-  _Jv_RegisterClass (ret);
+  _Jv_RegisterInitiatingLoader (ret, loader);
 
   return ret;
 }