Add early null check.

This commit is contained in:
Gary Gregory 2022-03-07 11:00:24 -05:00
parent abb5a409f7
commit 72ad3cbc1a
1 changed files with 8 additions and 10 deletions

View File

@ -31,6 +31,7 @@ import java.util.Iterator;
import java.util.LinkedHashSet; import java.util.LinkedHashSet;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Objects;
import java.util.Set; import java.util.Set;
import java.util.TreeMap; import java.util.TreeMap;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -201,32 +202,29 @@ public class MethodUtils {
* @throws IllegalAccessException if the requested method is not accessible via reflection * @throws IllegalAccessException if the requested method is not accessible via reflection
* @since 3.5 * @since 3.5
*/ */
public static Object invokeMethod(final Object object, final boolean forceAccess, final String methodName, public static Object invokeMethod(final Object object, final boolean forceAccess, final String methodName, Object[] args, Class<?>[] parameterTypes)
Object[] args, Class<?>[] parameterTypes) throws NoSuchMethodException, IllegalAccessException, InvocationTargetException {
throws NoSuchMethodException, IllegalAccessException, InvocationTargetException { Objects.requireNonNull(object, "object");
parameterTypes = ArrayUtils.nullToEmpty(parameterTypes); parameterTypes = ArrayUtils.nullToEmpty(parameterTypes);
args = ArrayUtils.nullToEmpty(args); args = ArrayUtils.nullToEmpty(args);
final String messagePrefix; final String messagePrefix;
final Method method; final Method method;
final Class<? extends Object> cls = object.getClass();
if (forceAccess) { if (forceAccess) {
messagePrefix = "No such method: "; messagePrefix = "No such method: ";
method = getMatchingMethod(object.getClass(), method = getMatchingMethod(cls, methodName, parameterTypes);
methodName, parameterTypes);
if (method != null && !method.isAccessible()) { if (method != null && !method.isAccessible()) {
method.setAccessible(true); method.setAccessible(true);
} }
} else { } else {
messagePrefix = "No such accessible method: "; messagePrefix = "No such accessible method: ";
method = getMatchingAccessibleMethod(object.getClass(), method = getMatchingAccessibleMethod(cls, methodName, parameterTypes);
methodName, parameterTypes);
} }
if (method == null) { if (method == null) {
throw new NoSuchMethodException(messagePrefix throw new NoSuchMethodException(messagePrefix + methodName + "() on object: " + cls.getName());
+ methodName + "() on object: "
+ object.getClass().getName());
} }
args = toVarArgs(method, args); args = toVarArgs(method, args);