diff options
-rw-r--r-- | libjava/ChangeLog | 13 | ||||
-rw-r--r-- | libjava/java/lang/Class.h | 15 | ||||
-rw-r--r-- | libjava/java/lang/natClassLoader.cc | 25 | ||||
-rw-r--r-- | libjava/prims.cc | 16 |
4 files changed, 43 insertions, 26 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog index ff59f96..aaebefa 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,5 +1,18 @@ 2001-12-16 Tom Tromey <tromey@redhat.com> + 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. + * Makefile.in: Rebuilt. * Makefile.am (ordinary_java_source_files): Removed old file; added new file. 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); diff --git a/libjava/prims.cc b/libjava/prims.cc index 40d1bd6..279e3ca 100644 --- a/libjava/prims.cc +++ b/libjava/prims.cc @@ -56,6 +56,7 @@ details. */ #include <java/lang/ArrayIndexOutOfBoundsException.h> #include <java/lang/ArithmeticException.h> #include <java/lang/ClassFormatError.h> +#include <java/lang/InternalError.h> #include <java/lang/NegativeArraySizeException.h> #include <java/lang/NullPointerException.h> #include <java/lang/OutOfMemoryError.h> @@ -533,8 +534,8 @@ _Jv_NewArray (jint type, jint size) case 10: return JvNewIntArray (size); case 11: return JvNewLongArray (size); } - JvFail ("newarray - bad type code"); - return NULL; // Placate compiler. + throw new java::lang::InternalError + (JvNewStringLatin1 ("invalid type code in _Jv_NewArray")); } // Allocate a possibly multi-dimensional array but don't check that @@ -613,9 +614,14 @@ _Jv_InitPrimClass (jclass cl, char *cname, char sig, int len, { using namespace java::lang::reflect; - // 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. + _Jv_InitNewClassFields (cl); + + // We must set the vtable for the class; the Java constructor + // doesn't do this. + (*(_Jv_VTable **) cl) = java::lang::Class::class$.vtable; + + // Initialize the fields we care about. We do this in the same + // order they are declared in Class.h. cl->name = _Jv_makeUtf8Const ((char *) cname, -1); cl->accflags = Modifier::PUBLIC | Modifier::FINAL | Modifier::ABSTRACT; cl->method_count = sig; |