summaryrefslogtreecommitdiff
path: root/libjava/gnu
diff options
context:
space:
mode:
authorTom Tromey <tromey@redhat.com>2005-02-02 20:59:41 +0000
committerTom Tromey <tromey@gcc.gnu.org>2005-02-02 20:59:41 +0000
commit6d27fe75d0c3200470aa42595746c853240ff6e0 (patch)
tree549b32af6b15702bf023898cb2c6638202d540ed /libjava/gnu
parent7ded35b4c2c8ebf53faa42987703616e2a813421 (diff)
downloadgcc-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.java57
-rw-r--r--libjava/gnu/gcj/runtime/VMClassLoader.java50
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;