From 75dda146912d307e39f394249d04fe3d078914d3 Mon Sep 17 00:00:00 2001 From: Ilya Mizus Date: Sat, 11 Oct 2014 23:36:14 +0400 Subject: [PATCH 1/2] Fixed small bug in getClassType() function. --- classpath/java/lang/Class.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) 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; From ecce49be5da0aa0fa1566b4c16bbd78230f73075 Mon Sep 17 00:00:00 2001 From: Ilya Mizus Date: Sat, 11 Oct 2014 23:50:53 +0400 Subject: [PATCH 2/2] Added some tests for class types --- test/Reflection.java | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) 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");