/* ProxyUtils.java -- Utilities class for Proxy related operations
Copyright (C) 2006 Olivier Jolly <olivier.jolly@pcedev.com>
This file is part of Mauve.
Mauve is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
Mauve is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with Mauve; see the file COPYING. If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
*/
// Tags: not-a-test
package gnu.testlet.wonka.lang.reflect.Proxy;
import java.lang.reflect.Method;
import java.util.Arrays;
/**
* Utility class with some proxy related methods
* @author Olivier Jolly <olivier.jolly@pcedev.com>
*/
public final class ProxyUtils
{
/**
* Compare two methods excepted the declaring class equality test
* @param lhs
* first method to test
* @param rhs
* second method to test
* @return whether the two methods are equals even if of different declaring
* class
*/
static boolean compareMethodExceptedDeclaringClass(Method lhs, Method rhs)
{
if (!lhs.getName().equals(rhs.getName()))
{
return false;
}
if (lhs.getReturnType() != rhs.getReturnType())
{
return false;
}
if (!Arrays.equals(lhs.getParameterTypes(), rhs.getParameterTypes()))
{
return false;
}
return true;
}
/**
* Compare two methods based only on their name and parameter
* @param lhs
* first method to test
* @param rhs
* second method to test
* @return whether the name and parameter type are equal
*/
static boolean compareMethodOnNameAndParameterTypes(Method lhs, Method rhs)
{
if (!lhs.getName().equals(rhs.getName()))
{
return false;
}
if (!Arrays.equals(lhs.getParameterTypes(), rhs.getParameterTypes()))
{
return false;
}
return true;
}
/**
* Return a valid value for the given class, even if a primitive
* @param returnType
* the expected class
* @return a neutral value of the expected class
* @throws InstantiationException
* in case of problem with the constructor invocation
* @throws IllegalAccessException
* in case of problem with the constructor invocation
*/
public static Object getNeutralValue(Class returnType)
throws InstantiationException, IllegalAccessException
{
if (returnType.equals(boolean.class))
{
return Boolean.FALSE;
}
if (returnType.equals(int.class))
{
return new Integer(0);
}
if (returnType.equals(float.class))
{
return new Float(0);
}
if (returnType.equals(double.class))
{
return new Double(0);
}
if (returnType.equals(char.class))
{
return new Character((char) 0);
}
if (returnType.equals(short.class))
{
return new Short((short) 0);
}
if (returnType.equals(long.class))
{
return new Long(0);
}
if (returnType.equals(void.class))
{
return null;
}
return returnType.newInstance();
}
}