public class org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory extends java.lang.Object
{
static final java.lang.String PROPERTY_NAME_ASYNC_EVENT_ROUTER;
static final java.lang.String PROPERTY_VALUE_DEFAULT_ASYNC_EVENT_ROUTER;
static final java.lang.String PROPERTY_VALUE_DISCARDING_ASYNC_EVENT_ROUTER;
static final java.lang.String PROPERTY_NAME_DISCARDING_THRESHOLD_LEVEL;
private static final org.apache.logging.log4j.Logger LOGGER;
public void <init>()
{
org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory v;
v := @this: org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public static org.apache.logging.log4j.core.async.AsyncQueueFullPolicy create()
{
org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy v;
org.apache.logging.log4j.core.async.AsyncQueueFullPolicy v, v;
java.lang.String v;
org.apache.logging.log4j.util.PropertiesUtil v;
boolean v, v;
v = staticinvoke <org.apache.logging.log4j.util.PropertiesUtil: org.apache.logging.log4j.util.PropertiesUtil getProperties()>();
v = virtualinvoke v.<org.apache.logging.log4j.util.PropertiesUtil: java.lang.String getStringProperty(java.lang.String)>("log4j.AsyncQueueFullPolicy");
if v == null goto label;
v = staticinvoke <org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory: boolean isRouterSelected(java.lang.String,java.lang.Class,java.lang.String)>(v, class "Lorg/apache/logging/log4j/core/async/DefaultAsyncQueueFullPolicy;", "Default");
if v == 0 goto label;
label:
v = new org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy;
specialinvoke v.<org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy: void <init>()>();
return v;
label:
v = staticinvoke <org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory: boolean isRouterSelected(java.lang.String,java.lang.Class,java.lang.String)>(v, class "Lorg/apache/logging/log4j/core/async/DiscardingAsyncQueueFullPolicy;", "Discard");
if v == 0 goto label;
v = staticinvoke <org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory: org.apache.logging.log4j.core.async.AsyncQueueFullPolicy createDiscardingAsyncQueueFullPolicy()>();
return v;
label:
v = staticinvoke <org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory: org.apache.logging.log4j.core.async.AsyncQueueFullPolicy createCustomRouter(java.lang.String)>(v);
return v;
}
private static boolean isRouterSelected(java.lang.String, java.lang.Class, java.lang.String)
{
java.lang.Class v;
java.lang.String v, v, v, v;
boolean v, v, v, v;
v := @parameter: java.lang.String;
v := @parameter: java.lang.Class;
v := @parameter: java.lang.String;
if v == null goto label;
v = virtualinvoke v.<java.lang.String: boolean equalsIgnoreCase(java.lang.String)>(v);
if v != 0 goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = virtualinvoke v.<java.lang.Class: java.lang.String getSimpleName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>(v);
if v == 0 goto label;
label:
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private static org.apache.logging.log4j.core.async.AsyncQueueFullPolicy createCustomRouter(java.lang.String)
{
org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy v;
org.apache.logging.log4j.Logger v, v;
java.lang.Object v;
java.lang.String v, v;
java.lang.Exception v;
v := @parameter: java.lang.String;
label:
v = <org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Creating custom AsyncQueueFullPolicy \'{}\'", v);
v = staticinvoke <org.apache.logging.log4j.util.LoaderUtil: java.lang.Object newCheckedInstanceOf(java.lang.String,java.lang.Class)>(v, class "Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;");
label:
return v;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object)>("Using DefaultAsyncQueueFullPolicy. Could not create custom AsyncQueueFullPolicy \'{}\': {}", v, v, v);
v = new org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy;
specialinvoke v.<org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy: void <init>()>();
return v;
catch java.lang.Exception from label to label with label;
}
private static org.apache.logging.log4j.core.async.AsyncQueueFullPolicy createDiscardingAsyncQueueFullPolicy()
{
org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy v;
org.apache.logging.log4j.Level v, v, v;
org.apache.logging.log4j.util.PropertiesUtil v;
org.apache.logging.log4j.Logger v;
java.lang.String v, v;
v = staticinvoke <org.apache.logging.log4j.util.PropertiesUtil: org.apache.logging.log4j.util.PropertiesUtil getProperties()>();
v = <org.apache.logging.log4j.Level: org.apache.logging.log4j.Level INFO>;
v = virtualinvoke v.<org.apache.logging.log4j.Level: java.lang.String name()>();
v = virtualinvoke v.<org.apache.logging.log4j.util.PropertiesUtil: java.lang.String getStringProperty(java.lang.String,java.lang.String)>("log4j.DiscardThreshold", v);
v = <org.apache.logging.log4j.Level: org.apache.logging.log4j.Level INFO>;
v = staticinvoke <org.apache.logging.log4j.Level: org.apache.logging.log4j.Level toLevel(java.lang.String,org.apache.logging.log4j.Level)>(v, v);
v = <org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory: org.apache.logging.log4j.Logger LOGGER>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void debug(java.lang.String,java.lang.Object)>("Creating custom DiscardingAsyncQueueFullPolicy(discardThreshold:{})", v);
v = new org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy;
specialinvoke v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: void <init>(org.apache.logging.log4j.Level)>(v);
return v;
}
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.async.AsyncQueueFullPolicyFactory: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}