Remove invokeExactMethod. Going to consolidate on one inokeMethod that considers superclasses and doesn't break scope rules.
git-svn-id: https://svn.apache.org/repos/asf/jakarta/commons/proper/lang/trunk@137136 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
97883eec49
commit
dd87113102
|
@ -82,7 +82,7 @@ import org.apache.commons.lang.StringUtils;
|
||||||
* @author Gregor Raýman
|
* @author Gregor Raýman
|
||||||
* @author Jan Sorensen
|
* @author Jan Sorensen
|
||||||
* @author Robert Burrell Donkin
|
* @author Robert Burrell Donkin
|
||||||
* @version $Id: MethodUtils.java,v 1.2 2002/11/14 18:51:57 rdonkin Exp $
|
* @version $Id: MethodUtils.java,v 1.3 2002/11/18 22:18:44 rdonkin Exp $
|
||||||
*/
|
*/
|
||||||
public class MethodUtils {
|
public class MethodUtils {
|
||||||
|
|
||||||
|
@ -192,11 +192,6 @@ public class MethodUtils {
|
||||||
/**
|
/**
|
||||||
* <p>Invoke a named method whose parameter type matches the object type.</p>
|
* <p>Invoke a named method whose parameter type matches the object type.</p>
|
||||||
*
|
*
|
||||||
* <p>The behaviour of this method is less deterministic
|
|
||||||
* than {@link #invokeExactMethod}.
|
|
||||||
* It loops through all methods with names that match
|
|
||||||
* and then executes the first it finds with compatable parameters.</p>
|
|
||||||
*
|
|
||||||
* <p>This method supports calls to methods taking primitive parameters
|
* <p>This method supports calls to methods taking primitive parameters
|
||||||
* via passing in wrapping classes. So, for example, a <code>Boolean</code> class
|
* via passing in wrapping classes. So, for example, a <code>Boolean</code> class
|
||||||
* would match a <code>boolean</code> primitive.</p>
|
* would match a <code>boolean</code> primitive.</p>
|
||||||
|
@ -241,11 +236,6 @@ public class MethodUtils {
|
||||||
/**
|
/**
|
||||||
* <p>Invoke a named method whose parameter type matches the object type.</p>
|
* <p>Invoke a named method whose parameter type matches the object type.</p>
|
||||||
*
|
*
|
||||||
* <p>The behaviour of this method is less deterministic
|
|
||||||
* than {@link #invokeExactMethod(Object object,String methodName,Object [] args)}.
|
|
||||||
* It loops through all methods with names that match
|
|
||||||
* and then executes the first it finds with compatable parameters.</p>
|
|
||||||
*
|
|
||||||
* <p>This method supports calls to methods taking primitive parameters
|
* <p>This method supports calls to methods taking primitive parameters
|
||||||
* via passing in wrapping classes. So, for example, a <code>Boolean</code> class
|
* via passing in wrapping classes. So, for example, a <code>Boolean</code> class
|
||||||
* would match a <code>boolean</code> primitive.</p>
|
* would match a <code>boolean</code> primitive.</p>
|
||||||
|
@ -298,12 +288,6 @@ public class MethodUtils {
|
||||||
/**
|
/**
|
||||||
* <p>Invoke a named method whose parameter type matches the object type.</p>
|
* <p>Invoke a named method whose parameter type matches the object type.</p>
|
||||||
*
|
*
|
||||||
* <p>The behaviour of this method is less deterministic
|
|
||||||
* than {@link
|
|
||||||
* #invokeExactMethod(Object object,String methodName,Object [] args,Class[] parameterTypes)}.
|
|
||||||
* It loops through all methods with names that match
|
|
||||||
* and then executes the first it finds with compatable parameters.</p>
|
|
||||||
*
|
|
||||||
* <p>This method supports calls to methods taking primitive parameters
|
* <p>This method supports calls to methods taking primitive parameters
|
||||||
* via passing in wrapping classes. So, for example, a <code>Boolean</code> class
|
* via passing in wrapping classes. So, for example, a <code>Boolean</code> class
|
||||||
* would match a <code>boolean</code> primitive.</p>
|
* would match a <code>boolean</code> primitive.</p>
|
||||||
|
@ -337,7 +321,6 @@ public class MethodUtils {
|
||||||
args = ArrayUtils.EMPTY_OBJECT_ARRAY;
|
args = ArrayUtils.EMPTY_OBJECT_ARRAY;
|
||||||
}
|
}
|
||||||
|
|
||||||
//return null;
|
|
||||||
Method method = getMatchingAccessibleMethod(
|
Method method = getMatchingAccessibleMethod(
|
||||||
object.getClass(),
|
object.getClass(),
|
||||||
methodName,
|
methodName,
|
||||||
|
@ -348,126 +331,6 @@ public class MethodUtils {
|
||||||
return method.invoke(object, args);
|
return method.invoke(object, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <p>Invoke a method whose parameter type matches exactly the object
|
|
||||||
* type.</p>
|
|
||||||
*
|
|
||||||
* <p> This is a convenient wrapper for
|
|
||||||
* {@link #invokeExactMethod(Object object,String methodName,Object [] args)}.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* @param object invoke method on this object
|
|
||||||
* @param methodName get method with this name
|
|
||||||
* @param arg use this argument
|
|
||||||
*
|
|
||||||
* @throws NoSuchMethodException if there is no such accessible method
|
|
||||||
* @throws InvocationTargetException wraps an exception thrown by the
|
|
||||||
* method invoked
|
|
||||||
* @throws IllegalAccessException if the requested method is not accessible
|
|
||||||
* via reflection
|
|
||||||
*/
|
|
||||||
public static Object invokeExactMethod(
|
|
||||||
Object object,
|
|
||||||
String methodName,
|
|
||||||
Object arg)
|
|
||||||
throws
|
|
||||||
NoSuchMethodException,
|
|
||||||
IllegalAccessException,
|
|
||||||
InvocationTargetException {
|
|
||||||
|
|
||||||
Object[] args = {arg};
|
|
||||||
return invokeExactMethod(object, methodName, args);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <p>Invoke a method whose parameter types match exactly the object
|
|
||||||
* types.</p>
|
|
||||||
*
|
|
||||||
* <p> This uses reflection to invoke the method obtained from a call to
|
|
||||||
* {@link #getAccessibleMethod}.</p>
|
|
||||||
*
|
|
||||||
* @param object invoke method on this object
|
|
||||||
* @param methodName get method with this name
|
|
||||||
* @param args use these arguments - treat null as empty array
|
|
||||||
*
|
|
||||||
* @throws NoSuchMethodException if there is no such accessible method
|
|
||||||
* @throws InvocationTargetException wraps an exception thrown by the
|
|
||||||
* method invoked
|
|
||||||
* @throws IllegalAccessException if the requested method is not accessible
|
|
||||||
* via reflection
|
|
||||||
*/
|
|
||||||
public static Object invokeExactMethod(
|
|
||||||
Object object,
|
|
||||||
String methodName,
|
|
||||||
Object[] args)
|
|
||||||
throws
|
|
||||||
NoSuchMethodException,
|
|
||||||
IllegalAccessException,
|
|
||||||
InvocationTargetException {
|
|
||||||
if (args == null) {
|
|
||||||
args = ArrayUtils.EMPTY_OBJECT_ARRAY;
|
|
||||||
}
|
|
||||||
int arguments = args.length;
|
|
||||||
Class parameterTypes [] = new Class[arguments];
|
|
||||||
for (int i = 0; i < arguments; i++) {
|
|
||||||
parameterTypes[i] = args[i].getClass();
|
|
||||||
}
|
|
||||||
return invokeExactMethod(object, methodName, args, parameterTypes);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <p>Invoke a method whose parameter types match exactly the parameter
|
|
||||||
* types given.</p>
|
|
||||||
*
|
|
||||||
* <p>This uses reflection to invoke the method obtained from a call to
|
|
||||||
* {@link #getAccessibleMethod}.</p>
|
|
||||||
*
|
|
||||||
* @param object invoke method on this object
|
|
||||||
* @param methodName get method with this name
|
|
||||||
* @param args use these arguments - treat null as empty array
|
|
||||||
* @param parameterTypes match these parameters - treat null as empty array
|
|
||||||
*
|
|
||||||
* @throws NoSuchMethodException if there is no such accessible method
|
|
||||||
* @throws InvocationTargetException wraps an exception thrown by the
|
|
||||||
* method invoked
|
|
||||||
* @throws IllegalAccessException if the requested method is not accessible
|
|
||||||
* via reflection
|
|
||||||
*/
|
|
||||||
public static Object invokeExactMethod(
|
|
||||||
Object object,
|
|
||||||
String methodName,
|
|
||||||
Object[] args,
|
|
||||||
Class[] parameterTypes)
|
|
||||||
throws
|
|
||||||
NoSuchMethodException,
|
|
||||||
IllegalAccessException,
|
|
||||||
InvocationTargetException {
|
|
||||||
|
|
||||||
if (args == null) {
|
|
||||||
args = ArrayUtils.EMPTY_OBJECT_ARRAY;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (parameterTypes == null) {
|
|
||||||
parameterTypes = ArrayUtils.EMPTY_CLASS_ARRAY;
|
|
||||||
}
|
|
||||||
|
|
||||||
Method method = getAccessibleMethod(
|
|
||||||
object.getClass(),
|
|
||||||
methodName,
|
|
||||||
parameterTypes);
|
|
||||||
if (method == null)
|
|
||||||
throw new NoSuchMethodException("No such accessible method: " +
|
|
||||||
methodName + "() on object: " + object.getClass().getName());
|
|
||||||
return method.invoke(object, args);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p>Return an accessible method (that is, one that can be invoked via
|
* <p>Return an accessible method (that is, one that can be invoked via
|
||||||
* reflection) with given name and a single parameter. If no such method
|
* reflection) with given name and a single parameter. If no such method
|
||||||
|
|
|
@ -171,16 +171,16 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p> Test <code>invokeExactMethod</code>.
|
* <p> Test <code>invokeMethod</code>.
|
||||||
*/
|
*/
|
||||||
public void testInvokeExactMethod() {
|
public void testinvokeMethod2() {
|
||||||
// test MethodUtils.invokeExactMethod
|
// test MethodUtils.invokeMethod
|
||||||
// easy bit first - invoke a public method
|
// easy bit first - invoke a public method
|
||||||
// METHOD ONE
|
// METHOD ONE
|
||||||
try {
|
try {
|
||||||
|
|
||||||
TestBean bean = new TestBean();
|
TestBean bean = new TestBean();
|
||||||
Object ret = MethodUtils.invokeExactMethod(bean, "setStringProperty", "TEST");
|
Object ret = MethodUtils.invokeMethod(bean, "setStringProperty", "TEST");
|
||||||
// check that the return's right and that the properties been set
|
// check that the return's right and that the properties been set
|
||||||
assertNull(ret);
|
assertNull(ret);
|
||||||
assertEquals("Method ONE was invoked", "TEST", bean.getStringProperty());
|
assertEquals("Method ONE was invoked", "TEST", bean.getStringProperty());
|
||||||
|
@ -194,7 +194,7 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
// METHOD TWO FAILURE
|
// METHOD TWO FAILURE
|
||||||
try {
|
try {
|
||||||
|
|
||||||
Object ret = MethodUtils.invokeExactMethod(
|
Object ret = MethodUtils.invokeMethod(
|
||||||
privateBeanFactory.create(),
|
privateBeanFactory.create(),
|
||||||
"methodBar",
|
"methodBar",
|
||||||
"ANOTHER TEST");
|
"ANOTHER TEST");
|
||||||
|
@ -212,7 +212,7 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
// METHOD THREE
|
// METHOD THREE
|
||||||
try {
|
try {
|
||||||
|
|
||||||
Object ret = MethodUtils.invokeExactMethod(
|
Object ret = MethodUtils.invokeMethod(
|
||||||
privateBeanFactory.createSubclass(),
|
privateBeanFactory.createSubclass(),
|
||||||
"methodBaz",
|
"methodBaz",
|
||||||
"YET ANOTHER TEST");
|
"YET ANOTHER TEST");
|
||||||
|
@ -301,8 +301,8 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
|
|
||||||
MethodUtils.invokeMethod(parent, "getName", null);
|
MethodUtils.invokeMethod(parent, "getName", null);
|
||||||
MethodUtils.invokeMethod(parent, "getName", null, null);
|
MethodUtils.invokeMethod(parent, "getName", null, null);
|
||||||
MethodUtils.invokeExactMethod(parent, "getName", null);
|
MethodUtils.invokeMethod(parent, "getName", null);
|
||||||
MethodUtils.invokeExactMethod(parent, "getName", null, null);
|
MethodUtils.invokeMethod(parent, "getName", null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -407,7 +407,7 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simple tests for accessing static methods via invokeExactMethod().
|
* Simple tests for accessing static methods via invokeMethod().
|
||||||
*/
|
*/
|
||||||
public void testSimpleStatic2() {
|
public void testSimpleStatic2() {
|
||||||
|
|
||||||
|
@ -418,7 +418,7 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
try {
|
try {
|
||||||
|
|
||||||
// Return initial value of the counter
|
// Return initial value of the counter
|
||||||
value = MethodUtils.invokeExactMethod
|
value = MethodUtils.invokeMethod
|
||||||
(bean, "currentCounter", new Object[0], new Class[0]);
|
(bean, "currentCounter", new Object[0], new Class[0]);
|
||||||
assertNotNull("currentCounter exists", value);
|
assertNotNull("currentCounter exists", value);
|
||||||
assertTrue("currentCounter type",
|
assertTrue("currentCounter type",
|
||||||
|
@ -428,12 +428,12 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
((Integer) value).intValue());
|
((Integer) value).intValue());
|
||||||
|
|
||||||
// Increment via no-arguments version
|
// Increment via no-arguments version
|
||||||
MethodUtils.invokeExactMethod
|
MethodUtils.invokeMethod
|
||||||
(bean, "incrementCounter", new Object[0], new Class[0]);
|
(bean, "incrementCounter", new Object[0], new Class[0]);
|
||||||
|
|
||||||
// Validate updated value
|
// Validate updated value
|
||||||
current++;
|
current++;
|
||||||
value = MethodUtils.invokeExactMethod
|
value = MethodUtils.invokeMethod
|
||||||
(bean, "currentCounter", new Object[0], new Class[0]);
|
(bean, "currentCounter", new Object[0], new Class[0]);
|
||||||
assertNotNull("currentCounter exists", value);
|
assertNotNull("currentCounter exists", value);
|
||||||
assertTrue("currentCounter type",
|
assertTrue("currentCounter type",
|
||||||
|
@ -443,14 +443,14 @@ public class MethodUtilsTestCase extends TestCase {
|
||||||
((Integer) value).intValue());
|
((Integer) value).intValue());
|
||||||
|
|
||||||
// Increment via specified-argument version
|
// Increment via specified-argument version
|
||||||
MethodUtils.invokeExactMethod
|
MethodUtils.invokeMethod
|
||||||
(bean, "incrementCounter",
|
(bean, "incrementCounter",
|
||||||
new Object[] { new Integer(5) },
|
new Object[] { new Integer(5) },
|
||||||
new Class[] { Integer.TYPE });
|
new Class[] { Integer.TYPE });
|
||||||
|
|
||||||
// Validate updated value
|
// Validate updated value
|
||||||
current += 5;
|
current += 5;
|
||||||
value = MethodUtils.invokeExactMethod
|
value = MethodUtils.invokeMethod
|
||||||
(bean, "currentCounter", new Object[0], new Class[0]);
|
(bean, "currentCounter", new Object[0], new Class[0]);
|
||||||
assertNotNull("currentCounter exists", value);
|
assertNotNull("currentCounter exists", value);
|
||||||
assertTrue("currentCounter type",
|
assertTrue("currentCounter type",
|
||||||
|
|
Loading…
Reference in New Issue