diff options
author | Bryce McKinlay <mckinlay@redhat.com> | 2006-06-01 07:45:55 +0000 |
---|---|---|
committer | Bryce McKinlay <bryce@gcc.gnu.org> | 2006-06-01 08:45:55 +0100 |
commit | 7d6d782d02ed4320a81e7e1d9caf526d583aae0a (patch) | |
tree | fc9999a1fb7eef2f890035a3561bfc6b284813d7 /libjava/gnu/java | |
parent | f3d5aeebf434fd8b5f500e138c12ba55aefde27b (diff) | |
download | gcc-7d6d782d02ed4320a81e7e1d9caf526d583aae0a.zip gcc-7d6d782d02ed4320a81e7e1d9caf526d583aae0a.tar.gz gcc-7d6d782d02ed4320a81e7e1d9caf526d583aae0a.tar.bz2 |
prims.cc (_Jv_RunMain): Use JvNewStringUTF for command-line class name, not Latin1.
2006-05-31 Bryce McKinlay <mckinlay@redhat.com>
* prims.cc (_Jv_RunMain): Use JvNewStringUTF for command-line class
name, not Latin1.
* gnu/java/lang/MainThread.java (run): Allow file separator char to
be used in place of '.' as class-name separator. Don't chain
ClassNotFoundException.
From-SVN: r114300
Diffstat (limited to 'libjava/gnu/java')
-rw-r--r-- | libjava/gnu/java/lang/MainThread.java | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/libjava/gnu/java/lang/MainThread.java b/libjava/gnu/java/lang/MainThread.java index c35359f..470de0c 100644 --- a/libjava/gnu/java/lang/MainThread.java +++ b/libjava/gnu/java/lang/MainThread.java @@ -39,6 +39,7 @@ exception statement from your version. */ package gnu.java.lang; +import java.io.File; import java.util.jar.Attributes; import java.util.jar.JarFile; @@ -91,13 +92,14 @@ final class MainThread extends Thread { try { - klass = Class.forName(klass_name, true, - ClassLoader.getSystemClassLoader()); + ClassLoader cl = ClassLoader.getSystemClassLoader(); + // Permit main class name to be specified in file-system format. + klass_name = klass_name.replace(File.separatorChar, '.'); + klass = cl.loadClass(klass_name); } catch (ClassNotFoundException x) { NoClassDefFoundError ncdfe = new NoClassDefFoundError(klass_name); - ncdfe.initCause(x); throw ncdfe; } } |