natField.cc (BooleanClass): Don't define.
authorTom Tromey <tromey@cygnus.com>
Fri, 6 Oct 2000 01:49:32 +0000 (01:49 +0000)
committerTom Tromey <tromey@gcc.gnu.org>
Fri, 6 Oct 2000 01:49:32 +0000 (01:49 +0000)
* java/lang/reflect/natField.cc (BooleanClass): Don't define.
* java/lang/reflect/natArray.cc (BooleanClass): Don't define.
* java/lang/Class.h (Object): Added `class$' field.
* java/lang/Object.h (Object): Added `class$' field.
* defineclass.cc (ClassClass): Use `class$' form.
(ClassObject): Likewise.
* resolve.cc (ClassObject): Use `class$' form.
(ObjectClass): Likewise.
* interpret.cc (ClassError): Removed.
* java/net/natPlainDatagramSocketImpl.cc (BooleanClass): Use
`class$' form.
(IntegerClass): Likewise.
* java/net/natPlainSocketImpl.cc (BooleanClass): Use `class$'
form.
* java/lang/natClassLoader.cc (CloneableClass): Use `class$' form.
(ObjectClass, ClassClass, VMClassLoaderClass, ClassLoaderClass,
SerializableClass): Likewise.
Include Serializable.h, Cloneable.h.
* java/lang/natSystem.cc (SystemClass): Removed.
(init_properties): Use `class$' form.
* java/lang/natObject.cc (CloneableClass): Removed.
(clone): Use `class$' form.
* java/lang/natClass.cc (CloneableClass): Use `class$' form.
(ObjectClass, ErrorClass, ClassClass, MethodClass, FieldClass,
ConstructorClass): Likewise.
* java/lang/reflect/natMethod.cc (ObjectClass): Use `class$' form.
(ClassClass, VoidClass, ByteClass, ShortClass, CharacterClass,
IntegerClass, LongClass, FloatClass, DoubleClass): Likewise.
* java/io/natObjectInputStream.cc (ObjectClass): Use `class$'
form.
(ClassClass): Likewise.
* include/jvm.h (StringClass): Use `class$' form.
* prims.cc (ObjectClass): Removed.
(_Jv_RunMain): Use `class$' form.
(_Jv_AllocObject): Likewise.
* jni.cc (ClassClass): Use `class$' form.
(ThrowableClass): Likewise.
(ObjectClass): Likewise.
(MethodClass): Likewise.
(ThreadGroupClass): Likewise.
(NativeThreadClass): Likewise.
* boehm.cc (ObjectClass): Removed.
(ClassClass): Removed.
(_Jv_MarkObj): Use `class$' form.
* gcj/field.h (JvFieldIsRef): Use `class$' form.
Include RawData.h.

From-SVN: r36740

21 files changed:
libjava/ChangeLog
libjava/boehm.cc
libjava/defineclass.cc
libjava/gcj/field.h
libjava/include/jvm.h
libjava/interpret.cc
libjava/java/io/natObjectInputStream.cc
libjava/java/lang/Class.h
libjava/java/lang/Object.h
libjava/java/lang/natClass.cc
libjava/java/lang/natClassLoader.cc
libjava/java/lang/natObject.cc
libjava/java/lang/natSystem.cc
libjava/java/lang/reflect/natArray.cc
libjava/java/lang/reflect/natField.cc
libjava/java/lang/reflect/natMethod.cc
libjava/java/net/natPlainDatagramSocketImpl.cc
libjava/java/net/natPlainSocketImpl.cc
libjava/jni.cc
libjava/prims.cc
libjava/resolve.cc

index f85f295..b93bb7d 100644 (file)
@@ -1,3 +1,52 @@
+2000-10-05  Tom Tromey  <tromey@cygnus.com>
+
+       * java/lang/reflect/natField.cc (BooleanClass): Don't define.
+       * java/lang/reflect/natArray.cc (BooleanClass): Don't define.
+       * java/lang/Class.h (Object): Added `class$' field.
+       * java/lang/Object.h (Object): Added `class$' field.
+       * defineclass.cc (ClassClass): Use `class$' form.
+       (ClassObject): Likewise.
+       * resolve.cc (ClassObject): Use `class$' form.
+       (ObjectClass): Likewise.
+       * interpret.cc (ClassError): Removed.
+       * java/net/natPlainDatagramSocketImpl.cc (BooleanClass): Use
+       `class$' form.
+       (IntegerClass): Likewise.
+       * java/net/natPlainSocketImpl.cc (BooleanClass): Use `class$'
+       form.
+       * java/lang/natClassLoader.cc (CloneableClass): Use `class$' form.
+       (ObjectClass, ClassClass, VMClassLoaderClass, ClassLoaderClass,
+       SerializableClass): Likewise.
+       Include Serializable.h, Cloneable.h.
+       * java/lang/natSystem.cc (SystemClass): Removed.
+       (init_properties): Use `class$' form.
+       * java/lang/natObject.cc (CloneableClass): Removed.
+       (clone): Use `class$' form.
+       * java/lang/natClass.cc (CloneableClass): Use `class$' form.
+       (ObjectClass, ErrorClass, ClassClass, MethodClass, FieldClass,
+       ConstructorClass): Likewise.
+       * java/lang/reflect/natMethod.cc (ObjectClass): Use `class$' form.
+       (ClassClass, VoidClass, ByteClass, ShortClass, CharacterClass,
+       IntegerClass, LongClass, FloatClass, DoubleClass): Likewise.
+       * java/io/natObjectInputStream.cc (ObjectClass): Use `class$'
+       form.
+       (ClassClass): Likewise.
+       * include/jvm.h (StringClass): Use `class$' form.
+       * prims.cc (ObjectClass): Removed.
+       (_Jv_RunMain): Use `class$' form.
+       (_Jv_AllocObject): Likewise.
+       * jni.cc (ClassClass): Use `class$' form.
+       (ThrowableClass): Likewise.
+       (ObjectClass): Likewise.
+       (MethodClass): Likewise.
+       (ThreadGroupClass): Likewise.
+       (NativeThreadClass): Likewise.
+       * boehm.cc (ObjectClass): Removed.
+       (ClassClass): Removed.
+       (_Jv_MarkObj): Use `class$' form.
+       * gcj/field.h (JvFieldIsRef): Use `class$' form.
+       Include RawData.h.
+
 2000-10-05  Warren Levy  <warrenl@cygnus.com>
 
        * Makefile.am: Removed java/io/Replaceable.java and
