data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
com.effektif.workflow.impl.util.Reflection Maven / Gradle / Ivy
/*
* Copyright 2014 Effektif GmbH.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.effektif.workflow.impl.util;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.lang.reflect.TypeVariable;
import java.lang.reflect.WildcardType;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.effektif.workflow.api.json.GenericType;
/**
* @author Tom Baeyens
*/
public class Reflection {
private static final Logger log = LoggerFactory.getLogger(Reflection.class);
public static List getNonStaticFieldsRecursive(Class< ? > type) {
List fieldCollector = new ArrayList<>();
collectNonStaticFieldsRecursive(type, fieldCollector);
return fieldCollector;
}
static void collectNonStaticFieldsRecursive(Class< ? > type, List fieldCollector) {
Field[] fields = type.getDeclaredFields();
if (fields!=null) {
for (Field field: fields) {
if (!Modifier.isStatic(field.getModifiers())) {
fieldCollector.add(field);
}
}
}
Class< ? > superclass = type.getSuperclass();
if (superclass!=null && superclass!=Object.class) {
collectNonStaticFieldsRecursive(superclass, fieldCollector);
}
}
public static T newInstance(Class type) {
if (type==null) {
return null;
}
try {
return type.newInstance();
} catch (Exception e) {
throw new RuntimeException("Couldn't instantiate "+type+" with the default constructor: "+e.getMessage(), e);
}
}
public static Class< ? > loadClass(String className) {
Class> clazz = null;
if (className!=null) {
try {
clazz = Class.forName(className);
} catch (ClassNotFoundException e) {
log.debug("Class not found with effektif classloader: "+className+". Trying context classloader...");
try {
clazz = Class.forName(className, true, Thread.currentThread().getContextClassLoader());
} catch (ClassNotFoundException e1) {
log.debug("Class not found with context classloader: "+className+". Giving up.");
}
}
}
return clazz;
}
public static Class< ? > getClass(Type type) {
Class> clazz = null;
if (type instanceof Class) {
clazz = (Class>) type;
} else if (type instanceof ParameterizedType) {
ParameterizedType parameterizedType = (ParameterizedType) type;
clazz = (Class< ? >) parameterizedType.getRawType();
} else if (type instanceof WildcardType) {
WildcardType wildcardType = (WildcardType) type;
clazz = (Class< ? >) wildcardType.getUpperBounds()[0];
} else if (type instanceof GenericType) {
clazz = ((GenericType)type).getRawClass();
}
return clazz;
}
public static Type getTypeArg(Type type, int i) {
if (type instanceof ParameterizedType) {
Type[] typeArgs = ((ParameterizedType) type).getActualTypeArguments();
if (typeArgs!=null && i getRawClass(Type type) {
if (type==null) {
return null;
}
if (type instanceof Class) {
return (Class>)type;
}
if (type instanceof ParameterizedType) {
return (Class>) ((ParameterizedType)type).getRawType();
}
if (type instanceof GenericType) {
return ((GenericType)type).getRawClass();
}
if (type instanceof WildcardType) {
return (Class) ((WildcardType)type).getUpperBounds()[0];
}
throw new RuntimeException("Unexpected type: "+type+" ("+type.getClass().getName()+"). Please perform GenericType.unify on the type first");
}
public static Type getSuperclass(Type type) {
return getRawClass(type).getGenericSuperclass();
}
public static String getSimpleName(Type type) {
if (type==null) {
return "null";
}
if (type instanceof Class) {
return ((Class)type).getSimpleName();
}
if (type instanceof ParameterizedType) {
ParameterizedType parameterizedType = (ParameterizedType) type;
StringBuilder name = new StringBuilder();
String rawname = getRawClass(parameterizedType.getRawType()).getSimpleName();
name.append(rawname);
Type[] typeArgs = parameterizedType.getActualTypeArguments();
if (typeArgs!=null) {
name.append("<");
for (int i = 0; i < typeArgs.length; i++) {
if (i!=0) {
name.append(",");
}
name.append(getSimpleName(typeArgs[i]));
}
name.append(">");
}
return name.toString();
}
return type.toString();
}
public static Object instantiate(Class< ? > clazz) {
try {
return clazz.newInstance();
} catch (InstantiationException | IllegalAccessException e) {
throw new RuntimeException("Couldn't instantiate "+clazz, e);
}
}
public static boolean isParameterized(Type type) {
return type instanceof ParameterizedType
|| type instanceof GenericType;
}
public static Type[] getTypeArgs(Type type) {
if (type instanceof ParameterizedType) {
return ((ParameterizedType)type).getActualTypeArguments();
}
if (type instanceof GenericType) {
return ((GenericType)type).getTypeArgs();
}
return null;
}
public static Map getTypeArgsMap(Type type) {
Type[] typeArgs = getTypeArgs(type);
if (typeArgs==null) {
return null;
}
Class> rawClass = getRawClass(type);
Map typeVariables = new HashMap<>();
TypeVariable>[] typeParameters = rawClass.getTypeParameters();
for (int i=0; i clazz, String methodName) {
return findMethod(clazz, methodName, null);
}
/** @Param args null means don't match args */
public static Method findMethod(Class> clazz, String methodName, Object[] args) {
if (clazz==null || methodName==null) {
return null;
}
for (Method method: clazz.getDeclaredMethods()) {
if (method.getName().equals(methodName)) {
if (argsMatch(method, args)) {
return method;
}
}
}
if (clazz.getSuperclass()!=null) {
return findMethod(clazz.getSuperclass(), methodName, args);
}
return null;
}
static boolean argsMatch(Method method, Object[] args) {
if (args==null) {
return true;
}
Class< ? >[] parameterTypes = method.getParameterTypes();
if (parameterTypes==null || parameterTypes.length!=args.length) {
return false;
}
for (int i=0; i
© 2015 - 2025 Weber Informatics LLC | Privacy Policy