public class org.apache.log4j.helpers.Loader extends java.lang.Object
{
static final java.lang.String TSTR;
private static boolean java;
private static boolean ignoreTCL;
public void <init>()
{
org.apache.log4j.helpers.Loader v;
v := @this: org.apache.log4j.helpers.Loader;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static java.net.URL getResource(java.lang.String, java.lang.Class)
{
java.lang.Class v;
java.lang.String v;
java.net.URL v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
v = staticinvoke <org.apache.log4j.helpers.Loader: java.net.URL getResource(java.lang.String)>(v);
return v;
}
public static java.net.URL getResource(java.lang.String)
{
java.lang.Throwable v, v, v;
java.net.URL v, v, v;
java.lang.Thread v;
java.lang.String v, v, v, v;
boolean v, v, v, v;
java.lang.IllegalAccessException v;
java.lang.reflect.InvocationTargetException v;
java.lang.Class v;
java.lang.ClassLoader v, v;
v := @parameter: java.lang.String;
label:
v = <org.apache.log4j.helpers.Loader: boolean java1>;
if v != 0 goto label;
v = <org.apache.log4j.helpers.Loader: boolean ignoreTCL>;
if v != 0 goto label;
v = staticinvoke <org.apache.log4j.helpers.Loader: java.lang.ClassLoader getTCL()>();
if v == null goto label;
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[])>("Trying to find [\u] using context classloader \u.");
staticinvoke <org.apache.log4j.helpers.LogLog: void debug(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.ClassLoader: java.net.URL getResource(java.lang.String)>(v);
if v == null goto label;
label:
return v;
label:
v = class "Lorg/apache/log4j/helpers/Loader;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
if v == null goto label;
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[])>("Trying to find [\u] using \u class loader.");
staticinvoke <org.apache.log4j.helpers.LogLog: void debug(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.ClassLoader: java.net.URL getResource(java.lang.String)>(v);
if v == null goto label;
label:
return v;
label:
v := @caughtexception;
staticinvoke <org.apache.log4j.helpers.LogLog: void warn(java.lang.String,java.lang.Throwable)>("Caught Exception while in Loader.getResource. This may be innocuous.", v);
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
v = v instanceof java.lang.InterruptedException;
if v != 0 goto label;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
v = v instanceof java.io.InterruptedIOException;
if v == 0 goto label;
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
label:
staticinvoke <org.apache.log4j.helpers.LogLog: void warn(java.lang.String,java.lang.Throwable)>("Caught Exception while in Loader.getResource. This may be innocuous.", v);
goto label;
label:
v := @caughtexception;
staticinvoke <org.apache.log4j.helpers.LogLog: void warn(java.lang.String,java.lang.Throwable)>("Caught Exception while in Loader.getResource. This may be innocuous.", v);
label:
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[])>("Trying to find [\u] using ClassLoader.getSystemResource().");
staticinvoke <org.apache.log4j.helpers.LogLog: void debug(java.lang.String)>(v);
v = staticinvoke <java.lang.ClassLoader: java.net.URL getSystemResource(java.lang.String)>(v);
return v;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.IllegalAccessException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public static boolean isJava1()
{
boolean v;
v = <org.apache.log4j.helpers.Loader: boolean java1>;
return v;
}
private static java.lang.ClassLoader getTCL() throws java.lang.IllegalAccessException, java.lang.reflect.InvocationTargetException
{
java.lang.NoSuchMethodException v;
java.lang.Thread v;
java.lang.Class v;
java.lang.Object v;
java.lang.reflect.Method v;
label:
v = class "Ljava/lang/Thread;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Method getMethod(java.lang.String,java.lang.Class[])>("getContextClassLoader", null);
label:
goto label;
label:
v := @caughtexception;
return null;
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.reflect.Method: java.lang.Object invoke(java.lang.Object,java.lang.Object[])>(v, null);
return v;
catch java.lang.NoSuchMethodException from label to label with label;
}
public static java.lang.Class loadClass(java.lang.String) throws java.lang.ClassNotFoundException
{
java.lang.Throwable v, v, v;
java.lang.reflect.InvocationTargetException v;
java.lang.Thread v;
java.lang.Class v, v, v;
java.lang.ClassLoader v;
java.lang.String v;
boolean v, v, v, v;
v := @parameter: java.lang.String;
v = <org.apache.log4j.helpers.Loader: boolean java1>;
if v != 0 goto label;
v = <org.apache.log4j.helpers.Loader: boolean ignoreTCL>;
if v == 0 goto label;
label:
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String)>(v);
return v;
label:
v = staticinvoke <org.apache.log4j.helpers.Loader: java.lang.ClassLoader getTCL()>();
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.Class loadClass(java.lang.String)>(v);
label:
return v;
label:
v := @caughtexception;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
v = v instanceof java.lang.InterruptedException;
if v != 0 goto label;
v = virtualinvoke v.<java.lang.reflect.InvocationTargetException: java.lang.Throwable getTargetException()>();
v = v instanceof java.io.InterruptedIOException;
if v == 0 goto label;
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void interrupt()>();
goto label;
label:
v := @caughtexception;
label:
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String)>(v);
return v;
catch java.lang.reflect.InvocationTargetException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
static void <clinit>()
{
int v, v, v;
char v;
java.lang.String v, v;
boolean v;
<org.apache.log4j.helpers.Loader: boolean java1> = 1;
<org.apache.log4j.helpers.Loader: boolean ignoreTCL> = 0;
v = staticinvoke <org.apache.log4j.helpers.OptionConverter: java.lang.String getSystemProperty(java.lang.String,java.lang.String)>("java.version", null);
if v == null goto label;
v = virtualinvoke v.<java.lang.String: int indexOf(int)>(46);
v = (int) -1;
if v == v goto label;
v = v + 1;
v = virtualinvoke v.<java.lang.String: char charAt(int)>(v);
if v == 49 goto label;
<org.apache.log4j.helpers.Loader: boolean java1> = 0;
label:
v = staticinvoke <org.apache.log4j.helpers.OptionConverter: java.lang.String getSystemProperty(java.lang.String,java.lang.String)>("log4j.ignoreTCL", null);
if v == null goto label;
v = staticinvoke <org.apache.log4j.helpers.OptionConverter: boolean toBoolean(java.lang.String,boolean)>(v, 1);
<org.apache.log4j.helpers.Loader: boolean ignoreTCL> = v;
label:
return;
}
}