From 24d201cb540c56400a17b4fe0c265bf7324f2660 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Fri, 2 Nov 2018 18:49:10 -0700 Subject: [PATCH] 8213256: Clarify runtime vs compile time annotations for RoundEnvironment.getElementsAnnotatedWith(Class) Reviewed-by: jjg, jlahoda --- .../processing/RoundEnvironment.java | 31 +++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/src/java.compiler/share/classes/javax/annotation/processing/RoundEnvironment.java b/src/java.compiler/share/classes/javax/annotation/processing/RoundEnvironment.java index 9f7fb7f6f6b..b8c53c2df1d 100644 --- a/src/java.compiler/share/classes/javax/annotation/processing/RoundEnvironment.java +++ b/src/java.compiler/share/classes/javax/annotation/processing/RoundEnvironment.java @@ -143,11 +143,26 @@ public interface RoundEnvironment { * simply because a {@code module-info} file for that module was * created. * + *

Note: An implementation of this method typically performs + * an internal conversion from the runtime reflective + * representation of an annotation type as a {@code Class} object + * to a different representation used for annotation + * processing. The set of annotation types present in the runtime + * context may differ from the set of annotation types present in + * the context of annotation processing in a particular + * environmental configuration. If an runtime annotation type is + * not present in the annotation processing context, the situation + * is not treated as an error and no elements are found for that + * annotation type. + * * @param a annotation type being requested * @return the elements annotated with the given annotation type, * or an empty set if there are none * @throws IllegalArgumentException if the argument does not * represent an annotation type + * + * @see javax.lang.model.AnnotatedConstruct#getAnnotation(Class) + * @see javax.lang.model.AnnotatedConstruct#getAnnotationsByType(Class) */ Set getElementsAnnotatedWith(Class a); @@ -155,6 +170,18 @@ public interface RoundEnvironment { * Returns the elements annotated with one or more of the given * annotation types. * + *

Note: An implementation of this method typically performs + * an internal conversion from the runtime reflective + * representation of an annotation type as a {@code Class} object + * to a different representation used for annotation + * processing. The set of annotation types present in the runtime + * context may differ from the set of annotation types present in + * the context of annotation processing in a particular + * environmental configuration. If an runtime annotation type is + * not present in the annotation processing context, the situation + * is not treated as an error and no elements are found for that + * annotation type. + * * @apiNote This method may be useful when processing repeating * annotations by looking for an annotation type and its * containing annotation type at the same time. @@ -172,6 +199,10 @@ public interface RoundEnvironment { * @throws IllegalArgumentException if the any elements of the * argument set do not represent an annotation type * @jls 9.6.3 Repeatable Annotation Types + * + * @see javax.lang.model.AnnotatedConstruct#getAnnotation(Class) + * @see javax.lang.model.AnnotatedConstruct#getAnnotationsByType(Class) + * * @since 9 */ default Set getElementsAnnotatedWithAny(Set> annotations){