public final class org.apache.logging.log4j.core.util.Loader extends java.lang.Object
{
private static final org.apache.logging.log4j.Logger LOGGER;
private static final java.lang.String TSTR;
private void <init>()
{
org.apache.logging.log4j.core.util.Loader v;
v := @this: org.apache.logging.log4j.core.util.Loader;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static java.lang.ClassLoader getClassLoader()
{
java.lang.ClassLoader v;
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getClassLoader(java.lang.Class,java.lang.Class)>(class "Lorg/apache/logging/log4j/core/util/Loader;", null);
return v;
}
public static java.lang.ClassLoader getThreadContextClassLoader()
{
java.lang.ClassLoader v;
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.ClassLoader getThreadContextClassLoader()>();
return v;
}
public static java.lang.ClassLoader getClassLoader(java.lang.Class, java.lang.Class)
{
java.lang.Class v, v;
java.lang.ClassLoader v, v, v, v, v, v;
boolean v, v, v;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.Class;
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getThreadContextClassLoader()>();
if v != null goto label;
v = null;
goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
label:
v = v;
if v != null goto label;
v = null;
goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
label:
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: boolean isChild(java.lang.ClassLoader,java.lang.ClassLoader)>(v, v);
if v == 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: boolean isChild(java.lang.ClassLoader,java.lang.ClassLoader)>(v, v);
if v == 0 goto label;
v = v;
goto label;
label:
v = v;
label:
return v;
label:
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: boolean isChild(java.lang.ClassLoader,java.lang.ClassLoader)>(v, v);
if v == 0 goto label;
v = v;
goto label;
label:
v = v;
label:
return v;
}
public static java.net.URL getResource(java.lang.String, java.lang.ClassLoader)
{
java.lang.Throwable v;
java.net.URL v, v, v, v;
org.apache.logging.log4j.Logger v, v, v, v, v;
java.lang.Class v;
java.lang.ClassLoader v, v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.ClassLoader;
label:
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getThreadContextClassLoader()>();
if v == null goto label;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Trying to find [{}] using context class loader {}.", v, 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/logging/log4j/core/util/Loader;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
if v == null goto label;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Trying to find [{}] using {} class loader.", v, v);
v = virtualinvoke v.<java.lang.ClassLoader: java.net.URL getResource(java.lang.String)>(v);
if v == null goto label;
label:
return v;
label:
if v == null goto label;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Trying to find [{}] using {} class loader.", v, 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;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Caught Exception while in Loader.getResource. This may be innocuous.", v);
label:
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("Trying to find [{}] using ClassLoader.getSystemResource().", v);
v = staticinvoke <java.lang.ClassLoader: java.net.URL getSystemResource(java.lang.String)>(v);
return v;
catch java.lang.Throwable 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 java.io.InputStream getResourceAsStream(java.lang.String, java.lang.ClassLoader)
{
java.lang.Throwable v;
org.apache.logging.log4j.Logger v, v, v, v, v;
java.lang.Class v;
java.lang.ClassLoader v, v, v;
java.lang.String v;
java.io.InputStream v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.ClassLoader;
label:
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getThreadContextClassLoader()>();
if v == null goto label;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Trying to find [{}] using context class loader {}.", v, v);
v = virtualinvoke v.<java.lang.ClassLoader: java.io.InputStream getResourceAsStream(java.lang.String)>(v);
if v == null goto label;
label:
return v;
label:
v = class "Lorg/apache/logging/log4j/core/util/Loader;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
if v == null goto label;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Trying to find [{}] using {} class loader.", v, v);
v = virtualinvoke v.<java.lang.ClassLoader: java.io.InputStream getResourceAsStream(java.lang.String)>(v);
if v == null goto label;
label:
return v;
label:
if v == null goto label;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Trying to find [{}] using {} class loader.", v, v);
v = virtualinvoke v.<java.lang.ClassLoader: java.io.InputStream getResourceAsStream(java.lang.String)>(v);
if v == null goto label;
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Throwable)>("Caught Exception while in Loader.getResource. This may be innocuous.", v);
label:
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("Trying to find [{}] using ClassLoader.getSystemResource().", v);
v = staticinvoke <java.lang.ClassLoader: java.io.InputStream getSystemResourceAsStream(java.lang.String)>(v);
return v;
catch java.lang.Throwable 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;
}
private static boolean isChild(java.lang.ClassLoader, java.lang.ClassLoader)
{
java.lang.ClassLoader v, v, v;
boolean v, v;
v := @parameter: java.lang.ClassLoader;
v := @parameter: java.lang.ClassLoader;
if v == null goto label;
if v == null goto label;
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.ClassLoader getParent()>();
label:
if v == null goto label;
if v == v goto label;
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.ClassLoader getParent()>();
goto label;
label:
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
label:
if v == null goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static java.lang.Class initializeClass(java.lang.String, java.lang.ClassLoader) throws java.lang.ClassNotFoundException
{
java.lang.Class v;
java.lang.ClassLoader v;
java.lang.String v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.ClassLoader;
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String,boolean,java.lang.ClassLoader)>(v, 1, v);
return v;
}
public static java.lang.Class loadClass(java.lang.String, java.lang.ClassLoader) throws java.lang.ClassNotFoundException
{
java.lang.Class v;
java.lang.ClassLoader v;
java.lang.String v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.ClassLoader;
if v == null goto label;
v = virtualinvoke v.<java.lang.ClassLoader: java.lang.Class loadClass(java.lang.String)>(v);
goto label;
label:
v = null;
label:
return v;
}
public static java.lang.Class loadSystemClass(java.lang.String) throws java.lang.ClassNotFoundException
{
java.lang.Throwable v;
org.apache.logging.log4j.Logger v;
java.lang.Class v, v;
java.lang.ClassLoader v;
java.lang.String v;
v := @parameter: java.lang.String;
label:
v = staticinvoke <java.lang.ClassLoader: java.lang.ClassLoader getSystemClassLoader()>();
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String,boolean,java.lang.ClassLoader)>(v, 1, v);
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("Couldn\'t use SystemClassLoader. Trying Class.forName({}).", v, v);
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String)>(v);
return v;
catch java.lang.Throwable from label to label with label;
}
public static java.lang.Object newInstanceOf(java.lang.String) throws java.lang.ClassNotFoundException, java.lang.IllegalAccessException, java.lang.InstantiationException, java.lang.NoSuchMethodException, java.lang.reflect.InvocationTargetException
{
java.lang.Throwable v;
java.lang.Thread v, v, v, v;
java.lang.Object v;
java.lang.ClassLoader v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getClassLoader()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Object newInstanceOf(java.lang.String)>(v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
return v;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
}
public static java.lang.Object newCheckedInstanceOf(java.lang.String, java.lang.Class) throws java.lang.ClassNotFoundException, java.lang.NoSuchMethodException, java.lang.IllegalAccessException, java.lang.reflect.InvocationTargetException, java.lang.InstantiationException
{
java.lang.Throwable v;
java.lang.Thread v, v, v, v;
java.lang.Class v;
java.lang.Object v;
java.lang.ClassLoader v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getClassLoader()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Object newCheckedInstanceOf(java.lang.String,java.lang.Class)>(v, v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
return v;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
}
public static java.lang.Object newCheckedInstanceOfProperty(java.lang.String, java.lang.Class) throws java.lang.ClassNotFoundException, java.lang.NoSuchMethodException, java.lang.reflect.InvocationTargetException, java.lang.InstantiationException, java.lang.IllegalAccessException
{
java.lang.Throwable v;
org.apache.logging.log4j.util.PropertiesUtil v;
java.lang.Thread v, v, v, v;
java.lang.Class v;
java.lang.Object v;
java.lang.ClassLoader v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
v = staticinvoke <org.apache.logging.log4j.util.PropertiesUtil: org.apache.logging.log4j.util.PropertiesUtil getProperties()>();
virtualinvoke v.<org.apache.logging.log4j.util.PropertiesUtil: java.lang.String getStringProperty(java.lang.String)>(v);
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getClassLoader()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Object newCheckedInstanceOfProperty(java.lang.String,java.lang.Class)>(v, v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
return v;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
}
public static boolean isClassAvailable(java.lang.String)
{
java.lang.Throwable v;
java.lang.Thread v, v, v, v;
java.lang.ClassLoader v, v;
java.lang.String v;
boolean v;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getClassLoader()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: boolean isClassAvailable(java.lang.String)>(v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
return v;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
}
public static boolean isJansiAvailable()
{
boolean v;
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: boolean isClassAvailable(java.lang.String)>("org.fusesource.jansi.AnsiRenderer");
return v;
}
public static java.lang.Class loadClass(java.lang.String) throws java.lang.ClassNotFoundException
{
java.lang.Throwable v;
java.lang.Thread v, v, v, v;
java.lang.Class v;
java.lang.ClassLoader v, v;
java.lang.String v;
v := @parameter: java.lang.String;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = staticinvoke <org.apache.logging.log4j.core.util.Loader: java.lang.ClassLoader getClassLoader()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Class loadClass(java.lang.String)>(v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
return v;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
throw v;
catch java.lang.Throwable from label to label with label;
}
static void <clinit>()
{
org.apache.logging.log4j.status.StatusLogger v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.util.Loader: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}