summaryrefslogtreecommitdiffstats
path: root/libjava/java/lang/ClassLoader.java
diff options
context:
space:
mode:
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2005-04-04 18:40:24 +0000
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2005-04-04 18:40:24 +0000
commita3857a178af208c7e54956bcc02d6433611e9be8 (patch)
treed4fa1a0589c9af574110daa317692041b9f2d10a /libjava/java/lang/ClassLoader.java
parent2b6f8cd0e3259dcebcbe286f72197d407a7797e4 (diff)
downloadppe42-gcc-a3857a178af208c7e54956bcc02d6433611e9be8.tar.gz
ppe42-gcc-a3857a178af208c7e54956bcc02d6433611e9be8.zip
* java/lang/ClassLoader.java (loadClass): Resolve class even if
it was already found. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@97565 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/java/lang/ClassLoader.java')
-rw-r--r--libjava/java/lang/ClassLoader.java32
1 files changed, 16 insertions, 16 deletions
diff --git a/libjava/java/lang/ClassLoader.java b/libjava/java/lang/ClassLoader.java
index f2beaac97f6..db68e60ba8d 100644
--- a/libjava/java/lang/ClassLoader.java
+++ b/libjava/java/lang/ClassLoader.java
@@ -285,28 +285,28 @@ public abstract class ClassLoader
{
// Have we already loaded this class?
Class c = findLoadedClass(name);
- if (c != null)
- return c;
-
- // Can the class be loaded by a parent?
- try
+ if (c == null)
{
- if (parent == null)
+ // Can the class be loaded by a parent?
+ try
{
- c = VMClassLoader.loadClass(name, resolve);
- if (c != null)
- return c;
+ if (parent == null)
+ {
+ c = VMClassLoader.loadClass(name, resolve);
+ if (c != null)
+ return c;
+ }
+ else
+ {
+ return parent.loadClass(name, resolve);
+ }
}
- else
+ catch (ClassNotFoundException e)
{
- return parent.loadClass(name, resolve);
}
+ // Still not found, we have to do it ourself.
+ c = findClass(name);
}
- catch (ClassNotFoundException e)
- {
- }
- // Still not found, we have to do it ourself.
- c = findClass(name);
if (resolve)
resolveClass(c);
return c;
OpenPOWER on IntegriCloud