aboutsummaryrefslogtreecommitdiff
path: root/libjava/java
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2001-12-16 22:28:35 +0000
committerTom Tromey <tromey@gcc.gnu.org>2001-12-16 22:28:35 +0000
commit68940f3f3c1c6011be4434d30e1e1f8548be7b7d (patch)
tree40b6d3dc40874ea7045518f5a5d294ffddf0cf1f /libjava/java
parent495513eea640d4135f4b62f341bc844a09779df7 (diff)
downloadgcc-68940f3f3c1c6011be4434d30e1e1f8548be7b7d.zip
gcc-68940f3f3c1c6011be4434d30e1e1f8548be7b7d.tar.gz
gcc-68940f3f3c1c6011be4434d30e1e1f8548be7b7d.tar.bz2
For PR java/5088:
* java/lang/natClassLoader.cc (_Jv_InitNewClassFields): New function. (_Jv_NewClass): Use it. (defineClass0): Use it. * prims.cc (_Jv_InitPrimClass): Adjust vtable here. (_Jv_InitPrimClass): Use _Jv_InitNewClassFields. (_Jv_NewArray): Don't abort; just throw exception. Include InternalError.h. * java/lang/Class.h (Class::Class): Declare, don't define. (Class): Declare _Jv_InitNewClassFields as a friend. (union _Jv_Self): Removed. From-SVN: r48081
Diffstat (limited to 'libjava/java')
-rw-r--r--libjava/java/lang/Class.h15
-rw-r--r--libjava/java/lang/natClassLoader.cc25
2 files changed, 19 insertions, 21 deletions
diff --git a/libjava/java/lang/Class.h b/libjava/java/lang/Class.h
index 2052391..73d81da 100644
--- a/libjava/java/lang/Class.h
+++ b/libjava/java/lang/Class.h
@@ -109,13 +109,6 @@ struct _Jv_ifaces
jshort count;
};
-// Used for vtable pointer manipulation.
-union _Jv_Self
-{
- char *vtable_ptr;
- jclass self;
-};
-
struct _Jv_MethodSymbol
{
_Jv_Utf8Const *class_name;
@@ -232,12 +225,7 @@ public:
// This constructor is used to create Class object for the primitive
// types. See prims.cc.
- Class ()
- {
- // 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.
- ((_Jv_Self *)this)->vtable_ptr -= 2 * sizeof (void *);
- }
+ Class ();
static java::lang::Class class$;
@@ -307,6 +295,7 @@ private:
_Jv_VTable *array_vtable = 0);
friend jclass _Jv_NewClass (_Jv_Utf8Const *name, jclass superclass,
java::lang::ClassLoader *loader);
+ friend void _Jv_InitNewClassFields (jclass klass);
// in prims.cc
friend void _Jv_InitPrimClass (jclass, char *, char, int, _Jv_ArrayVTable *);
diff --git a/libjava/java/lang/natClassLoader.cc b/libjava/java/lang/natClassLoader.cc
index ffe5b18..a6f7b60 100644
--- a/libjava/java/lang/natClassLoader.cc
+++ b/libjava/java/lang/natClassLoader.cc
@@ -61,6 +61,7 @@ java::lang::ClassLoader::defineClass0 (jstring name,
#ifdef INTERPRETER
jclass klass;
klass = (jclass) JvAllocObject (&ClassClass, sizeof (_Jv_InterpClass));
+ _Jv_InitNewClassFields (klass);
// synchronize on the class, so that it is not
// attempted initialized until we're done loading.
@@ -549,16 +550,13 @@ _Jv_FindClass (_Jv_Utf8Const *name, java::lang::ClassLoader *loader)
return klass;
}
-jclass
-_Jv_NewClass (_Jv_Utf8Const *name, jclass superclass,
- java::lang::ClassLoader *loader)
+void
+_Jv_InitNewClassFields (jclass ret)
{
- jclass ret = (jclass) JvAllocObject (&ClassClass);
-
ret->next = NULL;
- ret->name = name;
+ ret->name = NULL;
ret->accflags = 0;
- ret->superclass = superclass;
+ ret->superclass = NULL;
ret->constants.size = 0;
ret->constants.tags = NULL;
ret->constants.data = NULL;
@@ -571,7 +569,7 @@ _Jv_NewClass (_Jv_Utf8Const *name, jclass superclass,
ret->static_field_count = 0;
ret->vtable = NULL;
ret->interfaces = NULL;
- ret->loader = loader;
+ ret->loader = NULL;
ret->interface_count = 0;
ret->state = JV_STATE_NOTHING;
ret->thread = NULL;
@@ -579,6 +577,17 @@ _Jv_NewClass (_Jv_Utf8Const *name, jclass superclass,
ret->ancestors = NULL;
ret->idt = NULL;
ret->arrayclass = NULL;
+}
+
+jclass
+_Jv_NewClass (_Jv_Utf8Const *name, jclass superclass,
+ java::lang::ClassLoader *loader)
+{
+ jclass ret = (jclass) JvAllocObject (&ClassClass);
+ _Jv_InitNewClassFields (ret);
+ ret->name = name;
+ ret->superclass = superclass;
+ ret->loader = loader;
_Jv_RegisterClass (ret);