diff --git a/classpath/java/lang/reflect/Field.java b/classpath/java/lang/reflect/Field.java index 05512f108b..6ffc344d40 100644 --- a/classpath/java/lang/reflect/Field.java +++ b/classpath/java/lang/reflect/Field.java @@ -348,8 +348,13 @@ public class Field extends AccessibleObject { return (Annotation) a[0]; } + private boolean hasAnnotations() { + return vmField.addendum != null + && vmField.addendum.annotationTable != null; + } + public T getAnnotation(Class class_) { - if (vmField.addendum != null && vmField.addendum.annotationTable != null) { + if (hasAnnotations()) { Object[] table = (Object[]) vmField.addendum.annotationTable; for (int i = 0; i < table.length; ++i) { Object[] a = (Object[]) table[i]; @@ -362,7 +367,7 @@ public class Field extends AccessibleObject { } public Annotation[] getAnnotations() { - if (vmField.addendum.annotationTable != null) { + if (hasAnnotations()) { Object[] table = (Object[]) vmField.addendum.annotationTable; Annotation[] array = new Annotation[table.length]; for (int i = 0; i < table.length; ++i) { diff --git a/test/Reflection.java b/test/Reflection.java index 2a59548bec..96305010e1 100644 --- a/test/Reflection.java +++ b/test/Reflection.java @@ -252,6 +252,9 @@ public class Reflection { expect(avian.testing.annotations.Test.class.getPackage().getName().equals ("avian.testing.annotations")); + + expect(Baz.class.getField("foo").getAnnotation(Ann.class) == null); + expect(Baz.class.getField("foo").getAnnotations().length == 0); } protected static class Baz { @@ -280,3 +283,5 @@ interface A { } interface B extends A { } + +@interface Ann { }