Skip to content

Commit

Permalink
NotNullByDefault: refine the behavior for type parameters
Browse files Browse the repository at this point in the history
  • Loading branch information
amaembo committed Oct 2, 2024
1 parent 0c06dec commit 61bce51
Showing 1 changed file with 15 additions and 2 deletions.
17 changes: 15 additions & 2 deletions src/jvmMain/java/org/jetbrains/annotations/NotNullByDefault.java
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,21 @@
* The tools may issue a warning if the nullability for a subclass method contradicts from the specified nullability
* of a superclass method.
* <p>
* The annotation has no effect on newly declared type parameters and their bounds. Only instantiations of
* type parameters are constrained.
* For newly declared type parameters, the annotation applies to its bounds, including implicit {@code Object}
* bound if no explicit bound is declared. For example, {@code <T>} declared under {@code @NotNullByDefault} scope
* means the same as {@code <T extends @NotNull Object>}. To reset to default behavior in this case, one should use
* {@code <T extends @UnknownNullability Object>}.
* <p>
* The type parameter references are not affected by {@code @NotNullByDefault}. For example:
* <pre>{@code
* @NotNullByDefault
* interface Pair<K extends @Nullable Object, V> {
* // Not assumed to be @NotNull; may return null depending on the T instantiation
* K getKey();
* // Returns @NotNull, as implicit upper bound of V is @NotNull Object,
* // so it cannot be instantiated with a nullable type
* V getValue();
* }}</pre>
* <p>
* The annotation has no effect on local variables.
*
Expand Down

0 comments on commit 61bce51

Please # to comment.