public class io.vertx.core.logging.LoggerFactory extends java.lang.Object
{
public static final java.lang.String LOGGER_DELEGATE_FACTORY_CLASS_NAME;
private static volatile io.vertx.core.spi.logging.LogDelegateFactory delegateFactory;
private static final java.util.concurrent.ConcurrentMap loggers;
public void <init>()
{
io.vertx.core.logging.LoggerFactory v;
v := @this: io.vertx.core.logging.LoggerFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static synchronized void initialise()
{
java.net.URL v;
java.lang.Exception v;
java.lang.Thread v;
io.vertx.core.logging.JULLogDelegateFactory v;
java.lang.ClassLoader v;
java.lang.String v;
boolean v, v, 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.System: java.lang.String getProperty(java.lang.String)>("vertx.logger-delegate-factory-class-name");
label:
goto label;
label:
v := @caughtexception;
v = null;
label:
if v == null goto label;
v = staticinvoke <io.vertx.core.logging.LoggerFactory: boolean configureWith(java.lang.String,boolean,java.lang.ClassLoader)>(v, 0, v);
if v == 0 goto label;
return;
label:
v = virtualinvoke v.<java.lang.ClassLoader: java.net.URL getResource(java.lang.String)>("vertx-default-jul-logging.properties");
if v != null goto label;
v = staticinvoke <io.vertx.core.logging.LoggerFactory: boolean configureWith(java.lang.String,boolean,java.lang.ClassLoader)>("SLF4J", 1, v);
if v != 0 goto label;
v = staticinvoke <io.vertx.core.logging.LoggerFactory: boolean configureWith(java.lang.String,boolean,java.lang.ClassLoader)>("Log4j2", 1, v);
if v == 0 goto label;
label:
return;
label:
v = new io.vertx.core.logging.JULLogDelegateFactory;
specialinvoke v.<io.vertx.core.logging.JULLogDelegateFactory: void <init>()>();
<io.vertx.core.logging.LoggerFactory: io.vertx.core.spi.logging.LogDelegateFactory delegateFactory> = v;
return;
catch java.lang.Exception from label to label with label;
}
private static boolean configureWith(java.lang.String, boolean, java.lang.ClassLoader)
{
java.lang.Throwable v;
java.lang.Class v;
java.lang.Object v;
java.lang.ClassLoader v;
java.lang.String v, v;
boolean v, v;
v := @parameter: java.lang.String;
v := @parameter: boolean;
v := @parameter: java.lang.ClassLoader;
label:
if v == 0 goto 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[])>("io.vertx.core.logging.\u0001LogDelegateFactory");
goto label;
label:
v = v;
label:
v = staticinvoke <java.lang.Class: java.lang.Class forName(java.lang.String,boolean,java.lang.ClassLoader)>(v, 1, v);
v = virtualinvoke v.<java.lang.Class: java.lang.Object newInstance()>();
v = interfaceinvoke v.<io.vertx.core.spi.logging.LogDelegateFactory: boolean isAvailable()>();
if v != 0 goto label;
label:
return 0;
label:
<io.vertx.core.logging.LoggerFactory: io.vertx.core.spi.logging.LogDelegateFactory delegateFactory> = v;
label:
return 1;
label:
v := @caughtexception;
return 0;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public static io.vertx.core.logging.Logger getLogger(java.lang.Class)
{
java.lang.Class v, v;
java.lang.String v;
io.vertx.core.logging.Logger v;
boolean v;
v := @parameter: java.lang.Class;
v = virtualinvoke v.<java.lang.Class: boolean isAnonymousClass()>();
if v == 0 goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.Class getEnclosingClass()>();
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
goto label;
label:
v = virtualinvoke v.<java.lang.Class: java.lang.String getCanonicalName()>();
label:
v = staticinvoke <io.vertx.core.logging.LoggerFactory: io.vertx.core.logging.Logger getLogger(java.lang.String)>(v);
return v;
}
public static io.vertx.core.logging.Logger getLogger(java.lang.String)
{
io.vertx.core.spi.logging.LogDelegate v;
java.util.concurrent.ConcurrentMap v, v;
io.vertx.core.spi.logging.LogDelegateFactory v;
java.lang.Object v, v;
java.lang.String v;
io.vertx.core.logging.Logger v;
v := @parameter: java.lang.String;
v = <io.vertx.core.logging.LoggerFactory: java.util.concurrent.ConcurrentMap loggers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object get(java.lang.Object)>(v);
if v != null goto label;
v = <io.vertx.core.logging.LoggerFactory: io.vertx.core.spi.logging.LogDelegateFactory delegateFactory>;
v = interfaceinvoke v.<io.vertx.core.spi.logging.LogDelegateFactory: io.vertx.core.spi.logging.LogDelegate createDelegate(java.lang.String)>(v);
v = new io.vertx.core.logging.Logger;
specialinvoke v.<io.vertx.core.logging.Logger: void <init>(io.vertx.core.spi.logging.LogDelegate)>(v);
v = v;
v = <io.vertx.core.logging.LoggerFactory: java.util.concurrent.ConcurrentMap loggers>;
v = interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object putIfAbsent(java.lang.Object,java.lang.Object)>(v, v);
if v == null goto label;
v = v;
label:
return v;
}
public static void removeLogger(java.lang.String)
{
java.lang.String v;
java.util.concurrent.ConcurrentMap v;
v := @parameter: java.lang.String;
v = <io.vertx.core.logging.LoggerFactory: java.util.concurrent.ConcurrentMap loggers>;
interfaceinvoke v.<java.util.concurrent.ConcurrentMap: java.lang.Object remove(java.lang.Object)>(v);
return;
}
static void <clinit>()
{
io.vertx.core.spi.logging.LogDelegate v;
java.util.concurrent.ConcurrentHashMap v;
io.vertx.core.spi.logging.LogDelegateFactory v, v;
java.lang.Class v, v;
java.lang.String v, v, v;
v = new java.util.concurrent.ConcurrentHashMap;
specialinvoke v.<java.util.concurrent.ConcurrentHashMap: void <init>()>();
<io.vertx.core.logging.LoggerFactory: java.util.concurrent.ConcurrentMap loggers> = v;
staticinvoke <io.vertx.core.logging.LoggerFactory: void initialise()>();
v = <io.vertx.core.logging.LoggerFactory: io.vertx.core.spi.logging.LogDelegateFactory delegateFactory>;
v = class "Lio/vertx/core/logging/LoggerFactory;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = interfaceinvoke v.<io.vertx.core.spi.logging.LogDelegateFactory: io.vertx.core.spi.logging.LogDelegate createDelegate(java.lang.String)>(v);
v = <io.vertx.core.logging.LoggerFactory: io.vertx.core.spi.logging.LogDelegateFactory delegateFactory>;
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)>(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[])>("Using \u0001");
interfaceinvoke v.<io.vertx.core.spi.logging.LogDelegate: void debug(java.lang.Object)>(v);
return;
}
}