Class ReflectionHelper
- Author:
- Paul Sandoz, Jakub Podlesak
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic class
A tuple consisting of a concrete class and a declaring class that declares a generic interface type. -
Method Summary
Modifier and TypeMethodDescriptionstatic <T> PrivilegedAction<Class<T>>
classForNamePA
(String name) Get privileged action to obtain Class from given class name.static <T> PrivilegedAction<Class<T>>
classForNamePA
(String name, ClassLoader cl) Get privileged action to obtain Class from given class name.static <T> PrivilegedExceptionAction<Class<T>>
Get privileged exception action to obtain Class from given class name.static <T> PrivilegedExceptionAction<Class<T>>
classForNameWithExceptionPEA
(String name, ClassLoader cl) Get privileged exception action to obtain Class from given class name.static <T> Class<T>
Get theClass
representation of the given type.static PrivilegedAction<Method>
findMethodOnClassPA
(Class<?> c, Method m) Get privileged action to find a method on a class given an existing method.static Method
findOverridingMethodOnClass
(Class<?> clazz, Method method) static GenericType
genericTypeFor
(Object instance) Create ageneric type
information for a given Javainstance
.static PrivilegedAction<Field[]>
getAllFieldsPA
(Class<?> clazz) Get privileged action to obtain fields on given class, recursively through inheritance hierarchy.static Collection<Class<? extends Annotation>>
getAnnotationTypes
(AnnotatedElement annotatedElement, Class<? extends Annotation> metaAnnotation) Returns collection of all annotation types attached to a given annotated element that have the provided meta annotation attached.static Type
getArrayComponentType
(Type type) Gets the component type of the array.static Class<?>
Get Array class of component type.Find the declaring class that implements or extends an interface.static PrivilegedAction<ClassLoader>
getClassLoaderPA
(Class<?> clazz) Get privileged action to obtain class loader for given class.static PrivilegedAction<ClassLoader>
Get privileged action to obtain context class loader.static PrivilegedAction<Constructor<?>>
getDeclaredConstructorPA
(Class<?> clazz, Class<?>... params) Get privileged action to obtain declared constructor of given class with given parameters.static PrivilegedAction<Constructor<?>[]>
getDeclaredConstructorsPA
(Class<?> clazz) Get privileged action to obtain declared constructors of given class.static PrivilegedAction<Field[]>
getDeclaredFieldsPA
(Class<?> clazz) Get privileged action to obtain fields declared on given class.static PrivilegedAction<Collection<? extends Method>>
getDeclaredMethodsPA
(Class<?> clazz) Get privileged action to obtain methods declared on given class.static Class<?>
Get the declaring class of an accessible object.static PrivilegedAction<Method>
getFromStringStringMethodPA
(Class<?> clazz) Get privileged action to get the static fromString(String ) method.Get the list of classes that represent the type arguments of aparameterized
input type.static PrivilegedAction<Method[]>
getMethodsPA
(Class<?> c) Get privileged action to return an array containingMethod
objects reflecting all the public member methods of the supplied class or interface object, including those declared by the class or interface and those inherited from superclasses and superinterfaces.static OsgiRegistry
Returns anOsgiRegistry
instance.static Class[]
Get the parameterized class arguments for a declaring class that declares a generic interface type.static Type[]
Get the parameterized type arguments for a declaring class that declares a generic interface type.static String
getPropertyName
(Method method) Determine property (field) name from given getter/setter method.static Class<?>
getRawClass
(Type type) Given the type parameter gets the raw type represented by the type, or null if this has no associated raw class.static InputStream
getResourceAsStream
(ClassLoader loader, Class<?> originClass, String name) Lookup resource by given name.static PrivilegedAction<Constructor>
getStringConstructorPA
(Class<?> clazz) Get privileged action to obtain constructor that has a single parameter of String.static Type
getTypeArgument
(Type type, int index) Get a type argument at particular index for a parameterized type.static List<ClassTypePair>
getTypeArgumentAndClass
(Type type) Get the list of class-type pairs that represent the type arguments of aparameterized
input type.static Type[]
getTypeArguments
(Type type) Get the type arguments for a parameterized type.static PrivilegedAction<Method>
getValueOfStringMethodPA
(Class<?> clazz) Get privileged action to obtain the static valueOf(String ) method.static boolean
Checks if the type is an array type.static boolean
isArrayOfType
(Type type, Class<?> componentType) Checks if the type is an array of a given component type.static boolean
Determine whether a given method isgetter
.static boolean
Returns true iff JAX-B API is available on classpath.static boolean
isPrimitive
(Type type) Check if the given type is a primitive type.static boolean
Returntrue
iff the method is public.static boolean
isPublic
(Executable executable) Returntrue
iff the executable is public.static boolean
Determine whether a given method issetter
.static boolean
isSubClassOf
(Type subType, Type superType) Check ifsubType
is a sub-type ofsuperType
.static boolean
Returns true iff javax.xml.transform package is available on classpath.static String
Create a string representation of a method and an instance whose class implements the method.static String
Create a string representation of an object.static ClassTypePair
resolveGenericType
(Class concreteClass, Class declaringClass, Class rawResolvedType, Type genericResolvedType) Resolve generic type parameter(s) of a raw class and it's generic type based on the class that declares the generic type parameter(s) to be resolved and a concrete implementation of the declaring class.static ClassTypePair
resolveTypeVariable
(Class<?> c, Class<?> dc, TypeVariable tv) Given a type variable resolve the Java class of that variable.static PrivilegedAction
Get privileged action to set a method to be accessible.static PrivilegedAction
setContextClassLoaderPA
(ClassLoader classLoader) Get privileged action to set the actual context class loader.static Class<?>
theMostSpecificTypeOf
(Set<Type> contractTypes) Determine the most specific type from given set.
-
Method Details
-
getDeclaringClass
Get the declaring class of an accessible object.Supported are
Method
,Field
andConstructor
accessible object types.- Parameters:
ao
- an accessible object.- Returns:
- the declaring class of an accessible object.
- Throws:
IllegalArgumentException
- in case the type of the accessible object is not supported.
-
objectToString
Create a string representation of an object.Returns a string consisting of the name of the class of which the object is an instance, the at-sign character
'@'
, and the unsigned hexadecimal representation of the hash code of the object. In other words, this method returns a string equal to the value of:o.getClass().getName() + '@' + Integer.toHexString(o.hashCode())
- Parameters:
o
- the object.- Returns:
- the string representation of the object.
-
methodInstanceToString
Create a string representation of a method and an instance whose class implements the method.Returns a string consisting of the name of the class of which the object is an instance, the at-sign character
'@'
, the unsigned hexadecimal representation of the hash code of the object, the character'.'
, the name of the method, the character'('
, the list of method parameters, and the character')'
. In other words, those method returns a string equal to the value of:o.getClass().getName() + '@' + Integer.toHexString(o.hashCode()) + '.' + m.getName() + '(' + <parameters> + ')'.
- Parameters:
o
- the object whose class implementsm
.m
- the method.- Returns:
- the string representation of the method and instance.
-
classForNamePA
Get privileged action to obtain Class from given class name.If run using security manager, the returned privileged action must be invoked within a doPrivileged block. The context class loader will be utilized if accessible and non-null. Otherwise the defining class loader of this class will be utilized.
- Type Parameters:
T
- class type.- Parameters:
name
- class name.- Returns:
- privileged action to obtain desired Class.
The action could return
null
if the class cannot be found. - See Also:
-
classForNamePA
Get privileged action to obtain Class from given class name. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Type Parameters:
T
- class type.- Parameters:
name
- class name.cl
- class loader to use, ifnull
then the defining class loader of this class will be utilized.- Returns:
- privileged action to obtain desired Class. The action could return
null
if the class cannot be found. - See Also:
-
getClassLoaderPA
Get privileged action to obtain class loader for given class. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- class for which to get class loader.- Returns:
- privileged action to obtain class loader for the
clazz
class. - See Also:
-
getDeclaredFieldsPA
Get privileged action to obtain fields declared on given class. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- class for which to get the declared fields.- Returns:
- privileged action to obtain fields declared on the
clazz
class. - See Also:
-
getAllFieldsPA
Get privileged action to obtain fields on given class, recursively through inheritance hierarchy. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- class for which to get fields.- Returns:
- privileged action to obtain fields declared on the
clazz
class. - See Also:
-
getDeclaredMethodsPA
Get privileged action to obtain methods declared on given class. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- class for which to get the declared methods.- Returns:
- privileged action to obtain methods declared on the
clazz
class. - See Also:
-
classForNameWithExceptionPEA
public static <T> PrivilegedExceptionAction<Class<T>> classForNameWithExceptionPEA(String name) throws ClassNotFoundException Get privileged exception action to obtain Class from given class name. If run using security manager, the returned privileged exception action must be invoked within a doPrivileged block. The actual context class loader will be utilized if accessible and non-null. Otherwise the defining class loader of the calling class will be utilized.- Type Parameters:
T
- class type.- Parameters:
name
- class name.- Returns:
- privileged exception action to obtain the Class.
The action could throw
ClassNotFoundException
or returnnull
if the class cannot be found. - Throws:
ClassNotFoundException
- in case the class cannot be loaded with the context class loader.- See Also:
-
classForNameWithExceptionPEA
public static <T> PrivilegedExceptionAction<Class<T>> classForNameWithExceptionPEA(String name, ClassLoader cl) throws ClassNotFoundException Get privileged exception action to obtain Class from given class name. If run using security manager, the returned privileged exception action must be invoked within a doPrivileged block.- Type Parameters:
T
- class type.- Parameters:
name
- class name.cl
- class loader to use, ifnull
then the defining class loader of the calling class will be utilized.- Returns:
- privileged exception action to obtain the Class. If the class cannot be found, the action returns
null
, or throwsClassNotFoundException
in case the class loader has been specified. - Throws:
ClassNotFoundException
- in case the class cannot be loaded with the specified class loader.- See Also:
-
getContextClassLoaderPA
Get privileged action to obtain context class loader. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Returns:
- privileged action to obtain the actual context class loader. The action could return
null
if the context class loader has not been set. - See Also:
-
setContextClassLoaderPA
Get privileged action to set the actual context class loader. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
classLoader
- context class loader to be set.- Returns:
- privileged action to set context class loader.
- See Also:
-
setAccessibleMethodPA
Get privileged action to set a method to be accessible. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
m
- method to be set as accessible.- Returns:
- privileged action to set the method to be accessible.
- See Also:
-
isPublic
Returntrue
iff the method is public.- Parameters:
clazz
- The method in question- Returns:
true
if mod includes the public modifier;false
otherwise.
-
isPublic
Returntrue
iff the executable is public.- Parameters:
executable
- The executable in question- Returns:
true
if the executable includes the public modifier;false
otherwise.
-
getGenericTypeArgumentClasses
public static List<Class<?>> getGenericTypeArgumentClasses(Type type) throws IllegalArgumentException Get the list of classes that represent the type arguments of aparameterized
input type. For any given argument in the returned list, following rules apply:- If a type argument is a class then the class is returned.
- If the type argument is a generic array type and the generic component type is a class then class of the array is returned.
- If the type argument is a parameterized type and it's raw type is a class then that class is returned.
type
is not an instance of ParameterizedType an empty list is returned.- Parameters:
type
- parameterized type.- Returns:
- the list of classed representing the actual type arguments. May be empty,
but may never be
null
. - Throws:
IllegalArgumentException
- if any of the generic type arguments is not a class, or a generic array type, or the generic component type of the generic array type is not class, or not a parameterized type with a raw type that is not a class.
-
getTypeArgumentAndClass
public static List<ClassTypePair> getTypeArgumentAndClass(Type type) throws IllegalArgumentException Get the list of class-type pairs that represent the type arguments of aparameterized
input type. For any givenclass
part of each pair in the returned list, following rules apply:- If a type argument is a class then the class is returned as raw class.
- If the type argument is a generic array type and the generic component type is a class then class of the array is returned as raw class.
- If the type argument is a parameterized type and it's raw type is a class then that class is returned as raw class.
type
is not an instance of ParameterizedType an empty list is returned.- Parameters:
type
- parameterized type.- Returns:
- the list of class-type pairs representing the actual type arguments. May be empty, but may never be
null
. - Throws:
IllegalArgumentException
- if any of the generic type arguments is not a class, or a generic array type, or the generic component type of the generic array type is not class, or not a parameterized type with a raw type that is not a class.
-
isPrimitive
Check if the given type is a primitive type.- Parameters:
type
- type to be checked.- Returns:
true
in case the type represents a primitive type, otherwise returnsfalse
.
-
getTypeArguments
Get the type arguments for a parameterized type. In case the type is not aparameterized type
, the method returnsnull
.- Parameters:
type
- parameterized type.- Returns:
- type arguments for a parameterized type, or
null
in case the input type is not a parameterized type.
-
getTypeArgument
Get a type argument at particular index for a parameterized type. In case the type is not aparameterized type
, the method returnsnull
.- Parameters:
type
- parameterized type.index
- type parameter index.- Returns:
- type argument for a parameterized type at a given index, or
null
in case the input type is not a parameterized type.
-
erasure
Get theClass
representation of the given type. This corresponds to the notion of the erasure in JSR-14.- Parameters:
type
- type to provide the erasure for.- Returns:
- the given type's erasure.
-
isSubClassOf
Check ifsubType
is a sub-type ofsuperType
.- Parameters:
subType
- sub-type type.superType
- super-type type.- Returns:
true
in case thesubType
is a sub-type ofsuperType
,false
otherwise.
-
isArray
Checks if the type is an array type.- Parameters:
type
- type to check.- Returns:
true
in case the type is an array type,false
otherwise.
-
isArrayOfType
Checks if the type is an array of a given component type.- Parameters:
type
- type to check.componentType
- array component type.- Returns:
true
in case the type is an array type of a given component type,false
otherwise.
-
getArrayComponentType
Gets the component type of the array.- Parameters:
type
- must be an array.- Returns:
- array component type.
- Throws:
IllegalArgumentException
- in case the type is not an array type.
-
getArrayForComponentType
Get Array class of component type.- Parameters:
c
- the component class of the array- Returns:
- the array class.
-
getValueOfStringMethodPA
Get privileged action to obtain the static valueOf(String ) method. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- class to obtain the method.- Returns:
- privileged action to get the method.
The action could return
null
if the method is not present. - See Also:
-
getFromStringStringMethodPA
Get privileged action to get the static fromString(String ) method. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- class for which to get the method.- Returns:
- privileged action to obtain the method.
The action could return
null
if the method is not present. - See Also:
-
getStringConstructorPA
Get privileged action to obtain constructor that has a single parameter of String. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- The class for which to obtain the constructor.- Returns:
- privileged action to obtain the constructor.
The action could return
null
if the constructor is not present. - See Also:
-
getDeclaredConstructorsPA
Get privileged action to obtain declared constructors of given class. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- The class for which to obtain the constructors.- Returns:
- privileged action to obtain the array of constructors.
- See Also:
-
getDeclaredConstructorPA
public static PrivilegedAction<Constructor<?>> getDeclaredConstructorPA(Class<?> clazz, Class<?>... params) Get privileged action to obtain declared constructor of given class with given parameters. If run using security manager, the returned privileged action must be invoked within a doPrivileged block.- Parameters:
clazz
- The class for which to obtain the constructor.params
- constructor parameters.- Returns:
- privileged action to obtain the constructor or
null
, when constructor with given parameters is not found. - See Also:
-
getAnnotationTypes
public static Collection<Class<? extends Annotation>> getAnnotationTypes(AnnotatedElement annotatedElement, Class<? extends Annotation> metaAnnotation) Returns collection of all annotation types attached to a given annotated element that have the provided meta annotation attached.- Parameters:
annotatedElement
- annotated element.metaAnnotation
- meta annotation attached to the annotation types we are looking for (if null, annotation types of all attached annotations will be returned).- Returns:
- list of annotation types with a given meta annotation
-
isGetter
Determine whether a given method isgetter
.- Parameters:
method
- method to be examined.- Returns:
true
if the method isgetter
,false
otherwise.
-
genericTypeFor
Create ageneric type
information for a given Javainstance
.If the supplied instance is an instance of
GenericEntity
, the generic type information will be computed using theGenericEntity.getType()
information. Otherwise theinstance.getClass()
will be used.- Parameters:
instance
- Java instance for which theGenericType
description should be created.- Returns:
GenericType
describing the Javainstance
.
-
isSetter
Determine whether a given method issetter
.- Parameters:
method
- method to be examined.- Returns:
true
if the method issetter
,false
otherwise.
-
getPropertyName
Determine property (field) name from given getter/setter method.- Parameters:
method
- method to be examined.- Returns:
- property (field) name.
-
theMostSpecificTypeOf
Determine the most specific type from given set.- Parameters:
contractTypes
- to be taken into account.- Returns:
- the most specific type.
-
getParameterizedClassArguments
public static Class[] getParameterizedClassArguments(ReflectionHelper.DeclaringClassInterfacePair p) Get the parameterized class arguments for a declaring class that declares a generic interface type.- Parameters:
p
- the declaring class- Returns:
- the parameterized class arguments, or null if the generic interface type is not a parameterized type.
-
getParameterizedTypeArguments
Get the parameterized type arguments for a declaring class that declares a generic interface type.- Parameters:
p
- the declaring class- Returns:
- the parameterized type arguments, or null if the generic interface type is not a parameterized type.
-
getClass
public static ReflectionHelper.DeclaringClassInterfacePair getClass(Class<?> concrete, Class<?> iface) Find the declaring class that implements or extends an interface.- Parameters:
concrete
- the concrete class than directly or indirectly implements or extends an interface class.iface
- the interface class.- Returns:
- the tuple of the declaring class and the generic interface type.
-
resolveGenericType
public static ClassTypePair resolveGenericType(Class concreteClass, Class declaringClass, Class rawResolvedType, Type genericResolvedType) Resolve generic type parameter(s) of a raw class and it's generic type based on the class that declares the generic type parameter(s) to be resolved and a concrete implementation of the declaring class.- Parameters:
concreteClass
- concrete implementation of the declaring class.declaringClass
- class declaring the generic type parameter(s) to be resolved.rawResolvedType
- raw class of the generic type to be resolved.genericResolvedType
- generic type information of th type to be resolved.- Returns:
- a pair of class and the generic type values with the the resolved generic parameter types.
-
resolveTypeVariable
Given a type variable resolve the Java class of that variable.- Parameters:
c
- the concrete class from which all type variables are resolved.dc
- the declaring class where the type variable was defined.tv
- the type variable.- Returns:
- the resolved Java class and type, otherwise null if the type variable could not be resolved.
-
findMethodOnClassPA
Get privileged action to find a method on a class given an existing method. If run using security manager, the returned privileged action must be invoked within a doPrivileged block. If there exists a public method on the class that has the same name and parameters as the existing method then that public method is returned from the action. Otherwise, if there exists a public method on the class that has the same name and the same number of parameters as the existing method, and each generic parameter type, in order, of the public method is equal to the generic parameter type, in the same order, of the existing method or is an instance ofTypeVariable
then that public method is returned from the action.- Parameters:
c
- the class to search for a public methodm
- the method to find- Returns:
- privileged action to return public method found.
- See Also:
-
getMethodsPA
Get privileged action to return an array containingMethod
objects reflecting all the public member methods of the supplied class or interface object, including those declared by the class or interface and those inherited from superclasses and superinterfaces. Array classes return all the (public) member methods inherited from theObject
class. The elements in the array returned are not sorted and are not in any particular order. This method returns action providing an array of length 0 if thisClass
object represents a class or interface that has no public member methods, or if thisClass
object represents a primitive type or void.The class initialization method
<clinit>
is not included in the returned array. If the class declares multiple public member methods with the same parameter types, they are all included in the returned array.See The Java Language Specification, sections 8.2 and 8.4.
- Parameters:
c
- class for which the methods should be returned.- Returns:
- privileged action to obtain an array of
Method
objects representing the public methods of the class. - See Also:
-
findOverridingMethodOnClass
- Parameters:
clazz
- class to find overriding method on.method
- an abstract method to find implementing method for.- Returns:
- method that overrides the given method or the given method itself if a better alternative cannot be found.
-
getOsgiRegistryInstance
Returns anOsgiRegistry
instance.- Returns:
- an
OsgiRegistry
instance ornull
if the class cannot be instantiated (not in OSGi environment).
-
getResourceAsStream
public static InputStream getResourceAsStream(ClassLoader loader, Class<?> originClass, String name) Lookup resource by given name. If OSGi runtime is detected and the originClass parameter is not null, an attempt will be made to get the resource input stream via OSGi API from the bundle where originClass is included. Otherwise (non OSGi environment) or if OSGi fails to provide the input stream, the return value will be taken from the provided loader getResourceAsStream method.- Parameters:
loader
- class loader where to lookup the resource in non-OSGi environment or if OSGi means fail.originClass
- if not null, and OSGi environment is detected, the resource will be taken from the bundle including the originClass type.name
- filename of the desired resource.- Returns:
- an input stream corresponding to the required resource or null if the resource could not be found.
-
getRawClass
Given the type parameter gets the raw type represented by the type, or null if this has no associated raw class.- Parameters:
type
- the type to find the raw class on.- Returns:
- the raw class associated with this type.
-
isJaxbAvailable
public static boolean isJaxbAvailable()Returns true iff JAX-B API is available on classpath. -
isXmlTransformAvailable
public static boolean isXmlTransformAvailable()Returns true iff javax.xml.transform package is available on classpath.
-