index f0d679c..877d97c 100644 (file)
@@ -49,11 +49,6 @@ extern "C"
          && (ptr_t) (Obj) <= GC_greatest_plausible_heap_addr) \
         PUSH_CONTENTS (Obj, Top, Limit, Source, Exit)
 
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-#define ClassClass _CL_Q34java4lang5Class
-extern java::lang::Class ClassClass;
-
 \f
 
 // Nonzero if this module has been initialized.
@@ -110,7 +105,7 @@ _Jv_MarkObj (void *addr, void *msp, void *msl, void * /* env */)
   p = (ptr_t) klass;
   MAYBE_MARK (p, mark_stack_ptr, mark_stack_limit, obj, o2label);
 
-  if (__builtin_expect (klass == &ClassClass, false))
+  if (__builtin_expect (klass == &java::lang::Class::class$, false))
     {
       // Currently we allocate some of the memory referenced from class objects
       // as pointerfree memory, and then mark it more intelligently here.
@@ -263,7 +258,7 @@ _Jv_MarkObj (void *addr, void *msp, void *msl, void * /* env */)
       // Note: occasionally `klass' can be null.  For instance, this
       // can happen if a GC occurs between the point where an object
       // is allocated and where the vtbl slot is set.
-      while (klass && klass != &ObjectClass)
+      while (klass && klass != &java::lang::Object::class$)
        {
          jfieldID field = JvGetFirstInstanceField (klass);
          jint max = JvNumInstanceFields (klass);
index 7ddead0..06ca162 100644 (file)
@@ -43,11 +43,6 @@ details.  */
 #include <java/lang/IncompatibleClassChangeError.h>
 #include <java/lang/reflect/Modifier.h>
 
-#define ClassClass _CL_Q34java4lang5Class
-extern java::lang::Class ClassClass;
-#define ClassObject _CL_Q34java4lang6Object
-extern java::lang::Class ClassObject;
-
 // we don't verify method names that match these.
 static _Jv_Utf8Const *clinit_name = _Jv_makeUtf8Const ("<clinit>", 8);
 static _Jv_Utf8Const *init_name = _Jv_makeUtf8Const ("<init>", 6);
@@ -864,11 +859,12 @@ _Jv_ClassReader::handleClassBegin
       // interfaces have java.lang.Object as super.
       if (access_flags & Modifier::INTERFACE)
        {
-         def->superclass = (jclass)&ClassObject;
+         def->superclass = (jclass)&java::lang::Class::class$;
        }
 
       // FIXME: Consider this carefully!  
-      else if (!_Jv_equalUtf8Consts (def->name, ClassObject.name))
+      else if (!_Jv_equalUtf8Consts (def->name,
+                                    java::lang::Class::class$.name))
        {
          throw_no_class_def_found_error ("loading java.lang.Object");
        }
index 0ad381c..9279c83 100644 (file)
@@ -14,6 +14,7 @@ details.  */
 #include <java/lang/Class.h>
 #include <java/lang/reflect/Field.h>
 #include <java/lang/reflect/Modifier.h>
+#include <gnu/gcj/RawData.h>
 
 #define _Jv_FIELD_UNRESOLVED_FLAG      0x8000
 #define        _Jv_FIELD_CONSTANT_VALUE        0x4000
@@ -179,9 +180,7 @@ JvNumStaticFields (jclass klass)
 extern inline jboolean
 JvFieldIsRef (jfieldID field)
 {
-  // gnu.gcj.RawData.class is  _CL_Q33gnu3gcj7RawData
-  extern java::lang::Class _CL_Q33gnu3gcj7RawData;
-  return field->isRef () && field->type != &_CL_Q33gnu3gcj7RawData;
+  return field->isRef () && field->type != &gnu::gcj::RawData::class$;
 }
 
 extern inline jobject
index 8d93ed5..f453c9c 100644 (file)
@@ -102,8 +102,8 @@ extern jboolean _Jv_equalUtf8Consts (_Jv_Utf8Const *, _Jv_Utf8Const *);
 extern jboolean _Jv_equal (_Jv_Utf8Const *, jstring, jint);
 extern jboolean _Jv_equaln (_Jv_Utf8Const *, jstring, jint);
 
-#define StringClass _CL_Q34java4lang6String
-extern java::lang::Class StringClass;
+// FIXME: remove this define.
+#define StringClass java::lang::String::class$
 
 /* Type of pointer used as finalizer.  */
 typedef void _Jv_FinalizerFunc (jobject);
index 74e8788..7f2ad62 100644 (file)
@@ -39,9 +39,6 @@ details.  */
 #include <alloca.h>
 #endif
 
-#define ClassError _CL_Q34java4lang5Error
-extern java::lang::Class ClassError;
-
 static _Jv_Utf8Const *init_name = _Jv_makeUtf8Const ("<init>", 6);
 
 static void throw_internal_error (char *msg)
index b7a8dcb..8b5151d 100644 (file)
@@ -1,6 +1,6 @@
 // natObjectInputStream.cc - Native part of ObjectInputStream class.
 
-/* Copyright (C) 1998, 1999  Free Software Foundation
+/* Copyright (C) 1998, 1999, 2000  Free Software Foundation
 
    This ObjectInputStream is part of libgcj.
 
@@ -46,10 +46,8 @@ java::io::ObjectInputStream::allocateObject (jclass klass)
 }
 
 
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-#define ClassClass _CL_Q34java4lang5Class
-extern java::lang::Class ClassClass;
+#define ObjectClass java::lang::Object::class$
+#define ClassClass java::lang::Class::class$
 
 void 
 java::io::ObjectInputStream::callConstructor (jclass klass, jobject obj)
index 0300a59..0f26c54 100644 (file)
@@ -190,6 +190,8 @@ public:
   // finalization
   void finalize ();
 
+  static java::lang::Class class$;
+
 private:   
 
   void checkMemberAccess (jint flags);
index 2ed6d15..21e8fb0 100644 (file)
@@ -57,6 +57,8 @@ public:
   friend JV_MARKARRAY_DECL;
 #endif
 
+  static java::lang::Class class$;
+
 protected:
   virtual jobject clone (void);
   virtual void finalize (void);
index 1b40373..e3d4785 100644 (file)
@@ -51,20 +51,14 @@ details.  */
 
 \f
 
-#define CloneableClass _CL_Q34java4lang9Cloneable
-extern java::lang::Class CloneableClass;
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-#define ErrorClass _CL_Q34java4lang5Error
-extern java::lang::Class ErrorClass;
-#define ClassClass _CL_Q34java4lang5Class
-extern java::lang::Class ClassClass;
-#define MethodClass _CL_Q44java4lang7reflect6Method
-extern java::lang::Class MethodClass;
-#define FieldClass _CL_Q44java4lang7reflect5Field
-extern java::lang::Class FieldClass;
-#define ConstructorClass _CL_Q44java4lang7reflect11Constructor
-extern java::lang::Class ConstructorClass;
+// FIXME: remove these.
+#define CloneableClass java::lang::Cloneable::class$
+#define ObjectClass java::lang::Object::class$
+#define ErrorClass java::lang::Error::class$
+#define ClassClass java::lang::Class::class$
+#define MethodClass java::lang::reflect::Method::class$
+#define FieldClass java::lang::reflect::Field::class$
+#define ConstructorClass java::lang::reflect::Constructor::class$
 
 // Some constants we use to look up the class initializer.
 static _Jv_Utf8Const *void_signature = _Jv_makeUtf8Const ("()V", 3);
index b03b8c2..f1704ed 100644 (file)
@@ -35,19 +35,17 @@ details.  */
 #include <java/lang/IncompatibleClassChangeError.h>
 #include <java/lang/reflect/Modifier.h>
 #include <java/lang/Runtime.h>
+#include <java/io/Serializable.h>
+#include <java/lang/Cloneable.h>
+
+// FIXME: remove these.
+#define CloneableClass java::lang::Cloneable::class$
+#define ObjectClass java::lang::Object::class$
+#define ClassClass java::lang::Class::class$
+#define VMClassLoaderClass gnu::gcj::runtime::VMClassLoader::class$
+#define ClassLoaderClass java::lang::ClassLoader::class$
+#define SerializableClass java::io::Serializable::class$
 
-#define CloneableClass _CL_Q34java4lang9Cloneable
-extern java::lang::Class CloneableClass;
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-#define ClassClass _CL_Q34java4lang5Class
-extern java::lang::Class ClassClass;
-#define VMClassLoaderClass _CL_Q34java4lang17VMClassLoader
-extern java::lang::Class VMClassLoader;
-#define ClassLoaderClass _CL_Q34java4lang11ClassLoader
-extern java::lang::Class ClassLoaderClass;
-#define SerializableClass _CL_Q34java2io12Serializable
-extern java::lang::Class SerializableClass;
 /////////// java.lang.ClassLoader native methods ////////////
 
 java::lang::ClassLoader *
index 26b3f96..43201f6 100644 (file)
@@ -28,9 +28,6 @@ details.  */
 #include <java/lang/Cloneable.h>
 #include <java/lang/Thread.h>
 
-#define CloneableClass _CL_Q34java4lang9Cloneable
-extern java::lang::Class CloneableClass;
-
 \f
 
 // This is used to represent synchronization information.
@@ -92,7 +89,7 @@ java::lang::Object::clone (void)
     }
   else
     {
-      if (! CloneableClass.isAssignableFrom(klass))
+      if (! java::lang::Cloneable::class$.isAssignableFrom(klass))
        JvThrow (new CloneNotSupportedException);
 
       size = klass->size();
index 0022e2e..35198fb 100644 (file)
@@ -41,9 +41,6 @@ details.  */
 #include <java/io/PrintStream.h>
 #include <java/io/InputStream.h>
 
-#define SystemClass _CL_Q34java4lang6System
-extern java::lang::Class SystemClass;
-
 \f
 
 void
@@ -222,7 +219,7 @@ java::lang::System::init_properties (void)
 {
   {
     // We only need to synchronize around this gatekeeper.
-    JvSynchronize sync (&SystemClass);
+    JvSynchronize sync (&java::lang::System::class$);
     if (prop_init)
       return;
     prop_init = true;
index 4bce9ce..b5a2124 100644 (file)
@@ -25,9 +25,6 @@ details.  */
 #include <java/lang/Boolean.h>
 #include <java/lang/Character.h>
 
-#define BooleanClass _CL_Q34java4lang7Boolean
-extern java::lang::Class BooleanClass;
-
 jobject
 java::lang::reflect::Array::newInstance (jclass componentType, jint length)
 {
@@ -215,7 +212,7 @@ java::lang::reflect::Array::get (jobject array, jint index)
     return new java::lang::Character (elements ((jcharArray) array) [index]);
   if (elementType == JvPrimClass (boolean))
     {
-      _Jv_InitClass (&BooleanClass);
+      _Jv_InitClass (&java::lang::Boolean::class$);
       if (elements ((jbooleanArray) array) [index])
        return java::lang::Boolean::TRUE;
       else
index 3cd296c..57421d6 100644 (file)
@@ -1,6 +1,6 @@
 // natField.cc - Implementation of java.lang.reflect.Field native methods.
 
-/* Copyright (C) 1998, 1999  Free Software Foundation
+/* Copyright (C) 1998, 1999, 2000  Free Software Foundation
 
    This file is part of libgcj.
 
@@ -26,9 +26,6 @@ details.  */
 #include <java/lang/Boolean.h>
 #include <java/lang/Character.h>
 
-#define BooleanClass _CL_Q34java4lang7Boolean
-extern java::lang::Class BooleanClass;
-
 jint
 java::lang::reflect::Field::getModifiers ()
 {
@@ -255,7 +252,7 @@ java::lang::reflect::Field::get (jclass caller, jobject obj)
     return new java::lang::Character (* (jchar*) addr);
   if (fld->type == JvPrimClass (boolean))
     {
-      _Jv_InitClass (&BooleanClass);
+      _Jv_InitClass (&java::lang::Boolean::class$);
       if (* (jboolean*) addr)
        return java::lang::Boolean::TRUE;
       else
index 0f829de..0e83e0d 100644 (file)
@@ -38,31 +38,23 @@ details.  */
 #include <gcj/method.h>
 #include <gnu/gcj/RawData.h>
 
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-#define ClassClass _CL_Q34java4lang5Class
-extern java::lang::Class ClassClass;
+// FIXME: remove these
+#define ObjectClass java::lang::Object::class$
+#define ClassClass java::lang::Class::class$
 
 #include <stdlib.h>
 
 #include <ffi.h>
 
-#define VoidClass _CL_Q34java4lang4Void
-extern java::lang::Class VoidClass;
-#define ByteClass _CL_Q34java4lang4Byte
-extern java::lang::Class ByteClass;
-#define ShortClass _CL_Q34java4lang5Short
-extern java::lang::Class ShortClass;
-#define CharacterClass _CL_Q34java4lang9Character
-extern java::lang::Class CharacterClass;
-#define IntegerClass _CL_Q34java4lang7Integer
-extern java::lang::Class IntegerClass;
-#define LongClass _CL_Q34java4lang4Long
-extern java::lang::Class LongClass;
-#define FloatClass _CL_Q34java4lang5Float
-extern java::lang::Class FloatClass;
-#define DoubleClass _CL_Q34java4lang6Double
-extern java::lang::Class DoubleClass;
+// FIXME: remove these.
+#define VoidClass java::lang::Void::class$
+#define ByteClass java::lang::Byte::class$
+#define ShortClass java::lang::Short::class$
+#define CharacterClass java::lang::Character::class$
+#define IntegerClass java::lang::Integer::class$
+#define LongClass java::lang::Long::class$
+#define FloatClass java::lang::Float::class$
+#define DoubleClass java::lang::Double::class$
 
 struct cpair
 {
index 808fd01..6934f09 100644 (file)
@@ -50,10 +50,9 @@ details.  */
 #include <java/lang/Boolean.h>
 #include <java/lang/Integer.h>
 
-#define BooleanClass _CL_Q34java4lang7Boolean
-extern java::lang::Class BooleanClass;
-#define IntegerClass _CL_Q34java4lang7Integer
-extern java::lang::Class IntegerClass;
+// FIXME: remove these
+#define BooleanClass java::lang::Boolean::class$
+#define IntegerClass java::lang::Integer::class$
 
 #ifdef DISABLE_JAVA_NET
 
index ff7d8a3..3c6bc39 100644 (file)
@@ -49,8 +49,7 @@ details.  */
 #include <java/lang/Class.h>
 #include <java/lang/Integer.h>
 
-#define BooleanClass _CL_Q34java4lang7Boolean
-extern java::lang::Class BooleanClass;
+#define BooleanClass java::lang::Boolean::class$
 
 #ifdef DISABLE_JAVA_NET
 
index db13cdf..d4040b2 100644 (file)
@@ -46,19 +46,13 @@ details.  */
 
 #include <java-interp.h>
 
-#define ClassClass _CL_Q34java4lang5Class
-extern java::lang::Class ClassClass;
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-
-#define ThrowableClass _CL_Q34java4lang9Throwable
-extern java::lang::Class ThrowableClass;
-#define MethodClass _CL_Q44java4lang7reflect6Method
-extern java::lang::Class MethodClass;
-#define ThreadGroupClass _CL_Q34java4lang11ThreadGroup
-extern java::lang::Class ThreadGroupClass;
-#define NativeThreadClass _CL_Q43gnu3gcj3jni12NativeThread
-extern java::lang::Class ThreadGroupClass;
+// FIXME: remove these defines.
+#define ClassClass java::lang::Class::class$
+#define ObjectClass java::lang::Object::class$
+#define ThrowableClass java::lang::Throwable::class$
+#define MethodClass java::lang::reflect::Method::class$
+#define ThreadGroupClass java::lang::ThreadGroup::class$
+#define NativeThreadClass gnu::gcj::jni::NativeThread::class$
 
 // This enum is used to select different template instantiations in
 // the invocation code.
index ef88190..8ca05da 100644 (file)
@@ -67,9 +67,6 @@ details.  */
 #include <ltdl.h>
 #endif
 
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-
 // We allocate a single OutOfMemoryError exception which we keep
 // around for use if we run out of memory.
 static java::lang::OutOfMemoryError *no_memory;
@@ -358,7 +355,8 @@ _Jv_AllocObject (jclass klass, jint size)
   // implementation would look for Object.finalize in Object's method
   // table at startup, and then use that information to find the
   // appropriate index in the method vector.
-  if (klass->vtable->get_finalizer() != ObjectClass.vtable->get_finalizer())
+  if (klass->vtable->get_finalizer()
+      != java::lang::Object::class$.vtable->get_finalizer())
     _Jv_RegisterFinalizer (obj, _Jv_FinalizeObject);
 
 #ifdef ENABLE_JVMPI
@@ -915,7 +913,7 @@ _Jv_RunMain (const char *name, int argc, const char **argv, bool is_jar)
       arg_vec = JvConvertArgv (1, &_Jv_Jar_Class_Path);
 
       main_thread = 
-       new gnu::gcj::runtime::FirstThread (&_CL_Q43gnu3gcj7runtime11FirstThread,
+       new gnu::gcj::runtime::FirstThread (&gnu::gcj::runtime::FirstThread::class$,
                                            arg_vec);
       main_thread->start();
       _Jv_ThreadWait ();
index 898de51..4a37365 100644 (file)
@@ -41,11 +41,6 @@ static void throw_class_format_error (jstring msg)
 static void throw_class_format_error (char *msg)
        __attribute__ ((__noreturn__));
 
-#define ClassObject _CL_Q34java4lang6Object
-extern java::lang::Class ClassObject;
-#define ObjectClass _CL_Q34java4lang6Object
-extern java::lang::Class ObjectClass;
-
 // Exceptional return values for _Jv_DetermineVTableIndex
 #define METHOD_NOT_THERE (-2)
 #define METHOD_INACCESSIBLE (-1)
@@ -809,7 +804,8 @@ _Jv_InitField (jobject obj, jclass klass, int index)
       /* fall through */
 
     case JV_CONSTANT_ResolvedString:
-      if (! (field->type == &StringClass || field->type == &ObjectClass))
+      if (! (field->type == &StringClass
+            || field->type == &java::lang::Class::class$))
        throw_class_format_error ("string initialiser to non-string field");
 
       *(jstring*)addr = pool->data[init].string;