diff --git a/classpath/java/lang/Class.java b/classpath/java/lang/Class.java index 96c880ef72..4a500533b4 100644 --- a/classpath/java/lang/Class.java +++ b/classpath/java/lang/Class.java @@ -539,7 +539,7 @@ public final class Class if (skipDigits == chars.length) { return ClassType.ANONYMOUS; - } else if (skipDigits > dollar + 1) { + } else if (skipDigits == dollar + 1) { return ClassType.MEMBER; } else { return ClassType.LOCAL; diff --git a/test/Reflection.java b/test/Reflection.java index 7f0398ef81..39dc5c85a8 100644 --- a/test/Reflection.java +++ b/test/Reflection.java @@ -98,15 +98,31 @@ public class Reflection { expect(1 == args.length); expect(args[0] == String.class); } - + public static void throwOOME() { throw new OutOfMemoryError(); } + public static void classType() throws Exception { + // Class types + expect(!Reflection.class.isAnonymousClass()); + expect(!Reflection.class.isLocalClass()); + expect(!Reflection.class.isMemberClass()); + + expect(Reflection.Hello.class.isMemberClass()); + + Cloneable anonymousLocal = new Cloneable() {}; + expect(anonymousLocal.getClass().isAnonymousClass()); + + class NamedLocal {} + expect(NamedLocal.class.isLocalClass()); + } + public static void main(String[] args) throws Exception { innerClasses(); annotations(); genericType(); + classType(); Class system = Class.forName("java.lang.System"); Field out = system.getDeclaredField("out");