diff options
author | Tom Tromey <tromey@redhat.com> | 2005-02-02 20:59:41 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2005-02-02 20:59:41 +0000 |
commit | 6d27fe75d0c3200470aa42595746c853240ff6e0 (patch) | |
tree | 549b32af6b15702bf023898cb2c6638202d540ed /libjava/gnu | |
parent | 7ded35b4c2c8ebf53faa42987703616e2a813421 (diff) | |
download | gcc-6d27fe75d0c3200470aa42595746c853240ff6e0.tar.gz |
re PR libgcj/19681 (extension loading currently incorrect)
PR libgcj/19681:
* Makefile.in: Rebuilt.
* Makefile.am (ordinary_java_source_files): Added new class.
* java/lang/natVMClassLoader.cc (getSystemClassLoaderInternal):
Use system_instance, not instance.
* gnu/gcj/runtime/SystemClassLoader.java: New file.
* gnu/gcj/runtime/VMClassLoader.java (init): Don't search
java.class.path.
(system_instance): New field.
(initialize): Initialize the system loader as well.
(VMClassLoader): Default to LIB_CACHE.
From-SVN: r94611
Diffstat (limited to 'libjava/gnu')
-rw-r--r-- | libjava/gnu/gcj/runtime/SystemClassLoader.java | 57 | ||||
-rw-r--r-- | libjava/gnu/gcj/runtime/VMClassLoader.java | 50 |
2 files changed, 72 insertions, 35 deletions
diff --git a/libjava/gnu/gcj/runtime/SystemClassLoader.java b/libjava/gnu/gcj/runtime/SystemClassLoader.java new file mode 100644 index 00000000000..163d3dd84d7 --- /dev/null +++ b/libjava/gnu/gcj/runtime/SystemClassLoader.java @@ -0,0 +1,57 @@ +/* Copyright (C) 2005 Free Software Foundation + + This file is part of libgcj. + +This software is copyrighted work licensed under the terms of the +Libgcj License. Please consult the file "LIBGCJ_LICENSE" for +details. */ + +package gnu.gcj.runtime; + +import java.io.*; +import java.util.StringTokenizer; +import java.util.HashSet; +import java.net.URL; +import java.net.URLClassLoader; + +public final class SystemClassLoader extends URLClassLoader +{ + SystemClassLoader(ClassLoader parent) + { + super(new URL[0], parent); + } + + // We add the URLs to the system class loader late. The reason for + // this is that during bootstrap we don't want to parse URLs or + // create URL connections, since that will result in circularities + // causing a crash. + void init() + { + StringTokenizer st + = new StringTokenizer (System.getProperty ("java.class.path", "."), + File.pathSeparator); + while (st.hasMoreElements ()) + { + String e = st.nextToken (); + try + { + if ("".equals(e)) + e = "."; + + File path = new File(e); + // Ignore invalid paths. + if (!path.exists()) + continue; + if (!e.endsWith (File.separator) && path.isDirectory ()) + addURL(new URL("file", "", -1, e + File.separator)); + else + addURL(new URL("file", "", -1, e)); + } + catch (java.net.MalformedURLException x) + { + // This should never happen. + throw new RuntimeException(x); + } + } + } +} diff --git a/libjava/gnu/gcj/runtime/VMClassLoader.java b/libjava/gnu/gcj/runtime/VMClassLoader.java index 2d46ebcb770..1ded892a06d 100644 --- a/libjava/gnu/gcj/runtime/VMClassLoader.java +++ b/libjava/gnu/gcj/runtime/VMClassLoader.java @@ -14,8 +14,12 @@ import java.io.*; import java.util.StringTokenizer; import java.util.HashSet; import java.net.URL; +import java.net.URLClassLoader; -public final class VMClassLoader extends java.net.URLClassLoader +// Despite its name, this class is really the extension loader for +// libgcj. Class loader bootstrap is a bit tricky, see prims.cc and +// SystemClassLoader for some details. +public final class VMClassLoader extends URLClassLoader { private VMClassLoader () { @@ -28,44 +32,17 @@ public final class VMClassLoader extends java.net.URLClassLoader else if ("cache".equals(p)) lib_control = LIB_CACHE; else if ("full".equals(p)) - { - // In case we ever want to change the default. - lib_control = LIB_FULL; - } - else lib_control = LIB_FULL; + else + lib_control = LIB_CACHE; } private void init() { - StringTokenizer st - = new StringTokenizer (System.getProperty ("java.class.path", "."), - System.getProperty ("path.separator", ":")); - - while (st.hasMoreElements ()) - { - String e = st.nextToken (); - try - { - File path = new File(e); - // Ignore invalid paths. - if (!path.exists()) - continue; - if (!e.endsWith (File.separator) && path.isDirectory ()) - addURL(new URL("file", "", -1, e + File.separator)); - else - addURL(new URL("file", "", -1, e)); - } - catch (java.net.MalformedURLException x) - { - // This should never happen. - throw new RuntimeException(x); - } - } - // Add the contents of the extensions directories. - st = new StringTokenizer (System.getProperty ("java.ext.dirs"), - System.getProperty ("path.separator", ":")); + StringTokenizer st + = new StringTokenizer (System.getProperty ("java.ext.dirs"), + File.pathSeparator); try { @@ -91,8 +68,8 @@ public final class VMClassLoader extends java.net.URLClassLoader } } - // Add core:/ to the end of the java.class.path so any resources - // compiled into this executable may be found. + // Add core:/ to the end so any resources compiled into this + // executable may be found. addURL(new URL("core", "", -1, "/")); } catch (java.net.MalformedURLException x) @@ -116,6 +93,7 @@ public final class VMClassLoader extends java.net.URLClassLoader static void initialize () { instance.init(); + system_instance.init(); } // Define a package for something loaded natively. @@ -148,6 +126,8 @@ public final class VMClassLoader extends java.net.URLClassLoader // The only VMClassLoader that can exist. static VMClassLoader instance = new VMClassLoader(); + // The system class loader. + static SystemClassLoader system_instance = new SystemClassLoader(instance); private static final int LIB_FULL = 0; private static final int LIB_CACHE = 1; |