From 2d3372c8b5cad126a93f8290ebc18e116748c71f Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Wed, 5 Aug 2020 23:02:22 -0700 Subject: [PATCH] 8250660: Clarify that WildcardType and AnnotatedWildcardType bounds methods return one Reviewed-by: mchung, dholmes --- .../java/lang/reflect/AnnotatedWildcardType.java | 8 ++++++++ .../share/classes/java/lang/reflect/WildcardType.java | 10 ++++++++-- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java b/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java index 8a211eab6bf..b837143712f 100644 --- a/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java +++ b/src/java.base/share/classes/java/lang/reflect/AnnotatedWildcardType.java @@ -40,6 +40,10 @@ public interface AnnotatedWildcardType extends AnnotatedType { * If no lower bound is explicitly declared, the lower bound is the * type of null. In this case, a zero length array is returned. * + * @apiNote While to date a wildcard may have at most one lower + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return the potentially annotated lower bounds of this wildcard type or * an empty array if no lower bound is explicitly declared. * @see WildcardType#getLowerBounds() @@ -51,6 +55,10 @@ public interface AnnotatedWildcardType extends AnnotatedType { * If no upper bound is explicitly declared, the upper bound is * unannotated {@code Object} * + * @apiNote While to date a wildcard may have at most one upper + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return the potentially annotated upper bounds of this wildcard type * @see WildcardType#getUpperBounds() */ diff --git a/src/java.base/share/classes/java/lang/reflect/WildcardType.java b/src/java.base/share/classes/java/lang/reflect/WildcardType.java index 0ef18413ea4..124deb41f4c 100644 --- a/src/java.base/share/classes/java/lang/reflect/WildcardType.java +++ b/src/java.base/share/classes/java/lang/reflect/WildcardType.java @@ -46,6 +46,10 @@ public interface WildcardType extends Type { *
  • Otherwise, B is resolved. * * + * @apiNote While to date a wildcard may have at most one upper + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return an array of Types representing the upper bound(s) of this * type variable * @throws TypeNotPresentException if any of the @@ -70,6 +74,10 @@ public interface WildcardType extends Type { *
  • Otherwise, B is resolved. * * + * @apiNote While to date a wildcard may have at most one lower + * bound, callers of this method should be written to accommodate + * multiple bounds. + * * @return an array of Types representing the lower bound(s) of this * type variable * @throws TypeNotPresentException if any of the @@ -79,6 +87,4 @@ public interface WildcardType extends Type { * for any reason */ Type[] getLowerBounds(); - // one or many? Up to language spec; currently only one, but this API - // allows for generalization. }