Skip to content

Commit 1bc93e3

Browse files
committed
Revisit nullability annotations
This commit introduces the following changes. 1) It adds a new Spring @nonnull annotation which allows to apply @NonNullApi semantic on a specific element, like @nullable does. Combined with @nullable, it allows partial null-safety support when package granularity is too broad. 2) @nullable and @nonnull can apply to ElementType.TYPE_USE in order to be used on generic type arguments (SPR-15942). 3) Annotations does not apply to ElementType.TYPE_PARAMETER anymore since it is not supported yet (applicability for such use case is controversial and need to be discussed). 4) @NonNullApi does not apply to ElementType.FIELD anymore since in a lot of use cases (private, protected) it is not part for the public API + its usage should remain opt-in. A dedicated @NonNullFields annotation has been added in order to set fields default to non-nullable. 5) Updated Javadoc and reference documentation. Issue: SPR-15756
1 parent ec2218c commit 1bc93e3

File tree

364 files changed

+1003
-113
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

364 files changed

+1003
-113
lines changed

spring-aop/src/main/java/org/springframework/aop/aspectj/annotation/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,8 @@
44
* <p>Normally to be used through an AspectJAutoProxyCreator rather than directly.
55
*/
66
@NonNullApi
7+
@NonNullFields
78
package org.springframework.aop.aspectj.annotation;
89

9-
import org.springframework.lang.NonNullApi;
10+
import org.springframework.lang.NonNullApi;
11+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/aspectj/autoproxy/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,8 @@
33
* Support for AspectJ annotation aspects resides in the "aspectj.annotation" package.
44
*/
55
@NonNullApi
6+
@NonNullFields
67
package org.springframework.aop.aspectj.autoproxy;
78

8-
import org.springframework.lang.NonNullApi;
9+
import org.springframework.lang.NonNullApi;
10+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/aspectj/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,8 @@
99
* functionality, with consistent semantics, with the proxy-based Spring AOP framework.
1010
*/
1111
@NonNullApi
12+
@NonNullFields
1213
package org.springframework.aop.aspectj;
1314

14-
import org.springframework.lang.NonNullApi;
15+
import org.springframework.lang.NonNullApi;
16+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/config/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,8 @@
33
* with XML schema being the primary configuration format.
44
*/
55
@NonNullApi
6+
@NonNullFields
67
package org.springframework.aop.config;
78

8-
import org.springframework.lang.NonNullApi;
9+
import org.springframework.lang.NonNullApi;
10+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/framework/adapter/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,8 @@
1010
* <p>These adapters do not depend on any other Spring framework classes to allow such usage.
1111
*/
1212
@NonNullApi
13+
@NonNullFields
1314
package org.springframework.aop.framework.adapter;
1415

15-
import org.springframework.lang.NonNullApi;
16+
import org.springframework.lang.NonNullApi;
17+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/framework/autoproxy/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,8 @@
1010
* Post-processors can be explicitly registered on a ConfigurableBeanFactory instead.
1111
*/
1212
@NonNullApi
13+
@NonNullFields
1314
package org.springframework.aop.framework.autoproxy;
1415

15-
import org.springframework.lang.NonNullApi;
16+
import org.springframework.lang.NonNullApi;
17+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/framework/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@
1313
* ProxyFactory class.
1414
*/
1515
@NonNullApi
16+
@NonNullFields
1617
package org.springframework.aop.framework;
1718

18-
import org.springframework.lang.NonNullApi;
19+
import org.springframework.lang.NonNullApi;
20+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/interceptor/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,8 @@
44
* functionality packages, like "transaction" and "orm".
55
*/
66
@NonNullApi
7+
@NonNullFields
78
package org.springframework.aop.interceptor;
89

9-
import org.springframework.lang.NonNullApi;
10+
import org.springframework.lang.NonNullApi;
11+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818
* integrated with the Spring IoC container.
1919
*/
2020
@NonNullApi
21+
@NonNullFields
2122
package org.springframework.aop;
2223

23-
import org.springframework.lang.NonNullApi;
24+
import org.springframework.lang.NonNullApi;
25+
import org.springframework.lang.NonNullFields;

spring-aop/src/main/java/org/springframework/aop/scope/package-info.java

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,8 @@
22
* Support for AOP-based scoping of target objects, with configurable backend.
33
*/
44
@NonNullApi
5+
@NonNullFields
56
package org.springframework.aop.scope;
67

7-
import org.springframework.lang.NonNullApi;
8+
import org.springframework.lang.NonNullApi;
9+
import org.springframework.lang.NonNullFields;

0 commit comments

Comments
 (0)