From 8ec9dee44ff6baa301f8f046e2cd8ed5c0da0559 Mon Sep 17 00:00:00 2001 From: Matthew Jason Benson Date: Fri, 18 Mar 2011 23:25:09 +0000 Subject: [PATCH] respect @javax.enterprise.util.Nonbinding git-svn-id: https://svn.apache.org/repos/asf/commons/proper/lang/trunk@1083107 13f79535-47bb-0310-9956-ffa450edef68 --- .../apache/commons/lang3/AnnotationUtils.java | 33 ++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/src/main/java/org/apache/commons/lang3/AnnotationUtils.java b/src/main/java/org/apache/commons/lang3/AnnotationUtils.java index 3c7693a9b..28a91e7d0 100644 --- a/src/main/java/org/apache/commons/lang3/AnnotationUtils.java +++ b/src/main/java/org/apache/commons/lang3/AnnotationUtils.java @@ -88,6 +88,27 @@ public class AnnotationUtils { }; + /** + * Statically cached class instance for the CDI Nonbinding annotation. + */ + private static final Class NONBINDING_ANNOTATION_TYPE; + static { + Class nonbindingAnnotationType = null; + try { + nonbindingAnnotationType = ClassUtils.getClass("javax.enterprise.util.Nonbinding"); + } catch (ClassNotFoundException e) { + } + if (nonbindingAnnotationType != null + && Annotation.class.isAssignableFrom(nonbindingAnnotationType)) { + //just checked: + @SuppressWarnings("unchecked") + Class stronglyTyped = (Class) nonbindingAnnotationType; + NONBINDING_ANNOTATION_TYPE = stronglyTyped; + } else { + NONBINDING_ANNOTATION_TYPE = null; + } + } + /** *

{@code AnnotationUtils} instances should NOT be constructed in * standard programming. Instead, the class should be used statically.

@@ -127,7 +148,8 @@ public class AnnotationUtils { try { for (Method m : type.getDeclaredMethods()) { if (m.getParameterTypes().length == 0 - && isValidAnnotationMemberType(m.getReturnType())) { + && isValidAnnotationMemberType(m.getReturnType()) + && !isNonbindingMember(m)) { Object v1 = m.invoke(a1); Object v2 = m.invoke(a2); if (!memberEquals(m.getReturnType(), v1, v2)) { @@ -359,4 +381,13 @@ public class AnnotationUtils { return Arrays.hashCode((Object[]) o); } + /** + * Helper method to look for the CDI Nonbinding annotation on an Annotation member. + * @param accessor the accessor method to check + * @return whether the Nonbinding annotation was found + */ + private static boolean isNonbindingMember(Method accessor) { + return NONBINDING_ANNOTATION_TYPE != null + && accessor.isAnnotationPresent(NONBINDING_ANNOTATION_TYPE); + } }