public final class org.apache.ibatis.logging.LogFactory extends java.lang.Object
{
public static final java.lang.String MARKER;
private static final java.util.concurrent.locks.ReentrantLock lock;
private static java.lang.reflect.Constructor logConstructor;
private void <init>()
{
org.apache.ibatis.logging.LogFactory v;
v := @this: org.apache.ibatis.logging.LogFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static org.apache.ibatis.logging.Log getLog(java.lang.Class)
{
java.lang.Class v;
java.lang.String v;
org.apache.ibatis.logging.Log v;
v := @parameter: java.lang.Class;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.apache.ibatis.logging.LogFactory: org.apache.ibatis.logging.Log getLog(java.lang.String)>(v);
return v;
}
public static org.apache.ibatis.logging.Log getLog(java.lang.String)
{
java.lang.Throwable v;
java.lang.Object[] v;
java.lang.Object v;
java.lang.String v, v;
org.apache.ibatis.logging.LogException v;
java.lang.reflect.Constructor v;
v := @parameter: java.lang.String;
label:
v = <org.apache.ibatis.logging.LogFactory: java.lang.reflect.Constructor logConstructor>;
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
label:
return v;
label:
v := @caughtexception;
v = new org.apache.ibatis.logging.LogException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.Throwable)>(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[])>("Error creating logger for logger \u.  Cause: \u0001");
specialinvoke v.<org.apache.ibatis.logging.LogException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Throwable from label to label with label;
}
public static void useCustomLogging(java.lang.Class)
{
java.lang.Class v;
v := @parameter: java.lang.Class;
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(v);
return;
}
public static void useSlf4jLogging()
{
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(class "Lorg/apache/ibatis/logging/slf4j/Slf4jImpl;");
return;
}
public static void useCommonsLogging()
{
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(class "Lorg/apache/ibatis/logging/commons/JakartaCommonsLoggingImpl;");
return;
}
public static void useLog4JLogging()
{
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(class "Lorg/apache/ibatis/logging/log4j/Log4jImpl;");
return;
}
public static void useLog4J2Logging()
{
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(class "Lorg/apache/ibatis/logging/log4j2/Log4j2Impl;");
return;
}
public static void useJdkLogging()
{
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(class "Lorg/apache/ibatis/logging/jdk14/Jdk14LoggingImpl;");
return;
}
public static void useStdOutLogging()
{
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(class "Lorg/apache/ibatis/logging/stdout/StdOutImpl;");
return;
}
public static void useNoLogging()
{
staticinvoke <org.apache.ibatis.logging.LogFactory: void setImplementation(java.lang.Class)>(class "Lorg/apache/ibatis/logging/nologging/NoLoggingImpl;");
return;
}
private static void tryImplementation(java.lang.Runnable)
{
java.lang.Throwable v;
java.lang.Runnable v;
java.lang.reflect.Constructor v;
v := @parameter: java.lang.Runnable;
v = <org.apache.ibatis.logging.LogFactory: java.lang.reflect.Constructor logConstructor>;
if v != null goto label;
label:
interfaceinvoke v.<java.lang.Runnable: void run()>();
label:
goto label;
label:
v := @caughtexception;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private static void setImplementation(java.lang.Class)
{
java.lang.Throwable v;
java.lang.Object[] v;
java.util.concurrent.locks.ReentrantLock v, v;
java.lang.Class[] v;
java.lang.reflect.Constructor v;
java.lang.Class v, v;
java.lang.Object v;
java.lang.String v, v, v;
org.apache.ibatis.logging.LogException v;
boolean v;
v := @parameter: java.lang.Class;
v = <org.apache.ibatis.logging.LogFactory: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void lock()>();
label:
v = newarray (java.lang.Class)[1];
v[0] = class "Ljava/lang/String;";
v = virtualinvoke v.<java.lang.Class: java.lang.reflect.Constructor getConstructor(java.lang.Class[])>(v);
v = newarray (java.lang.Object)[1];
v = class "Lorg/apache/ibatis/logging/LogFactory;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v[0] = v;
v = virtualinvoke v.<java.lang.reflect.Constructor: java.lang.Object newInstance(java.lang.Object[])>(v);
v = interfaceinvoke v.<org.apache.ibatis.logging.Log: boolean isDebugEnabled()>();
if v == 0 goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Class)>(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[])>("Logging initialized using \'\u0001\' adapter.");
interfaceinvoke v.<org.apache.ibatis.logging.Log: void debug(java.lang.String)>(v);
label:
<org.apache.ibatis.logging.LogFactory: java.lang.reflect.Constructor logConstructor> = v;
label:
v = <org.apache.ibatis.logging.LogFactory: java.util.concurrent.locks.ReentrantLock lock>;
virtualinvoke v.<java.util.concurrent.locks.ReentrantLock: void unlock()>();
goto label;
label:
v := @caughtexception;
v = new org.apache.ibatis.logging.LogException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Throwable)>(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[])>("Error setting Log implementation.  Cause: \u0001");
specialinvoke v.<org.apache.ibatis.logging.LogException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
static void <clinit>()
{
java.util.concurrent.locks.ReentrantLock v;
java.lang.Runnable v, v, v, v, v, v;
v = new java.util.concurrent.locks.ReentrantLock;
specialinvoke v.<java.util.concurrent.locks.ReentrantLock: void <init>()>();
<org.apache.ibatis.logging.LogFactory: java.util.concurrent.locks.ReentrantLock lock> = v;
v = staticinvoke <org.apache.ibatis.logging.LogFactory$useSlf4jLogging__31: java.lang.Runnable bootstrap$()>();
staticinvoke <org.apache.ibatis.logging.LogFactory: void tryImplementation(java.lang.Runnable)>(v);
v = staticinvoke <org.apache.ibatis.logging.LogFactory$useCommonsLogging__32: java.lang.Runnable bootstrap$()>();
staticinvoke <org.apache.ibatis.logging.LogFactory: void tryImplementation(java.lang.Runnable)>(v);
v = staticinvoke <org.apache.ibatis.logging.LogFactory$useLog4J2Logging__33: java.lang.Runnable bootstrap$()>();
staticinvoke <org.apache.ibatis.logging.LogFactory: void tryImplementation(java.lang.Runnable)>(v);
v = staticinvoke <org.apache.ibatis.logging.LogFactory$useLog4JLogging__34: java.lang.Runnable bootstrap$()>();
staticinvoke <org.apache.ibatis.logging.LogFactory: void tryImplementation(java.lang.Runnable)>(v);
v = staticinvoke <org.apache.ibatis.logging.LogFactory$useJdkLogging__35: java.lang.Runnable bootstrap$()>();
staticinvoke <org.apache.ibatis.logging.LogFactory: void tryImplementation(java.lang.Runnable)>(v);
v = staticinvoke <org.apache.ibatis.logging.LogFactory$useNoLogging__36: java.lang.Runnable bootstrap$()>();
staticinvoke <org.apache.ibatis.logging.LogFactory: void tryImplementation(java.lang.Runnable)>(v);
return;
}
}