public class org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy extends org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy
{
private static final org.apache.logging.log4j.Logger LOGGER;
private final org.apache.logging.log4j.Level thresholdLevel;
private final java.util.concurrent.atomic.AtomicLong discardCount;
public void <init>(org.apache.logging.log4j.Level)
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy v;
org.apache.logging.log4j.Level v;
java.lang.Object v;
v := @this: org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy;
v := @parameter: org.apache.logging.log4j.Level;
specialinvoke v.<org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy: void <init>()>();
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>()>();
v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: java.util.concurrent.atomic.AtomicLong discardCount> = v;
v = staticinvoke <java.util.Objects: java.lang.Object requireNonNull(java.lang.Object,java.lang.String)>(v, "thresholdLevel");
v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: org.apache.logging.log4j.Level thresholdLevel> = v;
return;
}
public org.apache.logging.log4j.core.async.EventRoute getRoute(long, org.apache.logging.log4j.Level)
{
org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy v;
org.apache.logging.log4j.Level v, v, v;
long v, v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.logging.log4j.Logger v;
byte v;
org.apache.logging.log4j.core.async.EventRoute v, v;
boolean v;
v := @this: org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy;
v := @parameter: long;
v := @parameter: org.apache.logging.log4j.Level;
v = v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: org.apache.logging.log4j.Level thresholdLevel>;
v = virtualinvoke v.<org.apache.logging.log4j.Level: boolean isLessSpecificThan(org.apache.logging.log4j.Level)>(v);
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: java.util.concurrent.atomic.AtomicLong discardCount>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long getAndIncrement()>();
v = v cmp 0L;
if v != 0 goto label;
v = <org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: org.apache.logging.log4j.Logger LOGGER>;
v = v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: org.apache.logging.log4j.Level thresholdLevel>;
interfaceinvoke v.<org.apache.logging.log4j.Logger: void warn(java.lang.String,java.lang.Object,java.lang.Object)>("Async queue is full, discarding event with level {}. This message will only appear once; future events from {} are silently discarded until queue capacity becomes available.", v, v);
label:
v = <org.apache.logging.log4j.core.async.EventRoute: org.apache.logging.log4j.core.async.EventRoute DISCARD>;
return v;
label:
v = specialinvoke v.<org.apache.logging.log4j.core.async.DefaultAsyncQueueFullPolicy: org.apache.logging.log4j.core.async.EventRoute getRoute(long,org.apache.logging.log4j.Level)>(v, v);
return v;
}
public static long getDiscardCount(org.apache.logging.log4j.core.async.AsyncQueueFullPolicy)
{
java.util.concurrent.atomic.AtomicLong v;
org.apache.logging.log4j.core.async.AsyncQueueFullPolicy v;
long v;
boolean v;
v := @parameter: org.apache.logging.log4j.core.async.AsyncQueueFullPolicy;
v = v instanceof org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy;
if v == 0 goto label;
v = v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: java.util.concurrent.atomic.AtomicLong discardCount>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long get()>();
return v;
label:
return 0L;
}
public org.apache.logging.log4j.Level getThresholdLevel()
{
org.apache.logging.log4j.Level v;
org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy v;
v := @this: org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy;
v = v.<org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy: org.apache.logging.log4j.Level thresholdLevel>;
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.DiscardingAsyncQueueFullPolicy: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}