public abstract class org.springframework.util.ReflectionUtils extends java.lang.Object
{
private static final java.lang.String CGLIB_RENAMED_METHOD_PREFIX;
private static final java.lang.reflect.Method[] NO_METHODS;
private static final java.lang.reflect.Field[] NO_FIELDS;
private static final java.util.Map declaredMethodsCache;
private static final java.util.Map declaredFieldsCache;
public static final org.springframework.util.ReflectionUtils$MethodFilter NON_BRIDGED_METHODS;
public static final org.springframework.util.ReflectionUtils$MethodFilter USER_DECLARED_METHODS;
public static final org.springframework.util.ReflectionUtils$FieldFilter COPYABLE_FIELDS;
public void <init>()
{
org.springframework.util.ReflectionUtils v;
v := @this: org.springframework.util.ReflectionUtils;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static java.lang.reflect.Field findField(java.lang.Class, java.lang.String)
{
java.lang.Class v;
java.lang.String v;
java.lang.reflect.Field v;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.String;
v = staticinvoke <org.springframework.util.ReflectionUtils: java.lang.reflect.Field findField(java.lang.Class,java.lang.String,java.lang.Class)>(v, v, null);
return v;
}
public static java.lang.reflect.Field findField(java.lang.Class, java.lang.String, java.lang.Class)
{
java.lang.reflect.Field v;
java.lang.reflect.Field[] v;
int v, v;
java.lang.Class v, v, v, v;
java.lang.String v, v;
boolean v, v, v;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Class must not be null");
if v != null goto label;
if v == null goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
staticinvoke <org.springframework.util.Assert: void isTrue(boolean,java.lang.String)>(v, "Either name or type of the field must be specified");
v = v;
label:
if class "Ljava/lang/Object;" == v goto label;
if v == null goto label;
v = staticinvoke <org.springframework.util.ReflectionUtils: java.lang.reflect.Field[] getDeclaredFields(java.lang.Class)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
if v == null goto label;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
if v == null goto label;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.Class getType()>();
v = virtualinvoke v.<java.lang.Object: boolean equals(java.lang.Object)>(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;
}
public static void setField(java.lang.reflect.Field, java.lang.Object, java.lang.Object)
{
java.lang.IllegalStateException v;
java.lang.IllegalAccessException v;
java.lang.reflect.Field v;
java.lang.Class v;
java.lang.Object v, v;
java.lang.String v, v, v;
v := @parameter: java.lang.reflect.Field;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object;
label:
virtualinvoke v.<java.lang.reflect.Field: void set(java.lang.Object,java.lang.Object)>(v, v);
label:
goto label;
label:
v := @caughtexception;
staticinvoke <org.springframework.util.ReflectionUtils: void handleReflectionException(java.lang.Exception)>(v);
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.IllegalAccessException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("Unexpected reflection exception - \u0001: \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
catch java.lang.IllegalAccessException from label to label with label;
}
public static java.lang.Object getField(java.lang.reflect.Field, java.lang.Object)
{
java.lang.IllegalStateException v;
java.lang.IllegalAccessException v;
java.lang.reflect.Field v;
java.lang.Class v;
java.lang.Object v, v;
java.lang.String v, v, 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 <org.springframework.util.ReflectionUtils: void handleReflectionException(java.lang.Exception)>(v);
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.IllegalAccessException: java.lang.String getMessage()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("Unexpected reflection exception - \u0001: \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
catch java.lang.IllegalAccessException from label to label with label;
}
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 = newarray (java.lang.Class)[0];
v = staticinvoke <org.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, 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 <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Class must not be null");
staticinvoke <org.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 <org.springframework.util.ReflectionUtils: java.lang.reflect.Method[] getDeclaredMethods(java.lang.Class)>(v);
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 = 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;
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;
}
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 = newarray (java.lang.Object)[0];
v = staticinvoke <org.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 <org.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;
}
public static java.lang.Object invokeJdbcMethod(java.lang.reflect.Method, java.lang.Object) throws java.sql.SQLException
{
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 = newarray (java.lang.Object)[0];
v = staticinvoke <org.springframework.util.ReflectionUtils: java.lang.Object invokeJdbcMethod(java.lang.reflect.Method,java.lang.Object,java.lang.Object[])>(v, v, v);
return v;
}
public static transient java.lang.Object invokeJdbcMethod(java.lang.reflect.Method, java.lang.Object, java.lang.Object[]) throws java.sql.SQLException
{
java.lang.Throwable v, v;
java.lang.IllegalStateException v;
java.lang.IllegalAccessException v;
java.lang.Object[] v;
java.lang.reflect.InvocationTargetException v;
java.lang.Object v, v;
java.lang.reflect.Method v;
boolean 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 <org.springframework.util.ReflectionUtils: void handleReflectionException(java.lang.Exception)>(v);
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
v = v instanceof java.sql.SQLException;
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
throw v;
label:
staticinvoke <org.springframework.util.ReflectionUtils: void handleInvocationTargetException(java.lang.reflect.InvocationTargetException)>(v);
label:
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;
catch java.lang.reflect.InvocationTargetException from label to label with label;
}
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: \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 <org.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 <org.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 void rethrowException(java.lang.Throwable) throws java.lang.Exception
{
java.lang.Throwable v;
java.lang.reflect.UndeclaredThrowableException v;
boolean v, v;
v := @parameter: java.lang.Throwable;
v = v instanceof java.lang.Exception;
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 boolean declaresException(java.lang.reflect.Method, java.lang.Class)
{
int v, v;
java.lang.Class[] v;
java.lang.Class v, v;
java.lang.reflect.Method v;
boolean v;
v := @parameter: java.lang.reflect.Method;
v := @parameter: java.lang.Class;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Method must not be null");
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class[] getExceptionTypes()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v == 0 goto label;
return 1;
label:
v = v + 1;
goto label;
label:
return 0;
}
public static boolean isPublicStaticFinal(java.lang.reflect.Field)
{
int v;
java.lang.reflect.Field v;
boolean v, v, v, v;
v := @parameter: java.lang.reflect.Field;
v = virtualinvoke v.<java.lang.reflect.Field: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isPublic(int)>(v);
if v == 0 goto label;
v = staticinvoke <java.lang.reflect.Modifier: boolean isStatic(int)>(v);
if v == 0 goto label;
v = staticinvoke <java.lang.reflect.Modifier: boolean isFinal(int)>(v);
if v == 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static boolean isEqualsMethod(java.lang.reflect.Method)
{
int v;
java.lang.Class[] v;
java.lang.Class v;
java.lang.String v;
java.lang.reflect.Method v;
boolean v, v;
v := @parameter: java.lang.reflect.Method;
if v == null goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("equals");
if v != 0 goto label;
label:
return 0;
label:
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class[] getParameterTypes()>();
v = lengthof v;
if v != 1 goto label;
v = v[0];
if v != class "Ljava/lang/Object;" goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static boolean isHashCodeMethod(java.lang.reflect.Method)
{
int v;
java.lang.Class[] v;
java.lang.String v;
java.lang.reflect.Method v;
boolean v, v;
v := @parameter: java.lang.reflect.Method;
if v == null goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("hashCode");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class[] getParameterTypes()>();
v = lengthof v;
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static boolean isToStringMethod(java.lang.reflect.Method)
{
int v;
java.lang.Class[] v;
java.lang.String v;
java.lang.reflect.Method v;
boolean v, v;
v := @parameter: java.lang.reflect.Method;
if v == null goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("toString");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class[] getParameterTypes()>();
v = lengthof v;
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static boolean isObjectMethod(java.lang.reflect.Method)
{
java.lang.Class[] v;
java.lang.Class v;
java.lang.String v;
java.lang.reflect.Method v;
java.lang.Exception v;
v := @parameter: java.lang.reflect.Method;
if v != null goto label;
return 0;
label:
v = class "Ljava/lang/Object;";
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class[] getParameterTypes()>();
virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getDeclaredMethod(java.lang.String,java.lang.Class[])>(v, v);
label:
return 1;
label:
v := @caughtexception;
return 0;
catch java.lang.Exception from label to label with label;
}
public static boolean isCglibRenamedMethod(java.lang.reflect.Method)
{
char v, v;
int v, v, v, v, v;
java.lang.String v, v;
java.lang.reflect.Method v;
boolean v, v, v;
v := @parameter: java.lang.reflect.Method;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("CGLIB$");
if v == 0 goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - 1;
label:
if v < 0 goto label;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(v);
v = staticinvoke <java.lang.Character: boolean isDigit(char)>(v);
if v == 0 goto label;
v = v - 1;
goto label;
label:
v = "CGLIB$";
v = virtualinvoke v.<java.lang.String: int length()>();
if v <= v goto label;
v = virtualinvoke v.<java.lang.String: int length()>();
v = v - 1;
if v >= v goto label;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(v);
if v != 36 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
label:
return 0;
}
public static void makeAccessible(java.lang.reflect.Field)
{
java.lang.reflect.Field v;
int v, v, v;
java.lang.Class v;
boolean v, v, v, v;
v := @parameter: java.lang.reflect.Field;
v = virtualinvoke v.<java.lang.reflect.Field: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isPublic(int)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.Class getDeclaringClass()>();
v = virtualinvoke v.<java.lang.Class: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isPublic(int)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Field: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isFinal(int)>(v);
if v == 0 goto label;
label:
v = virtualinvoke v.<java.lang.reflect.Field: boolean isAccessible()>();
if v != 0 goto label;
virtualinvoke v.<java.lang.reflect.Field: void setAccessible(boolean)>(1);
label:
return;
}
public static void makeAccessible(java.lang.reflect.Method)
{
int v, v;
java.lang.Class v;
java.lang.reflect.Method v;
boolean v, v, v;
v := @parameter: java.lang.reflect.Method;
v = virtualinvoke v.<java.lang.reflect.Method: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isPublic(int)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Class getDeclaringClass()>();
v = virtualinvoke v.<java.lang.Class: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isPublic(int)>(v);
if v != 0 goto label;
label:
v = virtualinvoke v.<java.lang.reflect.Method: boolean isAccessible()>();
if v != 0 goto label;
virtualinvoke v.<java.lang.reflect.Method: void setAccessible(boolean)>(1);
label:
return;
}
public static void makeAccessible(java.lang.reflect.Constructor)
{
int v, v;
java.lang.Class v;
java.lang.reflect.Constructor v;
boolean v, v, v;
v := @parameter: java.lang.reflect.Constructor;
v = virtualinvoke v.<java.lang.reflect.Constructor: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isPublic(int)>(v);
if v == 0 goto label;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Class getDeclaringClass()>();
v = virtualinvoke v.<java.lang.Class: int getModifiers()>();
v = staticinvoke <java.lang.reflect.Modifier: boolean isPublic(int)>(v);
if v != 0 goto label;
label:
v = virtualinvoke v.<java.lang.reflect.Constructor: boolean isAccessible()>();
if v != 0 goto label;
virtualinvoke v.<java.lang.reflect.Constructor: void setAccessible(boolean)>(1);
label:
return;
}
public static void doWithLocalMethods(java.lang.Class, org.springframework.util.ReflectionUtils$MethodCallback)
{
java.lang.IllegalStateException v;
java.lang.IllegalAccessException v;
java.lang.reflect.Method[] v;
org.springframework.util.ReflectionUtils$MethodCallback v;
int v, v;
java.lang.Class v;
java.lang.String v, v;
java.lang.reflect.Method v;
v := @parameter: java.lang.Class;
v := @parameter: org.springframework.util.ReflectionUtils$MethodCallback;
v = staticinvoke <org.springframework.util.ReflectionUtils: java.lang.reflect.Method[] getDeclaredMethods(java.lang.Class)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
label:
interfaceinvoke v.<org.springframework.util.ReflectionUtils$MethodCallback: void doWith(java.lang.reflect.Method)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.IllegalAccessException)>(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[])>("Not allowed to access method \'\u0001\': \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v + 1;
goto label;
label:
return;
catch java.lang.IllegalAccessException from label to label with label;
}
public static void doWithMethods(java.lang.Class, org.springframework.util.ReflectionUtils$MethodCallback)
{
org.springframework.util.ReflectionUtils$MethodCallback v;
java.lang.Class v;
v := @parameter: java.lang.Class;
v := @parameter: org.springframework.util.ReflectionUtils$MethodCallback;
staticinvoke <org.springframework.util.ReflectionUtils: void doWithMethods(java.lang.Class,org.springframework.util.ReflectionUtils$MethodCallback,org.springframework.util.ReflectionUtils$MethodFilter)>(v, v, null);
return;
}
public static void doWithMethods(java.lang.Class, org.springframework.util.ReflectionUtils$MethodCallback, org.springframework.util.ReflectionUtils$MethodFilter)
{
java.lang.IllegalStateException v;
java.lang.reflect.Method[] v;
org.springframework.util.ReflectionUtils$MethodCallback v;
int v, v, v, v;
java.lang.String v, v;
java.lang.reflect.Method v;
boolean v, v;
java.lang.IllegalAccessException v;
java.lang.Class[] v;
org.springframework.util.ReflectionUtils$MethodFilter v;
java.lang.Class v, v, v, v;
v := @parameter: java.lang.Class;
v := @parameter: org.springframework.util.ReflectionUtils$MethodCallback;
v := @parameter: org.springframework.util.ReflectionUtils$MethodFilter;
v = staticinvoke <org.springframework.util.ReflectionUtils: java.lang.reflect.Method[] getDeclaredMethods(java.lang.Class)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
if v == null goto label;
v = interfaceinvoke v.<org.springframework.util.ReflectionUtils$MethodFilter: boolean matches(java.lang.reflect.Method)>(v);
if v == 0 goto label;
label:
interfaceinvoke v.<org.springframework.util.ReflectionUtils$MethodCallback: void doWith(java.lang.reflect.Method)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.IllegalAccessException)>(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[])>("Not allowed to access method \'\u0001\': \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.Class getSuperclass()>();
if v == null goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.Class getSuperclass()>();
staticinvoke <org.springframework.util.ReflectionUtils: void doWithMethods(java.lang.Class,org.springframework.util.ReflectionUtils$MethodCallback,org.springframework.util.ReflectionUtils$MethodFilter)>(v, v, v);
goto label;
label:
v = virtualinvoke v.<java.lang.Class: boolean isInterface()>();
if v == 0 goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.Class[] getInterfaces()>();
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
staticinvoke <org.springframework.util.ReflectionUtils: void doWithMethods(java.lang.Class,org.springframework.util.ReflectionUtils$MethodCallback,org.springframework.util.ReflectionUtils$MethodFilter)>(v, v, v);
v = v + 1;
goto label;
label:
return;
catch java.lang.IllegalAccessException from label to label with label;
}
public static java.lang.reflect.Method[] getAllDeclaredMethods(java.lang.Class)
{
java.lang.Object[] v;
org.springframework.util.ReflectionUtils$1 v;
int v;
java.lang.Class v;
java.lang.reflect.Method[] v;
java.util.ArrayList v;
v := @parameter: java.lang.Class;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(32);
v = new org.springframework.util.ReflectionUtils$1;
specialinvoke v.<org.springframework.util.ReflectionUtils$1: void <init>(java.util.List)>(v);
staticinvoke <org.springframework.util.ReflectionUtils: void doWithMethods(java.lang.Class,org.springframework.util.ReflectionUtils$MethodCallback)>(v, v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.reflect.Method)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
public static java.lang.reflect.Method[] getUniqueDeclaredMethods(java.lang.Class)
{
java.lang.Object[] v;
org.springframework.util.ReflectionUtils$2 v;
int v;
java.lang.Class v;
java.lang.reflect.Method[] v;
java.util.ArrayList v;
v := @parameter: java.lang.Class;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(32);
v = new org.springframework.util.ReflectionUtils$2;
specialinvoke v.<org.springframework.util.ReflectionUtils$2: void <init>(java.util.List)>(v);
staticinvoke <org.springframework.util.ReflectionUtils: void doWithMethods(java.lang.Class,org.springframework.util.ReflectionUtils$MethodCallback)>(v, v);
v = interfaceinvoke v.<java.util.List: int size()>();
v = newarray (java.lang.reflect.Method)[v];
v = interfaceinvoke v.<java.util.List: java.lang.Object[] toArray(java.lang.Object[])>(v);
return v;
}
private static java.lang.reflect.Method[] getDeclaredMethods(java.lang.Class)
{
java.lang.reflect.Method[] v, v;
java.util.Map v, v;
int v, v, v, v, v, v;
boolean v;
java.util.Iterator v;
java.util.List v;
java.lang.Class v;
java.lang.Object v, v;
v := @parameter: java.lang.Class;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Class must not be null");
v = <org.springframework.util.ReflectionUtils: java.util.Map declaredMethodsCache>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method[] getDeclaredMethods()>();
v = staticinvoke <org.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 = <org.springframework.util.ReflectionUtils: java.util.Map declaredMethodsCache>;
v = lengthof v;
if v != 0 goto label;
v = <org.springframework.util.ReflectionUtils: java.lang.reflect.Method[] NO_METHODS>;
goto label;
label:
v = v;
label:
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return v;
}
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 void doWithLocalFields(java.lang.Class, org.springframework.util.ReflectionUtils$FieldCallback)
{
java.lang.IllegalStateException v;
java.lang.IllegalAccessException v;
org.springframework.util.ReflectionUtils$FieldCallback v;
java.lang.reflect.Field v;
java.lang.reflect.Field[] v;
int v, v;
java.lang.Class v;
java.lang.String v, v;
v := @parameter: java.lang.Class;
v := @parameter: org.springframework.util.ReflectionUtils$FieldCallback;
v = staticinvoke <org.springframework.util.ReflectionUtils: java.lang.reflect.Field[] getDeclaredFields(java.lang.Class)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
label:
interfaceinvoke v.<org.springframework.util.ReflectionUtils$FieldCallback: void doWith(java.lang.reflect.Field)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.IllegalAccessException)>(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[])>("Not allowed to access field \'\u0001\': \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v + 1;
goto label;
label:
return;
catch java.lang.IllegalAccessException from label to label with label;
}
public static void doWithFields(java.lang.Class, org.springframework.util.ReflectionUtils$FieldCallback)
{
java.lang.Class v;
org.springframework.util.ReflectionUtils$FieldCallback v;
v := @parameter: java.lang.Class;
v := @parameter: org.springframework.util.ReflectionUtils$FieldCallback;
staticinvoke <org.springframework.util.ReflectionUtils: void doWithFields(java.lang.Class,org.springframework.util.ReflectionUtils$FieldCallback,org.springframework.util.ReflectionUtils$FieldFilter)>(v, v, null);
return;
}
public static void doWithFields(java.lang.Class, org.springframework.util.ReflectionUtils$FieldCallback, org.springframework.util.ReflectionUtils$FieldFilter)
{
org.springframework.util.ReflectionUtils$FieldFilter v;
java.lang.IllegalStateException v;
java.lang.IllegalAccessException v;
org.springframework.util.ReflectionUtils$FieldCallback v;
java.lang.reflect.Field v;
java.lang.reflect.Field[] v;
int v, v;
java.lang.Class v, v;
java.lang.String v, v;
boolean v;
v := @parameter: java.lang.Class;
v := @parameter: org.springframework.util.ReflectionUtils$FieldCallback;
v := @parameter: org.springframework.util.ReflectionUtils$FieldFilter;
v = v;
label:
v = staticinvoke <org.springframework.util.ReflectionUtils: java.lang.reflect.Field[] getDeclaredFields(java.lang.Class)>(v);
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
if v == null goto label;
v = interfaceinvoke v.<org.springframework.util.ReflectionUtils$FieldFilter: boolean matches(java.lang.reflect.Field)>(v);
if v == 0 goto label;
label:
interfaceinvoke v.<org.springframework.util.ReflectionUtils$FieldCallback: void doWith(java.lang.reflect.Field)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new java.lang.IllegalStateException;
v = virtualinvoke v.<java.lang.reflect.Field: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.IllegalAccessException)>(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[])>("Not allowed to access field \'\u0001\': \u0001");
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v + 1;
goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.Class getSuperclass()>();
if v == null goto label;
if v != class "Ljava/lang/Object;" goto label;
label:
return;
catch java.lang.IllegalAccessException from label to label with label;
}
private static java.lang.reflect.Field[] getDeclaredFields(java.lang.Class)
{
java.lang.reflect.Field[] v;
java.util.Map v, v;
int v;
java.lang.Class v;
java.lang.Object v;
v := @parameter: java.lang.Class;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Class must not be null");
v = <org.springframework.util.ReflectionUtils: java.util.Map declaredFieldsCache>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Field[] getDeclaredFields()>();
v = <org.springframework.util.ReflectionUtils: java.util.Map declaredFieldsCache>;
v = lengthof v;
if v != 0 goto label;
v = <org.springframework.util.ReflectionUtils: java.lang.reflect.Field[] NO_FIELDS>;
goto label;
label:
v = v;
label:
interfaceinvoke v.<java.util.Map: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
return v;
}
public static void shallowCopyFieldState(java.lang.Object, java.lang.Object)
{
org.springframework.util.ReflectionUtils$FieldFilter v;
java.lang.IllegalArgumentException v;
org.springframework.util.ReflectionUtils$3 v;
java.lang.Class v, v, v, v, v;
java.lang.Object v, v;
java.lang.String v, v, v;
boolean v;
v := @parameter: java.lang.Object;
v := @parameter: java.lang.Object;
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Source for field copy cannot be null");
staticinvoke <org.springframework.util.Assert: void notNull(java.lang.Object,java.lang.String)>(v, "Destination for field copy cannot be null");
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(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[])>("Destination class [\u] must be same or subclass as source class [\u]");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = new org.springframework.util.ReflectionUtils$3;
specialinvoke v.<org.springframework.util.ReflectionUtils$3: void <init>(java.lang.Object,java.lang.Object)>(v, v);
v = <org.springframework.util.ReflectionUtils: org.springframework.util.ReflectionUtils$FieldFilter COPYABLE_FIELDS>;
staticinvoke <org.springframework.util.ReflectionUtils: void doWithFields(java.lang.Class,org.springframework.util.ReflectionUtils$FieldCallback,org.springframework.util.ReflectionUtils$FieldFilter)>(v, v, v);
return;
}
public static void clearCache()
{
java.util.Map v, v;
v = <org.springframework.util.ReflectionUtils: java.util.Map declaredMethodsCache>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = <org.springframework.util.ReflectionUtils: java.util.Map declaredFieldsCache>;
interfaceinvoke v.<java.util.Map: void clear()>();
return;
}
static void <clinit>()
{
java.lang.reflect.Field[] v;
org.springframework.util.ConcurrentReferenceHashMap v, v;
org.springframework.util.ReflectionUtils$4 v;
org.springframework.util.ReflectionUtils$6 v;
org.springframework.util.ReflectionUtils$5 v;
java.lang.reflect.Method[] v;
v = newarray (java.lang.reflect.Method)[0];
<org.springframework.util.ReflectionUtils: java.lang.reflect.Method[] NO_METHODS> = v;
v = newarray (java.lang.reflect.Field)[0];
<org.springframework.util.ReflectionUtils: java.lang.reflect.Field[] NO_FIELDS> = v;
v = new org.springframework.util.ConcurrentReferenceHashMap;
specialinvoke v.<org.springframework.util.ConcurrentReferenceHashMap: void <init>(int)>(256);
<org.springframework.util.ReflectionUtils: java.util.Map declaredMethodsCache> = v;
v = new org.springframework.util.ConcurrentReferenceHashMap;
specialinvoke v.<org.springframework.util.ConcurrentReferenceHashMap: void <init>(int)>(256);
<org.springframework.util.ReflectionUtils: java.util.Map declaredFieldsCache> = v;
v = new org.springframework.util.ReflectionUtils$4;
specialinvoke v.<org.springframework.util.ReflectionUtils$4: void <init>()>();
<org.springframework.util.ReflectionUtils: org.springframework.util.ReflectionUtils$MethodFilter NON_BRIDGED_METHODS> = v;
v = new org.springframework.util.ReflectionUtils$5;
specialinvoke v.<org.springframework.util.ReflectionUtils$5: void <init>()>();
<org.springframework.util.ReflectionUtils: org.springframework.util.ReflectionUtils$MethodFilter USER_DECLARED_METHODS> = v;
v = new org.springframework.util.ReflectionUtils$6;
specialinvoke v.<org.springframework.util.ReflectionUtils$6: void <init>()>();
<org.springframework.util.ReflectionUtils: org.springframework.util.ReflectionUtils$FieldFilter COPYABLE_FIELDS> = v;
return;
}
}