org.reflections8.util.Utils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of reflections8 Show documentation
Show all versions of reflections8 Show documentation
Reflections8 - a Java runtime metadata analysis without guava on Java 8
package org.reflections8.util;
import static org.reflections8.ReflectionUtils.forName;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Constructor;
import java.lang.reflect.Field;
import java.lang.reflect.Member;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Optional;
import java.util.Set;
import org.reflections8.Reflections;
import org.reflections8.ReflectionsException;
import org.reflections8.scanners.Scanner;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* a garbage can of convenient methods
*/
public abstract class Utils {
public static String repeat(String string, int times) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < times; i++) {
sb.append(string);
}
return sb.toString();
}
/**
* isEmpty compatible with Java 5
*/
public static boolean isEmpty(String s) {
return s == null || s.length() == 0;
}
public static boolean isEmpty(Object[] objects) {
return objects == null || objects.length == 0;
}
public static File prepareFile(String filename) {
File file = new File(filename);
File parent = file.getAbsoluteFile().getParentFile();
if (!parent.exists()) {
//noinspection ResultOfMethodCallIgnored
parent.mkdirs();
}
return file;
}
public static Member getMemberFromDescriptor(String descriptor, ClassLoader... classLoaders) throws ReflectionsException {
return getMemberFromDescriptor(descriptor, Optional.of(classLoaders != null? classLoaders : new ClassLoader[]{}));
}
public static Member getMemberFromDescriptor(String descriptor, Optional classLoaders) throws ReflectionsException {
int p0 = descriptor.lastIndexOf('(');
String memberKey = p0 != -1 ? descriptor.substring(0, p0) : descriptor;
String methodParameters = p0 != -1 ? descriptor.substring(p0 + 1, descriptor.lastIndexOf(')')) : "";
int p1 = Math.max(memberKey.lastIndexOf('.'), memberKey.lastIndexOf("$"));
String className = memberKey.substring(memberKey.lastIndexOf(' ') + 1, p1);
String memberName = memberKey.substring(p1 + 1);
Class>[] parameterTypes = null;
if (!isEmpty(methodParameters)) {
String[] parameterNames = methodParameters.split(",");
List> result = new ArrayList>(parameterNames.length);
for (String name : parameterNames) {
result.add(forName(name.trim(), classLoaders));
}
parameterTypes = result.toArray(new Class>[result.size()]);
}
Class> aClass = forName(className, classLoaders);
while (aClass != null) {
try {
if (!descriptor.contains("(")) {
return aClass.isInterface() ? aClass.getField(memberName) : aClass.getDeclaredField(memberName);
} else if (isConstructor(descriptor)) {
return aClass.isInterface() ? aClass.getConstructor(parameterTypes) : aClass.getDeclaredConstructor(parameterTypes);
} else {
return aClass.isInterface() ? aClass.getMethod(memberName, parameterTypes) : aClass.getDeclaredMethod(memberName, parameterTypes);
}
} catch (Exception e) {
aClass = aClass.getSuperclass();
}
}
throw new ReflectionsException("Can't resolve member named " + memberName + " for class " + className);
}
public static Set getMethodsFromDescriptors(Iterable annotatedWith, Optional classLoaders) {
Set result = new HashSet();
for (String annotated : annotatedWith) {
if (!isConstructor(annotated)) {
Method member = (Method) getMemberFromDescriptor(annotated, classLoaders);
if (member != null) result.add(member);
}
}
return result;
}
public static Set getMethodsFromDescriptors(Iterable annotatedWith, ClassLoader... classLoaders) {
return getMethodsFromDescriptors(annotatedWith, Optional.of(classLoaders != null? classLoaders : new ClassLoader[]{}));
}
public static Set getConstructorsFromDescriptors(Iterable annotatedWith, Optional classLoaders) {
Set result = new HashSet();
for (String annotated : annotatedWith) {
if (isConstructor(annotated)) {
Constructor member = (Constructor) getMemberFromDescriptor(annotated, classLoaders);
if (member != null) result.add(member);
}
}
return result;
}
public static Set getConstructorsFromDescriptors(Iterable annotatedWith, ClassLoader... classLoaders) {
return getConstructorsFromDescriptors(annotatedWith, Optional.of(classLoaders != null? classLoaders : new ClassLoader[]{}));
}
public static Set getMembersFromDescriptors(Iterable values, Optional classLoaders) {
Set result = new HashSet();
for (String value : values) {
try {
result.add(Utils.getMemberFromDescriptor(value, classLoaders));
} catch (ReflectionsException e) {
throw new ReflectionsException("Can't resolve member named " + value, e);
}
}
return result;
}
public static Set getMembersFromDescriptors(Iterable values, ClassLoader... classLoaders) {
return getMembersFromDescriptors(values, Optional.of(classLoaders != null? classLoaders : new ClassLoader[]{}));
}
public static Field getFieldFromString(String field, ClassLoader... classLoaders) {
return getFieldFromString(field, Optional.of(classLoaders != null? classLoaders : new ClassLoader[]{}));
}
public static Field getFieldFromString(String field, Optional classLoaders) {
String className = field.substring(0, field.lastIndexOf('.'));
String fieldName = field.substring(field.lastIndexOf('.') + 1);
try {
return forName(className, classLoaders).getDeclaredField(fieldName);
} catch (NoSuchFieldException e) {
throw new ReflectionsException("Can't resolve field named " + fieldName, e);
}
}
public static void close(InputStream closeable) {
try { if (closeable != null) closeable.close(); }
catch (IOException e) {
if (Reflections.log.isPresent()) {
Reflections.log.get().warn("Could not close InputStream", e);
}
}
}
public static Optional findLogger(Class> aClass) {
try {
// This is to check whether an optional SLF4J binding is available. While SLF4J recommends that libraries
// "should not declare a dependency on any SLF4J binding but only depend on slf4j-api", doing so forces
// users of the library to either add a binding to the classpath (even if just slf4j-nop) or to set the
// "slf4j.suppressInitError" system property in order to avoid the warning, which both is inconvenient.
Class.forName("org.slf4j.impl.StaticLoggerBinder");
return Optional.of(LoggerFactory.getLogger(aClass));
} catch (Throwable e) {
return Optional.empty();
}
}
public static boolean isConstructor(String fqn) {
return fqn.contains("init>");
}
public static String name(Class type) {
if (!type.isArray()) {
return type.getName();
} else {
int dim = 0;
while (type.isArray()) {
dim++;
type = type.getComponentType();
}
return type.getName() + repeat("[]", dim);
}
}
public static List names(Iterable> types) {
List result = new ArrayList();
for (Class> type : types) result.add(name(type));
return result;
}
public static List names(Class>... types) {
return names(Arrays.asList(types));
}
public static String name(Constructor constructor) {
return constructor.getName() + "." + "" + "(" + Joiner.on(", ").join(names(constructor.getParameterTypes())) + ")";
}
public static String name(Method method) {
return method.getDeclaringClass().getName() + "." + method.getName() + "(" + Joiner.on(", ").join(names(method.getParameterTypes())) + ")";
}
public static String name(Field field) {
return field.getDeclaringClass().getName() + "." + field.getName();
}
public static String index(Class extends Scanner> scannerClass) { return scannerClass.getSimpleName(); }
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy