Details
-
Bug
-
Resolution: Fixed
-
P3
-
8
-
b122
Backports
Issue | Fix Version | Assignee | Priority | Status | Resolution | Resolved In Build |
---|---|---|---|---|---|---|
JDK-8030876 | 9 | Joe Darcy | P3 | Resolved | Fixed | b01 |
JDK-8031280 | 8u5 | Joe Darcy | P3 | Resolved | Fixed | b03 |
Description
Per the discussion of compatibility at http://mail.openjdk.java.net/pipermail/enhanced-metadata-spec-discuss/2013-January/000140.html, the interface-level javadoc of AnnotatedElement should say:
--
If an annotation of type T is present on an element, and T is made repeatable, then adding more annotations of type T to the element is source compatible and binary compatible.
It is not behaviorally compatible for the get[Declared]Annotation(Class<T>) methods and get[Declared]Annotations() methods, because they will now see only a container annotation on the element rather than any annotation of type T.
It is not behaviorally compatible for the get[Declared]AnnotationsByType(Class<T>) methods, because their results will expose the additional annotations of type T whereas previously they exposed only a single annotation of type T.
If an annotation of type TC is present on an element, then making
some other annotation type T repeatable (with TC as its containing annotation type) is source compatible and binary compatible.
It is behaviorally compatible for the get[Declared]Annotation(Class<T>) methods and get[Declared]Annotations() methods, in that their results will not change just because TC is a containing annotation type.
However, it is not behaviorally compatible for the get[Declared]AnnotationsByType(Class<T>) methods, because they will now recognize an annotation of type TC as a container annotation and "look through" it to expose annotations of type T.
--
--
If an annotation of type T is present on an element, and T is made repeatable, then adding more annotations of type T to the element is source compatible and binary compatible.
It is not behaviorally compatible for the get[Declared]Annotation(Class<T>) methods and get[Declared]Annotations() methods, because they will now see only a container annotation on the element rather than any annotation of type T.
It is not behaviorally compatible for the get[Declared]AnnotationsByType(Class<T>) methods, because their results will expose the additional annotations of type T whereas previously they exposed only a single annotation of type T.
If an annotation of type TC is present on an element, then making
some other annotation type T repeatable (with TC as its containing annotation type) is source compatible and binary compatible.
It is behaviorally compatible for the get[Declared]Annotation(Class<T>) methods and get[Declared]Annotations() methods, in that their results will not change just because TC is a containing annotation type.
However, it is not behaviorally compatible for the get[Declared]AnnotationsByType(Class<T>) methods, because they will now recognize an annotation of type TC as a container annotation and "look through" it to expose annotations of type T.
--
Attachments
Issue Links
- backported by
-
JDK-8030876 Add compatibility note to AnnotatedElement
- Resolved
-
JDK-8031280 Add compatibility note to AnnotatedElement
- Resolved
- clones
-
JDK-8007072 Update Core Reflection for Type Annotations to match latest spec
- Closed