Class.h (_Jv_Self): New union type.
authorBryce McKinlay <bryce@waitaki.otago.ac.nz>
Sun, 6 May 2001 13:42:11 +0000 (13:42 +0000)
committerBryce McKinlay <bryce@gcc.gnu.org>
Sun, 6 May 2001 13:42:11 +0000 (14:42 +0100)
* java/lang/Class.h (_Jv_Self): New union type.
(Class): Manipulate vtable pointer via _Jv_Self union. Thanks to
Jeff Sturm and Fergus Henderson.

* java/lang/ClassLoader.java: Remove dead code fragment.

From-SVN: r41876

libjava/ChangeLog
libjava/java/lang/Class.h
libjava/java/lang/ClassLoader.java

index 018b62b262cc786f8f3042231e86f38b2f789dab..5a95e2fc84d383cd175d2d20e4053e196a3dfd8d 100644 (file)
@@ -1,3 +1,13 @@
+2001-05-06  Bryce McKinlay  <bryce@waitaki.otago.ac.nz>
+
+       * java/lang/Class.h (_Jv_Self): New union type.
+       (Class): Manipulate vtable pointer via _Jv_Self union. Thanks to
+       Jeff Sturm and Fergus Henderson.
+
+2001-05-06  Bryce McKinlay  <bryce@waitaki.otago.ac.nz>
+
+       * java/lang/ClassLoader.java: Remove dead code fragment.
+
 2001-05-03  Martin Kahlert  <martin.kahlert@infineon.com>
 
        * jni.cc (_Jv_JNI_GetPrimitiveArrayRegion): Fixed bounds
index a0cd730ef26ed89e497938a71a7762687facb22c..8cce30f3f6e8e70a28cf66f33db3f67669d57874 100644 (file)
@@ -99,6 +99,13 @@ struct _Jv_ifaces
   jshort count;
 };
 
+// Used for vtable pointer manipulation.
+union _Jv_Self
+{
+  char *vtable_ptr;
+  jclass self;
+};
+
 #define JV_PRIMITIVE_VTABLE ((_Jv_VTable *) -1)
 
 #define JV_CLASS(Obj) ((jclass) (*(_Jv_VTable **) Obj)->clas)
@@ -211,9 +218,8 @@ public:
 
     // C++ ctors set the vtbl pointer to point at an offset inside the vtable
     // object. That doesn't work for Java, so this hack adjusts it back.
-    void *p =  ((void **)this)[0];
-    ((void **)this)[0] = (void *)((char *)p-2*sizeof (void *));
-
+    ((_Jv_Self *)this)->vtable_ptr -= 2 * sizeof (void *);
+    
     // We must initialize every field of the class.  We do this in the
     // same order they are declared in Class.h, except for fields that
     // are initialized to NULL.
index 56d73e6f833fd6acc51135a78dbcd5538c77cf96..9c4b3c8ad756ba3a7c2d442d4d5a33241b5218ff 100644 (file)
@@ -91,10 +91,6 @@ public abstract class ClassLoader
     return loadClass (name, false);
   }
   
-  /* findClass implementation for the system classloader. 
-  native Class systemFindClass(String name)
-    throws java.lang.ClassNotFoundException;
-
   /** 
    * Loads the class by the given name.  The default implementation
    * will search for the class in the following order (similar to jdk 1.2)