From f31933e67e054a4df2fcd58684750aaf3efc7bbb Mon Sep 17 00:00:00 2001 From: Juergen Hoeller Date: Tue, 13 Apr 2021 12:26:52 +0200 Subject: [PATCH] Nullability refinements --- .../java/org/springframework/http/MediaTypeFactory.java | 6 ++++-- .../springframework/web/method/HandlerTypePredicate.java | 5 +++-- .../mvc/method/annotation/MvcUriComponentsBuilder.java | 8 +++++--- 3 files changed, 12 insertions(+), 7 deletions(-) diff --git a/spring-web/src/main/java/org/springframework/http/MediaTypeFactory.java b/spring-web/src/main/java/org/springframework/http/MediaTypeFactory.java index 8487ab5b8868..b61cfea07350 100644 --- a/spring-web/src/main/java/org/springframework/http/MediaTypeFactory.java +++ b/spring-web/src/main/java/org/springframework/http/MediaTypeFactory.java @@ -1,5 +1,5 @@ /* - * Copyright 2002-2020 the original author or authors. + * Copyright 2002-2021 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -28,6 +28,7 @@ import org.springframework.core.io.Resource; import org.springframework.lang.Nullable; +import org.springframework.util.Assert; import org.springframework.util.LinkedMultiValueMap; import org.springframework.util.MultiValueMap; import org.springframework.util.StringUtils; @@ -65,6 +66,7 @@ private MediaTypeFactory() { */ private static MultiValueMap parseMimeTypes() { InputStream is = MediaTypeFactory.class.getResourceAsStream(MIME_TYPES_FILE_NAME); + Assert.state(is != null, MIME_TYPES_FILE_NAME + " not found in classpath"); try (BufferedReader reader = new BufferedReader(new InputStreamReader(is, StandardCharsets.US_ASCII))) { MultiValueMap result = new LinkedMultiValueMap<>(); String line; @@ -82,7 +84,7 @@ private static MultiValueMap parseMimeTypes() { return result; } catch (IOException ex) { - throw new IllegalStateException("Could not load '" + MIME_TYPES_FILE_NAME + "'", ex); + throw new IllegalStateException("Could not read " + MIME_TYPES_FILE_NAME, ex); } } diff --git a/spring-web/src/main/java/org/springframework/web/method/HandlerTypePredicate.java b/spring-web/src/main/java/org/springframework/web/method/HandlerTypePredicate.java index b40e0483f3e1..2050bbdf7d6c 100644 --- a/spring-web/src/main/java/org/springframework/web/method/HandlerTypePredicate.java +++ b/spring-web/src/main/java/org/springframework/web/method/HandlerTypePredicate.java @@ -1,5 +1,5 @@ /* - * Copyright 2002-2018 the original author or authors. + * Copyright 2002-2021 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -26,6 +26,7 @@ import java.util.function.Predicate; import org.springframework.core.annotation.AnnotationUtils; +import org.springframework.lang.Nullable; import org.springframework.util.ClassUtils; import org.springframework.util.StringUtils; @@ -69,7 +70,7 @@ private HandlerTypePredicate(Set basePackages, List> assignable @Override - public boolean test(Class controllerType) { + public boolean test(@Nullable Class controllerType) { if (!hasSelectors()) { return true; } diff --git a/spring-webmvc/src/main/java/org/springframework/web/servlet/mvc/method/annotation/MvcUriComponentsBuilder.java b/spring-webmvc/src/main/java/org/springframework/web/servlet/mvc/method/annotation/MvcUriComponentsBuilder.java index fcda20d4688d..7c60bee6675a 100644 --- a/spring-webmvc/src/main/java/org/springframework/web/servlet/mvc/method/annotation/MvcUriComponentsBuilder.java +++ b/spring-webmvc/src/main/java/org/springframework/web/servlet/mvc/method/annotation/MvcUriComponentsBuilder.java @@ -1,5 +1,5 @@ /* - * Copyright 2002-2020 the original author or authors. + * Copyright 2002-2021 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -97,7 +97,9 @@ */ public class MvcUriComponentsBuilder { - /** Well-known name for the {@link CompositeUriComponentsContributor} object in the bean factory. */ + /** + * Well-known name for the {@link CompositeUriComponentsContributor} object in the bean factory. + */ public static final String MVC_URI_COMPONENTS_CONTRIBUTOR_BEAN_NAME = "mvcUriComponentsContributor"; @@ -716,7 +718,7 @@ private static class ControllerMethodInvocationInterceptor @Override @Nullable - public Object intercept(Object obj, Method method, Object[] args, @Nullable MethodProxy proxy) { + public Object intercept(@Nullable Object obj, Method method, Object[] args, @Nullable MethodProxy proxy) { switch (method.getName()) { case "getControllerType": return this.controllerType; case "getControllerMethod": return this.controllerMethod;