diff options
author | tromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-04-22 02:33:31 +0000 |
---|---|---|
committer | tromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4> | 2005-04-22 02:33:31 +0000 |
commit | 4dd553338562a8a36301ac65f3267a24923d5ace (patch) | |
tree | 63043ece0a148eebb123acaf6ed4cf86b645fe45 /libjava/java | |
parent | 6f597a250919a2efc572c8e452981f024406f7eb (diff) | |
download | ppe42-gcc-4dd553338562a8a36301ac65f3267a24923d5ace.tar.gz ppe42-gcc-4dd553338562a8a36301ac65f3267a24923d5ace.zip |
* java/lang/natClass.cc (initializeClass): Link class.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@98540 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/java')
-rw-r--r-- | libjava/java/lang/natClass.cc | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/libjava/java/lang/natClass.cc b/libjava/java/lang/natClass.cc index b93694790bb..e29ed6809ef 100644 --- a/libjava/java/lang/natClass.cc +++ b/libjava/java/lang/natClass.cc @@ -703,7 +703,20 @@ java::lang::Class::initializeClass (void) JvSynchronize sync (this); if (state < JV_STATE_LINKED) - java::lang::VMClassLoader::resolveClass (this); + { + try + { + _Jv_Linker::wait_for_state(this, JV_STATE_LINKED); + } + catch (java::lang::Throwable *x) + { + // Turn into a NoClassDefFoundError. + java::lang::NoClassDefFoundError *result + = new java::lang::NoClassDefFoundError(getName()); + result->initCause(x); + throw result; + } + } // Step 2. java::lang::Thread *self = java::lang::Thread::currentThread(); |