public final class org.slf4j.LoggerFactory extends java.lang.Object
{
static final java.lang.String CODES_PREFIX;
static final java.lang.String NO_PROVIDERS_URL;
static final java.lang.String IGNORED_BINDINGS_URL;
static final java.lang.String NO_STATICLOGGERBINDER_URL;
static final java.lang.String MULTIPLE_BINDINGS_URL;
static final java.lang.String NULL_LF_URL;
static final java.lang.String VERSION_MISMATCH;
static final java.lang.String SUBSTITUTE_LOGGER_URL;
static final java.lang.String LOGGER_NAME_MISMATCH_URL;
static final java.lang.String REPLAY_URL;
static final java.lang.String UNSUCCESSFUL_INIT_URL;
static final java.lang.String UNSUCCESSFUL_INIT_MSG;
static final int UNINITIALIZED;
static final int ONGOING_INITIALIZATION;
static final int FAILED_INITIALIZATION;
static final int SUCCESSFUL_INITIALIZATION;
static final int NOP_FALLBACK_INITIALIZATION;
static volatile int INITIALIZATION_STATE;
static final org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER;
static final org.slf4j.helpers.NOP_FallbackServiceProvider NOP_FALLBACK_SERVICE_PROVIDER;
static final java.lang.String DETECT_LOGGER_NAME_MISMATCH_PROPERTY;
static final java.lang.String JAVA_VENDOR_PROPERTY;
static boolean DETECT_LOGGER_NAME_MISMATCH;
static volatile org.slf4j.spi.SLF4JServiceProvider PROVIDER;
private static final java.lang.String[] API_COMPATIBILITY_LIST;
private static final java.lang.String STATIC_LOGGER_BINDER_PATH;
static java.util.List findServiceProviders()
{
java.util.Iterator v;
java.lang.Class v;
java.util.ServiceLoader v;
java.lang.ClassLoader v;
boolean v;
java.util.ArrayList v;
v = class "Lorg/slf4j/LoggerFactory;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
v = staticinvoke <org.slf4j.LoggerFactory: java.util.ServiceLoader getServiceLoader(java.lang.ClassLoader)>(v);
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>()>();
v = virtualinvoke v.<java.util.ServiceLoader: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
staticinvoke <org.slf4j.LoggerFactory: void safelyInstantiate(java.util.List,java.util.Iterator)>(v, v);
goto label;
label:
return v;
}
private static java.util.ServiceLoader getServiceLoader(java.lang.ClassLoader)
{
java.lang.Object v;
java.lang.ClassLoader v;
java.security.PrivilegedAction v;
java.lang.SecurityManager v;
v := @parameter: java.lang.ClassLoader;
v = staticinvoke <java.lang.System: java.lang.SecurityManager getSecurityManager()>();
if v != null goto label;
staticinvoke <java.util.ServiceLoader: java.util.ServiceLoader load(java.lang.Class,java.lang.ClassLoader)>(class "Lorg/slf4j/spi/SLF4JServiceProvider;", v);
goto label;
label:
v = staticinvoke <org.slf4j.LoggerFactory$lambda_getServiceLoader_0__3523: java.security.PrivilegedAction bootstrap$(java.lang.ClassLoader)>(v);
v = staticinvoke <java.security.AccessController: java.lang.Object doPrivileged(java.security.PrivilegedAction)>(v);
label:
return v;
}
private static void safelyInstantiate(java.util.List, java.util.Iterator)
{
java.util.List v;
java.util.Iterator v;
java.util.ServiceConfigurationError v;
java.lang.Object v;
java.lang.String v, v;
v := @parameter: java.util.List;
v := @parameter: java.util.Iterator;
label:
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
interfaceinvoke v.<java.util.List: boolean add(java.lang.Object)>(v);
label:
goto label;
label:
v := @caughtexception;
v = virtualinvoke v.<java.util.ServiceConfigurationError: 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[])>("A SLF4J service provider failed to instantiate:\n\u0001");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
label:
return;
catch java.util.ServiceConfigurationError from label to label with label;
}
private void <init>()
{
org.slf4j.LoggerFactory v;
v := @this: org.slf4j.LoggerFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
static void reset()
{
<org.slf4j.LoggerFactory: int INITIALIZATION_STATE> = 0;
return;
}
private static final void performInitialization()
{
int v;
staticinvoke <org.slf4j.LoggerFactory: void bind()>();
v = <org.slf4j.LoggerFactory: int INITIALIZATION_STATE>;
if v != 3 goto label;
staticinvoke <org.slf4j.LoggerFactory: void versionSanityCheck()>();
label:
return;
}
private static final void bind()
{
java.lang.IllegalStateException v;
java.util.List v;
org.slf4j.spi.SLF4JServiceProvider v;
java.util.Set v;
java.lang.Object v;
java.lang.Exception v;
boolean v;
label:
v = staticinvoke <org.slf4j.LoggerFactory: java.util.List findServiceProviders()>();
staticinvoke <org.slf4j.LoggerFactory: void reportMultipleBindingAmbiguity(java.util.List)>(v);
if v == null goto label;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
<org.slf4j.LoggerFactory: org.slf4j.spi.SLF4JServiceProvider PROVIDER> = v;
v = <org.slf4j.LoggerFactory: org.slf4j.spi.SLF4JServiceProvider PROVIDER>;
interfaceinvoke v.<org.slf4j.spi.SLF4JServiceProvider: void initialize()>();
<org.slf4j.LoggerFactory: int INITIALIZATION_STATE> = 3;
staticinvoke <org.slf4j.LoggerFactory: void reportActualBinding(java.util.List)>(v);
goto label;
label:
<org.slf4j.LoggerFactory: int INITIALIZATION_STATE> = 4;
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("No SLF4J providers were found.");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("Defaulting to no-operation (NOP) logger implementation");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("See https://www.slf4j.org/codes.html#noProviders for further details.");
v = staticinvoke <org.slf4j.LoggerFactory: java.util.Set findPossibleStaticLoggerBinderPathSet()>();
staticinvoke <org.slf4j.LoggerFactory: void reportIgnoredStaticLoggerBinders(java.util.Set)>(v);
label:
staticinvoke <org.slf4j.LoggerFactory: void postBindCleanUp()>();
label:
goto label;
label:
v := @caughtexception;
staticinvoke <org.slf4j.LoggerFactory: void failedBinding(java.lang.Throwable)>(v);
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String,java.lang.Throwable)>("Unexpected initialization failure", v);
throw v;
label:
return;
catch java.lang.Exception from label to label with label;
}
private static void reportIgnoredStaticLoggerBinders(java.util.Set)
{
java.util.Iterator v;
java.util.Set v;
java.lang.Object v;
java.lang.String v;
boolean v, v;
v := @parameter: java.util.Set;
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v == 0 goto label;
return;
label:
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("Class path contains SLF4J bindings targeting slf4j-api versions 1.7.x or earlier.");
v = interfaceinvoke v.<java.util.Set: 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 = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Object)>(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[])>("Ignoring binding found at [\u]");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
goto label;
label:
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("See https://www.slf4j.org/codes.html#ignoredBindings for an explanation.");
return;
}
static java.util.Set findPossibleStaticLoggerBinderPathSet()
{
java.util.Enumeration v;
java.io.IOException v;
java.lang.Class v;
java.lang.Object v;
java.lang.ClassLoader v;
java.util.LinkedHashSet v;
boolean v;
v = new java.util.LinkedHashSet;
specialinvoke v.<java.util.LinkedHashSet: void <init>()>();
label:
v = class "Lorg/slf4j/LoggerFactory;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
if v != null goto label;
v = staticinvoke <java.lang.ClassLoader: java.util.Enumeration getSystemResources(java.lang.String)>("org/slf4j/impl/StaticLoggerBinder.class");
goto label;
label:
v = virtualinvoke v.<java.lang.ClassLoader: java.util.Enumeration getResources(java.lang.String)>("org/slf4j/impl/StaticLoggerBinder.class");
label:
v = interfaceinvoke v.<java.util.Enumeration: boolean hasMoreElements()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Enumeration: java.lang.Object nextElement()>();
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
v := @caughtexception;
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String,java.lang.Throwable)>("Error getting resources from path", v);
label:
return v;
catch java.io.IOException from label to label with label;
}
private static void postBindCleanUp()
{
org.slf4j.helpers.SubstituteServiceProvider v;
org.slf4j.helpers.SubstituteLoggerFactory v;
staticinvoke <org.slf4j.LoggerFactory: void fixSubstituteLoggers()>();
staticinvoke <org.slf4j.LoggerFactory: void replayEvents()>();
v = <org.slf4j.LoggerFactory: org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER>;
v = virtualinvoke v.<org.slf4j.helpers.SubstituteServiceProvider: org.slf4j.helpers.SubstituteLoggerFactory getSubstituteLoggerFactory()>();
virtualinvoke v.<org.slf4j.helpers.SubstituteLoggerFactory: void clear()>();
return;
}
private static void fixSubstituteLoggers()
{
java.lang.Throwable v;
org.slf4j.Logger v;
java.util.Iterator v;
org.slf4j.helpers.SubstituteServiceProvider v, v, v;
org.slf4j.helpers.SubstituteLoggerFactory v, v;
java.util.List v;
java.lang.Object v;
java.lang.String v;
boolean v;
v = <org.slf4j.LoggerFactory: org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER>;
entermonitor v;
label:
v = <org.slf4j.LoggerFactory: org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER>;
v = virtualinvoke v.<org.slf4j.helpers.SubstituteServiceProvider: org.slf4j.helpers.SubstituteLoggerFactory getSubstituteLoggerFactory()>();
virtualinvoke v.<org.slf4j.helpers.SubstituteLoggerFactory: void postInitialization()>();
v = <org.slf4j.LoggerFactory: org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER>;
v = virtualinvoke v.<org.slf4j.helpers.SubstituteServiceProvider: org.slf4j.helpers.SubstituteLoggerFactory getSubstituteLoggerFactory()>();
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLoggerFactory: java.util.List getLoggers()>();
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 = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: java.lang.String getName()>();
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.String)>(v);
virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: void setDelegate(org.slf4j.Logger)>(v);
goto label;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
static void failedBinding(java.lang.Throwable)
{
java.lang.Throwable v;
v := @parameter: java.lang.Throwable;
<org.slf4j.LoggerFactory: int INITIALIZATION_STATE> = 2;
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String,java.lang.Throwable)>("Failed to instantiate SLF4J LoggerFactory", v);
return;
}
private static void replayEvents()
{
java.util.Iterator v;
org.slf4j.helpers.SubstituteServiceProvider v;
java.util.concurrent.LinkedBlockingQueue v;
java.util.ArrayList v;
org.slf4j.helpers.SubstituteLoggerFactory v;
int v, v, v, v;
java.lang.Object v;
boolean v;
v = <org.slf4j.LoggerFactory: org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER>;
v = virtualinvoke v.<org.slf4j.helpers.SubstituteServiceProvider: org.slf4j.helpers.SubstituteLoggerFactory getSubstituteLoggerFactory()>();
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLoggerFactory: java.util.concurrent.LinkedBlockingQueue getEventQueue()>();
v = virtualinvoke v.<java.util.concurrent.LinkedBlockingQueue: int size()>();
v = 0;
v = new java.util.ArrayList;
specialinvoke v.<java.util.ArrayList: void <init>(int)>(128);
label:
v = virtualinvoke v.<java.util.concurrent.LinkedBlockingQueue: int drainTo(java.util.Collection,int)>(v, 128);
if v == 0 goto label;
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()>();
staticinvoke <org.slf4j.LoggerFactory: void replaySingleEvent(org.slf4j.event.SubstituteLoggingEvent)>(v);
v = v;
v = v + 1;
if v != 0 goto label;
staticinvoke <org.slf4j.LoggerFactory: void emitReplayOrSubstituionWarning(org.slf4j.event.SubstituteLoggingEvent,int)>(v, v);
goto label;
label:
interfaceinvoke v.<java.util.List: void clear()>();
goto label;
label:
return;
}
private static void emitReplayOrSubstituionWarning(org.slf4j.event.SubstituteLoggingEvent, int)
{
org.slf4j.event.SubstituteLoggingEvent v;
int v;
org.slf4j.helpers.SubstituteLogger v, v;
boolean v, v;
v := @parameter: org.slf4j.event.SubstituteLoggingEvent;
v := @parameter: int;
v = virtualinvoke v.<org.slf4j.event.SubstituteLoggingEvent: org.slf4j.helpers.SubstituteLogger getLogger()>();
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: boolean isDelegateEventAware()>();
if v == 0 goto label;
staticinvoke <org.slf4j.LoggerFactory: void emitReplayWarning(int)>(v);
goto label;
label:
v = virtualinvoke v.<org.slf4j.event.SubstituteLoggingEvent: org.slf4j.helpers.SubstituteLogger getLogger()>();
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: boolean isDelegateNOP()>();
if v != 0 goto label;
staticinvoke <org.slf4j.LoggerFactory: void emitSubstitutionWarning()>();
label:
return;
}
private static void replaySingleEvent(org.slf4j.event.SubstituteLoggingEvent)
{
java.lang.IllegalStateException v;
org.slf4j.helpers.SubstituteLogger v;
org.slf4j.event.SubstituteLoggingEvent v;
org.slf4j.event.Level v;
java.lang.String v;
boolean v, v, v, v;
v := @parameter: org.slf4j.event.SubstituteLoggingEvent;
if v != null goto label;
return;
label:
v = virtualinvoke v.<org.slf4j.event.SubstituteLoggingEvent: org.slf4j.helpers.SubstituteLogger getLogger()>();
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: java.lang.String getName()>();
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: boolean isDelegateNull()>();
if v == 0 goto label;
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Delegate logger cannot be null at this state.");
throw v;
label:
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: boolean isDelegateNOP()>();
if v != 0 goto label;
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: boolean isDelegateEventAware()>();
if v == 0 goto label;
v = virtualinvoke v.<org.slf4j.event.SubstituteLoggingEvent: org.slf4j.event.Level getLevel()>();
v = virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: boolean isEnabledForLevel(org.slf4j.event.Level)>(v);
if v == 0 goto label;
virtualinvoke v.<org.slf4j.helpers.SubstituteLogger: void log(org.slf4j.event.LoggingEvent)>(v);
goto label;
label:
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
label:
return;
}
private static void emitSubstitutionWarning()
{
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("The following set of substitute loggers may have been accessed");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("during the initialization phase. Logging calls during this");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("phase were not honored. However, subsequent logging calls to these");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("loggers will work as normally expected.");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("See also https://www.slf4j.org/codes.html#substituteLogger");
return;
}
private static void emitReplayWarning(int)
{
int v;
java.lang.String v;
v := @parameter: int;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("A number (\u) of logging calls during the initialization phase have been intercepted and are");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("now being replayed. These are subject to the filtering rules of the underlying logging system.");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("See also https://www.slf4j.org/codes.html#replay");
return;
}
private static final void versionSanityCheck()
{
java.lang.Throwable v;
java.lang.String[] v, v;
java.lang.NoSuchFieldError v;
java.util.List v;
org.slf4j.spi.SLF4JServiceProvider v;
int v, v;
java.lang.String v, v, v, v;
boolean v, v;
label:
v = <org.slf4j.LoggerFactory: org.slf4j.spi.SLF4JServiceProvider PROVIDER>;
v = interfaceinvoke v.<org.slf4j.spi.SLF4JServiceProvider: java.lang.String getRequestedApiVersion()>();
v = 0;
v = <org.slf4j.LoggerFactory: java.lang.String[] API_COMPATIBILITY_LIST>;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>(v);
if v == 0 goto label;
v = 1;
label:
v = v + 1;
goto label;
label:
if v != 0 goto label;
v = <org.slf4j.LoggerFactory: java.lang.String[] API_COMPATIBILITY_LIST>;
v = staticinvoke <java.util.Arrays: java.util.List asList(java.lang.Object[])>(v);
v = interfaceinvoke v.<java.util.List: java.lang.String toString()>();
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[])>("The requested version \u by your slf4j binding is not compatible with \u0001");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("See https://www.slf4j.org/codes.html#version_mismatch for further details.");
label:
goto label;
label:
v := @caughtexception;
goto label;
label:
v := @caughtexception;
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String,java.lang.Throwable)>("Unexpected problem occured during version sanity check", v);
label:
return;
catch java.lang.NoSuchFieldError from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private static boolean isAmbiguousProviderList(java.util.List)
{
int v;
java.util.List v;
boolean v;
v := @parameter: java.util.List;
v = interfaceinvoke v.<java.util.List: int size()>();
if v <= 1 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private static void reportMultipleBindingAmbiguity(java.util.List)
{
java.util.List v;
java.util.Iterator v;
java.lang.Object v;
java.lang.String v;
boolean v, v;
v := @parameter: java.util.List;
v = staticinvoke <org.slf4j.LoggerFactory: boolean isAmbiguousProviderList(java.util.List)>(v);
if v == 0 goto label;
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("Class path contains multiple SLF4J providers.");
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 = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Object)>(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[])>("Found provider [\u]");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
goto label;
label:
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("See https://www.slf4j.org/codes.html#multiple_bindings for an explanation.");
label:
return;
}
private static void reportActualBinding(java.util.List)
{
java.util.List v;
java.lang.Object v;
java.lang.String v;
boolean v, v;
v := @parameter: java.util.List;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = staticinvoke <org.slf4j.LoggerFactory: boolean isAmbiguousProviderList(java.util.List)>(v);
if v == 0 goto label;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(0);
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Object)>(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[])>("Actual provider is of type [\u]");
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
label:
return;
}
public static org.slf4j.Logger getLogger(java.lang.String)
{
java.lang.String v;
org.slf4j.Logger v;
org.slf4j.ILoggerFactory v;
v := @parameter: java.lang.String;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.ILoggerFactory getILoggerFactory()>();
v = interfaceinvoke v.<org.slf4j.ILoggerFactory: org.slf4j.Logger getLogger(java.lang.String)>(v);
return v;
}
public static org.slf4j.Logger getLogger(java.lang.Class)
{
java.lang.Object[] v;
org.slf4j.Logger v;
java.lang.Class v, v;
java.lang.String v, v, v, v;
boolean v, v;
v := @parameter: java.lang.Class;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.String)>(v);
v = <org.slf4j.LoggerFactory: boolean DETECT_LOGGER_NAME_MISMATCH>;
if v == 0 goto label;
v = staticinvoke <org.slf4j.helpers.Util: java.lang.Class getCallingClass()>();
if v == null goto label;
v = staticinvoke <org.slf4j.LoggerFactory: boolean nonMatchingClasses(java.lang.Class,java.lang.Class)>(v, v);
if v == 0 goto label;
v = newarray (java.lang.Object)[2];
v = interfaceinvoke v.<org.slf4j.Logger: java.lang.String getName()>();
v[0] = v;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("Detected logger name mismatch. Given name: \"%s\"; computed name: \"%s\".", v);
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>(v);
staticinvoke <org.slf4j.helpers.Util: void report(java.lang.String)>("See https://www.slf4j.org/codes.html#loggerNameMismatch for an explanation");
label:
return v;
}
private static boolean nonMatchingClasses(java.lang.Class, java.lang.Class)
{
java.lang.Class v, v;
boolean v, v;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.Class;
v = virtualinvoke v.<java.lang.Class: boolean isAssignableFrom(java.lang.Class)>(v);
if v != 0 goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public static org.slf4j.ILoggerFactory getILoggerFactory()
{
org.slf4j.ILoggerFactory v;
org.slf4j.spi.SLF4JServiceProvider v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.spi.SLF4JServiceProvider getProvider()>();
v = interfaceinvoke v.<org.slf4j.spi.SLF4JServiceProvider: org.slf4j.ILoggerFactory getLoggerFactory()>();
return v;
}
static org.slf4j.spi.SLF4JServiceProvider getProvider()
{
java.lang.Throwable v;
java.lang.IllegalStateException v, v;
org.slf4j.helpers.SubstituteServiceProvider v;
org.slf4j.spi.SLF4JServiceProvider v;
int v, v, v;
org.slf4j.helpers.NOP_FallbackServiceProvider v;
v = <org.slf4j.LoggerFactory: int INITIALIZATION_STATE>;
if v != 0 goto label;
entermonitor class "Lorg/slf4j/LoggerFactory;";
label:
v = <org.slf4j.LoggerFactory: int INITIALIZATION_STATE>;
if v != 0 goto label;
<org.slf4j.LoggerFactory: int INITIALIZATION_STATE> = 1;
staticinvoke <org.slf4j.LoggerFactory: void performInitialization()>();
label:
exitmonitor class "Lorg/slf4j/LoggerFactory;";
label:
goto label;
label:
v := @caughtexception;
exitmonitor class "Lorg/slf4j/LoggerFactory;";
throw v;
label:
v = <org.slf4j.LoggerFactory: int INITIALIZATION_STATE>;
tableswitch(v)
{
case 1: goto label;
case 2: goto label;
case 3: goto label;
case 4: goto label;
default: goto label;
};
label:
v = <org.slf4j.LoggerFactory: org.slf4j.spi.SLF4JServiceProvider PROVIDER>;
return v;
label:
v = <org.slf4j.LoggerFactory: org.slf4j.helpers.NOP_FallbackServiceProvider NOP_FALLBACK_SERVICE_PROVIDER>;
return v;
label:
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("org.slf4j.LoggerFactory in failed state. Original exception was thrown EARLIER. See also https://www.slf4j.org/codes.html#unsuccessfulInit");
throw v;
label:
v = <org.slf4j.LoggerFactory: org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER>;
return v;
label:
v = new java.lang.IllegalStateException;
specialinvoke v.<java.lang.IllegalStateException: void <init>(java.lang.String)>("Unreachable code");
throw v;
catch java.lang.Throwable from label to label with label;
}
static void <clinit>()
{
org.slf4j.helpers.SubstituteServiceProvider v;
org.slf4j.helpers.NOP_FallbackServiceProvider v;
java.lang.String[] v;
boolean v;
<org.slf4j.LoggerFactory: int INITIALIZATION_STATE> = 0;
v = new org.slf4j.helpers.SubstituteServiceProvider;
specialinvoke v.<org.slf4j.helpers.SubstituteServiceProvider: void <init>()>();
<org.slf4j.LoggerFactory: org.slf4j.helpers.SubstituteServiceProvider SUBST_PROVIDER> = v;
v = new org.slf4j.helpers.NOP_FallbackServiceProvider;
specialinvoke v.<org.slf4j.helpers.NOP_FallbackServiceProvider: void <init>()>();
<org.slf4j.LoggerFactory: org.slf4j.helpers.NOP_FallbackServiceProvider NOP_FALLBACK_SERVICE_PROVIDER> = v;
v = staticinvoke <org.slf4j.helpers.Util: boolean safeGetBooleanSystemProperty(java.lang.String)>("slf4j.detectLoggerNameMismatch");
<org.slf4j.LoggerFactory: boolean DETECT_LOGGER_NAME_MISMATCH> = v;
v = newarray (java.lang.String)[1];
v[0] = "2.0";
<org.slf4j.LoggerFactory: java.lang.String[] API_COMPATIBILITY_LIST> = v;
return;
}
}