fix primitive class resolution to avoid mistaking normal classes with names like 'B' for primitive classes

This commit is contained in:
Joel Dice
2007-07-28 10:55:24 -06:00
parent 41bee5829e
commit abd9c2bc8d
16 changed files with 95 additions and 42 deletions

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Boolean {
public static final Class TYPE = Class.forName("Z");
public static final Class TYPE = Class.forCanonicalName("Z");
private final boolean value;

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Byte extends Number {
public static final Class TYPE = Class.forName("B");
public static final Class TYPE = Class.forCanonicalName("B");
private final byte value;

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Character {
public static final Class TYPE = Class.forName("C");
public static final Class TYPE = Class.forCanonicalName("C");
private final char value;

View File

@ -26,7 +26,28 @@ public final class Class <T> {
return new String(name, 0, name.length - 1, false);
}
public static native Class forName(String name);
public static native Class forName(String name)
throws ClassNotFoundException;
private static native Class primitiveClass(char name);
static Class forCanonicalName(String name) {
try {
if (name.startsWith("[")) {
return forName(name);
} else if (name.startsWith("L")) {
return forName(name.substring(1, name.length() - 1));
} else {
if (name.length() == 0) {
return primitiveClass(name.charAt(0));
} else {
throw new ClassNotFoundException(name);
}
}
} catch (ClassNotFoundException e) {
throw new RuntimeException(e);
}
}
public native boolean isAssignableFrom(Class c);

View File

@ -9,7 +9,7 @@ public class ClassLoader {
return instance;
}
public Class loadClass(String name) {
public Class loadClass(String name) throws ClassNotFoundException {
return Class.forName(name);
}
}

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Double {
public static final Class TYPE = Class.forName("D");
public static final Class TYPE = Class.forCanonicalName("D");
private final double value;

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Float extends Number {
public static final Class TYPE = Class.forName("F");
public static final Class TYPE = Class.forCanonicalName("F");
private final float value;

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Integer extends Number {
public static final Class TYPE = Class.forName("I");
public static final Class TYPE = Class.forCanonicalName("I");
private final int value;

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Long extends Number {
public static final Class TYPE = Class.forName("J");
public static final Class TYPE = Class.forCanonicalName("J");
private final long value;

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Short extends Number {
public static final Class TYPE = Class.forName("S");
public static final Class TYPE = Class.forCanonicalName("S");
private final short value;

View File

@ -4,10 +4,11 @@ import java.util.Map;
import java.util.WeakHashMap;
public class Thread implements Runnable {
private long peer;
private final Runnable task;
private Map<ThreadLocal, Object> locals;
private Object sleepLock;
private long peer;
private boolean interrupted;
public Thread(Runnable task) {
this.task = task;

View File

@ -1,7 +1,7 @@
package java.lang;
public final class Void {
public static final Class TYPE = Class.forName("V");
public static final Class TYPE = Class.forCanonicalName("V");
private Void() { }
}

View File

@ -51,31 +51,35 @@ public class Method<T> extends AccessibleObject implements Member {
String spec = new String(this.spec, 1, this.spec.length - 1, false);
for (int i = 0; i < spec.length(); ++i) {
char c = spec.charAt(i);
if (c == ')') {
break;
} else if (c == 'L') {
int start = i + 1;
i = next(';', spec, start);
String name = spec.substring(start, i);
types[index++] = Class.forName(name);
} else if (c == '[') {
int start = i;
while (spec.charAt(i) == '[') ++i;
if (spec.charAt(i) == 'L') {
i = next(';', spec, i + 1);
try {
for (int i = 0; i < spec.length(); ++i) {
char c = spec.charAt(i);
if (c == ')') {
break;
} else if (c == 'L') {
int start = i + 1;
i = next(';', spec, start);
String name = spec.substring(start, i);
types[index++] = Class.forName(name);
} else if (c == '[') {
int start = i;
while (spec.charAt(i) == '[') ++i;
if (spec.charAt(i) == 'L') {
i = next(';', spec, i + 1);
String name = spec.substring(start, i);
types[index++] = Class.forName(name);
} else {
String name = spec.substring(start, i + 1);
types[index++] = Class.forName(name);
}
} else {
String name = spec.substring(start, i + 1);
String name = spec.substring(i, i + 1);
types[index++] = Class.forName(name);
}
} else {
String name = spec.substring(i, i + 1);
types[index++] = Class.forName(name);
}
} catch (ClassNotFoundException e) {
throw new RuntimeException(e);
}
return types;