public abstract class nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils extends java.lang.Object
{
private static final java.lang.Class[] EMPTY_CLASS_ARRAY;
private static final java.lang.reflect.Method[] EMPTY_METHOD_ARRAY;
private static final java.lang.Object[] EMPTY_OBJECT_ARRAY;
private static final java.util.Map DECLARED_METHODS_CACHE;
private void <init>()
{
nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils v;
v := @this: nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static void handleReflectionException(java.lang.Exception)
{
java.lang.IllegalStateException v, v;
java.lang.reflect.UndeclaredThrowableException v;
java.lang.Exception v;
java.lang.String v, v, v, v;
boolean v, v, v, v;
v := @parameter: java.lang.Exception;
v = v instanceof java.lang.NoSuchMethodException;
if v == 0 goto label;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Method not found: \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v instanceof java.lang.IllegalAccessException;
if v == 0 goto label;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Could not access method or field: \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v instanceof java.lang.reflect.InvocationTargetException;
if v == 0 goto label;
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: void handleInvocationTargetException(java.lang.reflect.InvocationTargetException)>(v);
label:
v = v instanceof java.lang.RuntimeException;
if v == 0 goto label;
throw v;
label:
v = new java.lang.reflect.UndeclaredThrowableException;
specialinvoke v.<java.lang.reflect.UndeclaredThrowableException: void <init>(java.lang.Throwable)>(v);
throw v;
}
public static void handleInvocationTargetException(java.lang.reflect.InvocationTargetException)
{
java.lang.Throwable v;
java.lang.reflect.InvocationTargetException v;
v := @parameter: java.lang.reflect.InvocationTargetException;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: void rethrowRuntimeException(java.lang.Throwable)>(v);
return;
}
public static void rethrowRuntimeException(java.lang.Throwable)
{
java.lang.Throwable v;
java.lang.reflect.UndeclaredThrowableException v;
boolean v, v;
v := @parameter: java.lang.Throwable;
v = v instanceof java.lang.RuntimeException;
if v == 0 goto label;
throw v;
label:
v = v instanceof java.lang.Error;
if v == 0 goto label;
throw v;
label:
v = new java.lang.reflect.UndeclaredThrowableException;
specialinvoke v.<java.lang.reflect.UndeclaredThrowableException: void <init>(java.lang.Throwable)>(v);
throw v;
}
public static java.lang.reflect.Method findMethod(java.lang.Class, java.lang.String)
{
java.lang.Class[] v;
java.lang.Class v;
java.lang.String v;
java.lang.reflect.Method v;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.String;
v = <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.Class[] EMPTY_CLASS_ARRAY>;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.reflect.Method findMethod(java.lang.Class,java.lang.String,java.lang.Class[])>(v, v, v);
return v;
}
public static transient java.lang.reflect.Method findMethod(java.lang.Class, java.lang.String, java.lang.Class[])
{
java.lang.Class[] v;
java.lang.reflect.Method[] v, v;
int v, v;
java.lang.Class v, v;
java.lang.String v, v;
java.lang.reflect.Method v;
boolean v, v, v;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class[];
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Class must not be null");
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Method name must not be null");
v = v;
label:
if v == null goto label;
v = virtualinvoke v.<java.lang.Class: boolean isInterface()>();
if v == 0 goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method[] getMethods()>();
goto label;
label:
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.reflect.Method[] getDeclaredMethods(java.lang.Class,boolean)>(v, 0);
label:
v = v;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
if v == null goto label;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: boolean hasSameParams(java.lang.reflect.Method,java.lang.Class[])>(v, v);
if v == 0 goto label;
label:
return v;
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.Class getSuperclass()>();
goto label;
label:
return null;
}
private static boolean hasSameParams(java.lang.reflect.Method, java.lang.Class[])
{
int v, v;
java.lang.Class[] v, v;
java.lang.reflect.Method v;
boolean v, v;
v := @parameter: java.lang.reflect.Method;
v := @parameter: java.lang.Class[];
v = lengthof v;
v = virtualinvoke v.<java.lang.reflect.Method: int getParameterCount()>();
if v != v goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class[] getParameterTypes()>();
v = staticinvoke <java.util.Arrays: boolean equals(java.lang.Object[],java.lang.Object[])>(v, v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static java.lang.Object invokeMethod(java.lang.reflect.Method, java.lang.Object)
{
java.lang.Object[] v;
java.lang.Object v, v;
java.lang.reflect.Method v;
v := @parameter: java.lang.reflect.Method;
v := @parameter: java.lang.Object;
v = <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.Object[] EMPTY_OBJECT_ARRAY>;
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.Object invokeMethod(java.lang.reflect.Method,java.lang.Object,java.lang.Object[])>(v, v, v);
return v;
}
public static transient java.lang.Object invokeMethod(java.lang.reflect.Method, java.lang.Object, java.lang.Object[])
{
java.lang.IllegalStateException v;
java.lang.Object[] v;
java.lang.Object v, v;
java.lang.reflect.Method v;
java.lang.Exception v;
v := @parameter: java.lang.reflect.Method;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object[];
label:
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, v);
label:
return v;
label:
v := @caughtexception;
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: void handleReflectionException(java.lang.Exception)>(v);
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Should never get here");
throw v;
catch java.lang.Exception from label to label with label;
}
private static java.lang.reflect.Method[] getDeclaredMethods(java.lang.Class, boolean)
{
java.lang.Throwable v;
java.lang.IllegalStateException v;
java.lang.reflect.Method[] v, v;
java.util.Map v, v;
int v, v, v, v, v, v, v;
java.lang.String v, v;
boolean v, v;
java.util.Iterator v;
java.util.List v;
java.lang.Class v;
java.lang.Object v, v, v;
java.lang.ClassLoader v;
v := @parameter: java.lang.Class;
v := @parameter: boolean;
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Class must not be null");
v = <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.util.Map DECLARED_METHODS_CACHE>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method[] getDeclaredMethods()>();
v = staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.util.List findConcreteMethodsOnInterfaces(java.lang.Class)>(v);
if v == null goto label;
v = lengthof v;
v = interfaceinvoke v.<java.util.List: int size()>();
v = v + v;
v = newarray (java.lang.reflect.Method)[v];
v = lengthof v;
staticinvoke <java.lang.System: void arraycopy(java.lang.Object,int,java.lang.Object,int,int)>(v, 0, v, 0, v);
v = lengthof v;
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v[v] = v;
v = v + 1;
goto label;
label:
v = v;
label:
v = <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.util.Map DECLARED_METHODS_CACHE>;
v = lengthof v;
if v != 0 goto label;
v = <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.reflect.Method[] EMPTY_METHOD_ARRAY>;
goto label;
label:
v = v;
label:
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.ClassLoader)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Failed to introspect Class [\u] from ClassLoader [\u]");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v = lengthof v;
if v == 0 goto label;
if v == 0 goto label;
v = virtualinvoke v.<java.lang.Object: java.lang.Object clone()>();
label:
return v;
catch java.lang.Throwable from label to label with label;
}
private static java.util.List findConcreteMethodsOnInterfaces(java.lang.Class)
{
java.lang.Class[] v;
java.lang.reflect.Method[] v;
java.util.ArrayList v, v;
int v, v, v, v, v;
java.lang.Class v, v;
java.lang.reflect.Method v;
boolean v;
v := @parameter: java.lang.Class;
v = null;
v = virtualinvoke v.<java.lang.Class: java.lang.Class[] getInterfaces()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method[] getMethods()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.reflect.Method: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isAbstract(int)>(v);
if v != 0 goto label;
if v != null goto label;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = v;
label:
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
v = v + 1;
goto label;
label:
v = v + 1;
goto label;
label:
return v;
}
public static java.lang.Object getField(java.lang.reflect.Field, java.lang.Object)
{
java.lang.IllegalStateException v;
java.lang.IllegalAccessException v;
java.lang.Object v, v;
java.lang.reflect.Field v;
v := @parameter: java.lang.reflect.Field;
v := @parameter: java.lang.Object;
label:
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.Object get(java.lang.Object)>(v);
label:
return v;
label:
v := @caughtexception;
staticinvoke <nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: void handleReflectionException(java.lang.Exception)>(v);
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Should never get here");
throw v;
catch java.lang.IllegalAccessException from label to label with label;
}
static void <clinit>()
{
nl.basjes.parse.useragent.utils.springframework.util.ConcurrentReferenceHashMap v;
java.lang.Object[] v;
java.lang.Class[] v;
java.lang.reflect.Method[] v;
v = newarray (java.lang.Class)[0];
<nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.Class[] EMPTY_CLASS_ARRAY> = v;
v = newarray (java.lang.reflect.Method)[0];
<nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.reflect.Method[] EMPTY_METHOD_ARRAY> = v;
v = newarray (java.lang.Object)[0];
<nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.lang.Object[] EMPTY_OBJECT_ARRAY> = v;
v = new nl.basjes.parse.useragent.utils.springframework.util.ConcurrentReferenceHashMap;
specialinvoke v.<nl.basjes.parse.useragent.utils.springframework.util.ConcurrentReferenceHashMap: void <init>(int)>(256);
<nl.basjes.parse.useragent.utils.springframework.util.ReflectionUtils: java.util.Map DECLARED_METHODS_CACHE> = v;
return;
}
}