+2001-10-23 Bryce McKinlay <bryce@waitaki.otago.ac.nz>
+
+ * prims.cc (_Jv_Abort): Always print error message using fprintf,
+ don't try to allocate.
+ (_Jv_CreateJavaVM): Set gcj::runTimeInitialized.
+ * include/jvm.h (gcj::runTimeInitialized): New variable declaration.
+ * java/lang/natClassLoader.cc (_Jv_RegisterClassHookDefault): Handle
+ duplicate class registration with JvFail if the runtime hasn't been
+ initialized yet.
+
2001-10-22 Tom Tromey <tromey@redhat.com>
* java/util/GregorianCalendar.java (getGregorianChange): Removed
extern _Jv_Utf8Const *clinit_name; /* "<clinit>" */
extern _Jv_Utf8Const *init_name; /* "<init>" */
extern _Jv_Utf8Const *finit_name; /* "finit$", */
+
+ /* Set to true by _Jv_CreateJavaVM. */
+ extern bool runtimeInitialized;
};
/* Type of pointer used as finalizer. */
#include <stdlib.h>
#include <string.h>
+#include <stdio.h>
#include <gcj/cni.h>
#include <jvm.h>
{
// If you get this, it means you have the same class in two
// different libraries.
- throw new java::lang::VirtualMachineError (JvNewStringLatin1 ("class registered twice"));
+ char *message;
+ asprintf (&message, "Duplicate class registration: %s",
+ klass->name->data);
+ if (! gcj::runtimeInitialized)
+ JvFail (message);
+ else
+ {
+ java::lang::String *str = JvNewStringLatin1 (message);
+ free (message);
+ throw new java::lang::VirtualMachineError (str);
+ }
}
check_class = check_class->next;
"libgcj failure: %s\n in function %s, file %s, line %d\n",
message, function, file, line);
#else
- java::io::PrintStream *err = java::lang::System::err;
- err->print(JvNewStringLatin1 ("libgcj failure: "));
- err->println(JvNewStringLatin1 (message));
- err->flush();
+ fprintf (stderr, "libgcj failure: %s\n", message);
#endif
abort ();
}
_Jv_Utf8Const *clinit_name;
_Jv_Utf8Const *init_name;
_Jv_Utf8Const *finit_name;
+
+ bool runtimeInitialized = false;
}
jint
{
using namespace gcj;
- static bool init = false;
-
- if (init)
+ if (runtimeInitialized)
return -1;
- init = true;
+ runtimeInitialized = true;
PROCESS_GCJ_PROPERTIES;