class org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher extends org.apache.logging.log4j.core.util.Log4jThread
{
private static final org.apache.logging.log4j.core.LogEvent STOP_EVENT;
private static final java.util.concurrent.atomic.AtomicLong THREAD_COUNTER;
private static final org.apache.logging.log4j.Logger LOGGER;
private final org.apache.logging.log4j.core.config.AppenderControl errorAppender;
private final java.util.List appenders;
private final java.util.concurrent.BlockingQueue queue;
private final java.util.concurrent.atomic.AtomicBoolean stoppedRef;
void <init>(java.lang.String, org.apache.logging.log4j.core.config.AppenderControl, java.util.List, java.util.concurrent.BlockingQueue)
{
org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher v;
org.apache.logging.log4j.core.config.AppenderControl v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.BlockingQueue v;
long v;
java.util.concurrent.atomic.AtomicLong v;
java.util.List v;
java.lang.String v, v;
v := @this: org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher;
v := @parameter: java.lang.String;
v := @parameter: org.apache.logging.log4j.core.config.AppenderControl;
v := @parameter: java.util.List;
v := @parameter: java.util.concurrent.BlockingQueue;
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.atomic.AtomicLong THREAD_COUNTER>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicLong: long incrementAndGet()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (long,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[])>("AsyncAppenderEventDispatcher-\u0001-\u0001");
specialinvoke v.<org.apache.logging.log4j.core.util.Log4jThread: void <init>(java.lang.String)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void setDaemon(boolean)>(1);
v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.config.AppenderControl errorAppender> = v;
v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.List appenders> = v;
v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.BlockingQueue queue> = v;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>()>();
v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.atomic.AtomicBoolean stoppedRef> = v;
return;
}
java.util.List getAppenders()
{
org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher v;
java.util.List v;
java.util.stream.Stream v, v;
java.lang.Object v;
java.util.stream.Collector v;
java.util.function.Function v;
v := @this: org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher;
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.List appenders>;
v = interfaceinvoke v.<java.util.List: java.util.stream.Stream stream()>();
v = staticinvoke <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher$getAppender__1102: java.util.function.Function bootstrap$()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.util.stream.Stream map(java.util.function.Function)>(v);
v = staticinvoke <java.util.stream.Collectors: java.util.stream.Collector toList()>();
v = interfaceinvoke v.<java.util.stream.Stream: java.lang.Object collect(java.util.stream.Collector)>(v);
return v;
}
public void run()
{
org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher v;
java.lang.String v;
org.apache.logging.log4j.Logger v;
v := @this: org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher;
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("{} has started.", v);
specialinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void dispatchAll()>();
specialinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void dispatchRemaining()>();
return;
}
private void dispatchAll()
{
org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.BlockingQueue v, v;
org.apache.logging.log4j.core.LogEvent v;
org.apache.logging.log4j.Logger v;
java.lang.InterruptedException v;
java.lang.Object v;
java.lang.String v;
boolean v, v;
v := @this: org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher;
label:
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.atomic.AtomicBoolean stoppedRef>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean get()>();
if v != 0 goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: java.lang.Object take()>();
label:
goto label;
label:
v := @caughtexception;
virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void interrupt()>();
goto label;
label:
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.LogEvent STOP_EVENT>;
if v == v goto label;
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: boolean isEmpty()>();
interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: void setEndOfBatch(boolean)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void dispatch(org.apache.logging.log4j.core.LogEvent)>(v);
goto label;
label:
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("{} has stopped.", v);
return;
catch java.lang.InterruptedException from label to label with label;
}
private void dispatchRemaining()
{
org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher v;
java.util.concurrent.BlockingQueue v, v;
java.lang.Integer v;
org.apache.logging.log4j.core.LogEvent v;
org.apache.logging.log4j.Logger v;
int v;
java.lang.Object v;
java.lang.String v;
boolean v;
v := @this: org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher;
v = 0;
label:
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: java.lang.Object poll()>();
if v == null goto label;
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.LogEvent STOP_EVENT>;
if v == v goto label;
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.BlockingQueue queue>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: boolean isEmpty()>();
interfaceinvoke v.<org.apache.logging.log4j.core.LogEvent: void setEndOfBatch(boolean)>(v);
virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void dispatch(org.apache.logging.log4j.core.LogEvent)>(v);
v = v + 1;
goto label;
label:
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.lang.String getName()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object)>("{} has processed the last {} remaining event(s).", v, v);
return;
}
void dispatch(org.apache.logging.log4j.core.LogEvent)
{
java.lang.Throwable v, v;
org.apache.logging.log4j.core.LogEvent v;
int v, v;
java.lang.String v, v, v, v;
boolean v;
org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher v;
org.apache.logging.log4j.core.config.AppenderControl v, v, v;
java.util.List v, v;
org.apache.logging.log4j.Logger v, v;
java.lang.Object v;
v := @this: org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher;
v := @parameter: org.apache.logging.log4j.core.LogEvent;
v = 0;
v = 0;
label:
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.List appenders>;
v = interfaceinvoke v.<java.util.List: int size()>();
if v >= v goto label;
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.List appenders>;
v = interfaceinvoke v.<java.util.List: java.lang.Object get(int)>(v);
label:
virtualinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: void callAppender(org.apache.logging.log4j.core.LogEvent)>(v);
v = 1;
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.lang.String getName()>();
v = virtualinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: java.lang.String getAppenderName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object)>("{} has failed to call appender {}", v, v, v);
label:
v = v + 1;
goto label;
label:
if v != 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.config.AppenderControl errorAppender>;
if v == null goto label;
label:
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.config.AppenderControl errorAppender>;
virtualinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: void callAppender(org.apache.logging.log4j.core.LogEvent)>(v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.lang.String getName()>();
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.config.AppenderControl errorAppender>;
v = virtualinvoke v.<org.apache.logging.log4j.core.config.AppenderControl: java.lang.String getAppenderName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object,java.lang.Object,java.lang.Object)>("{} has failed to call the error appender {}", v, v, v);
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
void stop(long) throws java.lang.InterruptedException
{
org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher v;
java.lang.Thread$State v, v;
java.util.concurrent.atomic.AtomicBoolean v;
java.util.concurrent.BlockingQueue v;
long v;
org.apache.logging.log4j.core.LogEvent v;
org.apache.logging.log4j.Logger v;
java.lang.String v;
boolean v, v, v;
v := @this: org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher;
v := @parameter: long;
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.atomic.AtomicBoolean stoppedRef>;
v = virtualinvoke v.<java.util.concurrent.atomic.AtomicBoolean: boolean compareAndSet(boolean,boolean)>(0, 1);
if v == 0 goto label;
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.Logger LOGGER>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.lang.String getName()>();
interfaceinvoke v.<org.apache.logging.log4j.Logger: void trace(java.lang.String,java.lang.Object)>("{} is signaled to stop.", v);
label:
v = <java.lang.Thread$State: java.lang.Thread$State NEW>;
v = virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.lang.Thread$State getState()>();
v = virtualinvoke v.<java.lang.Thread$State: boolean equals(java.lang.Object)>(v);
if v != 0 goto label;
v = v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.BlockingQueue queue>;
v = <org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.LogEvent STOP_EVENT>;
v = interfaceinvoke v.<java.util.concurrent.BlockingQueue: boolean offer(java.lang.Object)>(v);
if v != 0 goto label;
virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void interrupt()>();
label:
virtualinvoke v.<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: void join(long)>(v);
return;
}
static void <clinit>()
{
org.apache.logging.log4j.status.StatusLogger v;
java.util.concurrent.atomic.AtomicLong v;
org.apache.logging.log4j.core.impl.Log4jLogEvent v;
v = new org.apache.logging.log4j.core.impl.Log4jLogEvent;
specialinvoke v.<org.apache.logging.log4j.core.impl.Log4jLogEvent: void <init>()>();
<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.core.LogEvent STOP_EVENT> = v;
v = new java.util.concurrent.atomic.AtomicLong;
specialinvoke v.<java.util.concurrent.atomic.AtomicLong: void <init>(long)>(0L);
<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: java.util.concurrent.atomic.AtomicLong THREAD_COUNTER> = v;
v = staticinvoke <org.apache.logging.log4j.status.StatusLogger: org.apache.logging.log4j.status.StatusLogger getLogger()>();
<org.apache.logging.log4j.core.appender.AsyncAppenderEventDispatcher: org.apache.logging.log4j.Logger LOGGER> = v;
return;
}
}