public final class org.apache.logging.log4j.core.appender.AsyncAppender extends org.apache.logging.log4j.core.appender.AbstractAppender
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: org.apache.logging.log4j.core.appender.AsyncAppender
super_class: org.apache.logging.log4j.core.appender.AbstractAppender
{
private static final int DEFAULT_QUEUE_SIZE;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 1024
private static final org.apache.logging.log4j.core.LogEvent SHUTDOWN_LOG_EVENT;
descriptor: Lorg/apache/logging/log4j/core/LogEvent;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private static final java.util.concurrent.atomic.AtomicLong THREAD_SEQUENCE;
descriptor: Ljava/util/concurrent/atomic/AtomicLong;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private final java.util.concurrent.BlockingQueue<org.apache.logging.log4j.core.LogEvent> queue;
descriptor: Ljava/util/concurrent/BlockingQueue;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/concurrent/BlockingQueue<Lorg/apache/logging/log4j/core/LogEvent;>;
private final int queueSize;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final boolean blocking;
descriptor: Z
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final long shutdownTimeout;
descriptor: J
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.apache.logging.log4j.core.config.Configuration config;
descriptor: Lorg/apache/logging/log4j/core/config/Configuration;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.apache.logging.log4j.core.config.AppenderRef[] appenderRefs;
descriptor: [Lorg/apache/logging/log4j/core/config/AppenderRef;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.lang.String errorRef;
descriptor: Ljava/lang/String;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final boolean includeLocation;
descriptor: Z
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private org.apache.logging.log4j.core.config.AppenderControl errorAppender;
descriptor: Lorg/apache/logging/log4j/core/config/AppenderControl;
flags: (0x0002) ACC_PRIVATE
private org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread thread;
descriptor: Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
flags: (0x0002) ACC_PRIVATE
private org.apache.logging.log4j.core.async.AsyncQueueFullPolicy asyncQueueFullPolicy;
descriptor: Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;
flags: (0x0002) ACC_PRIVATE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=4, locals=0, args_size=0
0: new org.apache.logging.log4j.core.appender.AsyncAppender$1
dup
invokespecial org.apache.logging.log4j.core.appender.AsyncAppender$1.<init>:()V
putstatic org.apache.logging.log4j.core.appender.AsyncAppender.SHUTDOWN_LOG_EVENT:Lorg/apache/logging/log4j/core/LogEvent;
1: new java.util.concurrent.atomic.AtomicLong
dup
lconst_1
invokespecial java.util.concurrent.atomic.AtomicLong.<init>:(J)V
putstatic org.apache.logging.log4j.core.appender.AsyncAppender.THREAD_SEQUENCE:Ljava/util/concurrent/atomic/AtomicLong;
return
LocalVariableTable:
Start End Slot Name Signature
private void <init>(java.lang.String, org.apache.logging.log4j.core.Filter, org.apache.logging.log4j.core.config.AppenderRef[], java.lang.String, int, boolean, boolean, long, org.apache.logging.log4j.core.config.Configuration, boolean, org.apache.logging.log4j.core.async.BlockingQueueFactory<org.apache.logging.log4j.core.LogEvent>, org.apache.logging.log4j.core.config.Property[]);
descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;[Lorg/apache/logging/log4j/core/config/AppenderRef;Ljava/lang/String;IZZJLorg/apache/logging/log4j/core/config/Configuration;ZLorg/apache/logging/log4j/core/async/BlockingQueueFactory;[Lorg/apache/logging/log4j/core/config/Property;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=6, locals=14, args_size=13
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 10 start local 11 start local 12 start local 13 0: aload 0
aload 1
aload 2
aconst_null
iload 7
aload 13
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/Layout;Z[Lorg/apache/logging/log4j/core/config/Property;)V
1: aload 0
aload 12
iload 5
invokeinterface org.apache.logging.log4j.core.async.BlockingQueueFactory.create:(I)Ljava/util/concurrent/BlockingQueue;
putfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
2: aload 0
iload 5
putfield org.apache.logging.log4j.core.appender.AsyncAppender.queueSize:I
3: aload 0
iload 6
putfield org.apache.logging.log4j.core.appender.AsyncAppender.blocking:Z
4: aload 0
lload 8
putfield org.apache.logging.log4j.core.appender.AsyncAppender.shutdownTimeout:J
5: aload 0
aload 10
putfield org.apache.logging.log4j.core.appender.AsyncAppender.config:Lorg/apache/logging/log4j/core/config/Configuration;
6: aload 0
aload 3
putfield org.apache.logging.log4j.core.appender.AsyncAppender.appenderRefs:[Lorg/apache/logging/log4j/core/config/AppenderRef;
7: aload 0
aload 4
putfield org.apache.logging.log4j.core.appender.AsyncAppender.errorRef:Ljava/lang/String;
8: aload 0
iload 11
putfield org.apache.logging.log4j.core.appender.AsyncAppender.includeLocation:Z
9: return
end local 13 end local 12 end local 11 end local 10 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 10 1 name Ljava/lang/String;
0 10 2 filter Lorg/apache/logging/log4j/core/Filter;
0 10 3 appenderRefs [Lorg/apache/logging/log4j/core/config/AppenderRef;
0 10 4 errorRef Ljava/lang/String;
0 10 5 queueSize I
0 10 6 blocking Z
0 10 7 ignoreExceptions Z
0 10 8 shutdownTimeout J
0 10 10 config Lorg/apache/logging/log4j/core/config/Configuration;
0 10 11 includeLocation Z
0 10 12 blockingQueueFactory Lorg/apache/logging/log4j/core/async/BlockingQueueFactory<Lorg/apache/logging/log4j/core/LogEvent;>;
0 10 13 properties [Lorg/apache/logging/log4j/core/config/Property;
Signature: (Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;[Lorg/apache/logging/log4j/core/config/AppenderRef;Ljava/lang/String;IZZJLorg/apache/logging/log4j/core/config/Configuration;ZLorg/apache/logging/log4j/core/async/BlockingQueueFactory<Lorg/apache/logging/log4j/core/LogEvent;>;[Lorg/apache/logging/log4j/core/config/Property;)V
MethodParameters:
Name Flags
name final
filter final
appenderRefs final
errorRef final
queueSize final
blocking final
ignoreExceptions final
shutdownTimeout final
config final
includeLocation final
blockingQueueFactory final
properties final
public void start();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=6, locals=8, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.config:Lorg/apache/logging/log4j/core/config/Configuration;
invokeinterface org.apache.logging.log4j.core.config.Configuration.getAppenders:()Ljava/util/Map;
astore 1
start local 1 1: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 2
start local 2 2: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.appenderRefs:[Lorg/apache/logging/log4j/core/config/AppenderRef;
dup
astore 6
arraylength
istore 5
iconst_0
istore 4
goto 10
StackMap locals: org.apache.logging.log4j.core.appender.AsyncAppender java.util.Map java.util.List top int int org.apache.logging.log4j.core.config.AppenderRef[]
StackMap stack:
3: aload 6
iload 4
aaload
astore 3
start local 3 4: aload 1
aload 3
invokevirtual org.apache.logging.log4j.core.config.AppenderRef.getRef:()Ljava/lang/String;
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.Appender
astore 7
start local 7 5: aload 7
ifnull 8
6: aload 2
new org.apache.logging.log4j.core.config.AppenderControl
dup
aload 7
aload 3
invokevirtual org.apache.logging.log4j.core.config.AppenderRef.getLevel:()Lorg/apache/logging/log4j/Level;
aload 3
invokevirtual org.apache.logging.log4j.core.config.AppenderRef.getFilter:()Lorg/apache/logging/log4j/core/Filter;
invokespecial org.apache.logging.log4j.core.config.AppenderControl.<init>:(Lorg/apache/logging/log4j/core/Appender;Lorg/apache/logging/log4j/Level;Lorg/apache/logging/log4j/core/Filter;)V
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
7: goto 9
8: StackMap locals: org.apache.logging.log4j.core.appender.AsyncAppender java.util.Map java.util.List org.apache.logging.log4j.core.config.AppenderRef int int org.apache.logging.log4j.core.config.AppenderRef[] org.apache.logging.log4j.core.Appender
StackMap stack:
getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "No appender named {} was configured"
aload 3
invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;)V
end local 7 end local 3 9: StackMap locals: org.apache.logging.log4j.core.appender.AsyncAppender java.util.Map java.util.List top int int org.apache.logging.log4j.core.config.AppenderRef[]
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
10: iload 4
iload 5
if_icmplt 3
11: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.errorRef:Ljava/lang/String;
ifnull 17
12: aload 1
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.errorRef:Ljava/lang/String;
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.Appender
astore 3
start local 3 13: aload 3
ifnull 16
14: aload 0
new org.apache.logging.log4j.core.config.AppenderControl
dup
aload 3
aconst_null
aconst_null
invokespecial org.apache.logging.log4j.core.config.AppenderControl.<init>:(Lorg/apache/logging/log4j/core/Appender;Lorg/apache/logging/log4j/Level;Lorg/apache/logging/log4j/core/Filter;)V
putfield org.apache.logging.log4j.core.appender.AsyncAppender.errorAppender:Lorg/apache/logging/log4j/core/config/AppenderControl;
15: goto 17
16: StackMap locals: org.apache.logging.log4j.core.appender.AsyncAppender java.util.Map java.util.List org.apache.logging.log4j.core.Appender
StackMap stack:
getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "Unable to set up error Appender. No appender named {} was configured"
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.errorRef:Ljava/lang/String;
invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;)V
end local 3 17: StackMap locals:
StackMap stack:
aload 2
invokeinterface java.util.List.size:()I
ifle 21
18: aload 0
new org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread
dup
aload 0
aload 2
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
invokespecial org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread.<init>:(Lorg/apache/logging/log4j/core/appender/AsyncAppender;Ljava/util/List;Ljava/util/concurrent/BlockingQueue;)V
putfield org.apache.logging.log4j.core.appender.AsyncAppender.thread:Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
19: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.thread:Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
new java.lang.StringBuilder
dup
ldc "AsyncAppender-"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread.setName:(Ljava/lang/String;)V
20: goto 23
StackMap locals:
StackMap stack:
21: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.errorRef:Ljava/lang/String;
ifnonnull 23
22: new org.apache.logging.log4j.core.config.ConfigurationException
dup
new java.lang.StringBuilder
dup
ldc "No appenders are available for AsyncAppender "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial org.apache.logging.log4j.core.config.ConfigurationException.<init>:(Ljava/lang/String;)V
athrow
23: StackMap locals:
StackMap stack:
aload 0
invokestatic org.apache.logging.log4j.core.async.AsyncQueueFullPolicyFactory.create:()Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;
putfield org.apache.logging.log4j.core.appender.AsyncAppender.asyncQueueFullPolicy:Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;
24: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.thread:Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread.start:()V
25: aload 0
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.start:()V
26: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 27 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
1 27 1 map Ljava/util/Map<Ljava/lang/String;Lorg/apache/logging/log4j/core/Appender;>;
2 27 2 appenders Ljava/util/List<Lorg/apache/logging/log4j/core/config/AppenderControl;>;
4 9 3 appenderRef Lorg/apache/logging/log4j/core/config/AppenderRef;
5 9 7 appender Lorg/apache/logging/log4j/core/Appender;
13 17 3 appender Lorg/apache/logging/log4j/core/Appender;
public boolean stop(long, java.util.concurrent.TimeUnit);
descriptor: (JLjava/util/concurrent/TimeUnit;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=3
start local 0 start local 1 start local 3 0: aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.setStopping:()V
1: aload 0
lload 1
aload 3
iconst_0
invokespecial org.apache.logging.log4j.core.appender.AbstractAppender.stop:(JLjava/util/concurrent/TimeUnit;Z)Z
pop
2: getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "AsyncAppender stopping. Queue still has {} events."
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
invokeinterface java.util.concurrent.BlockingQueue.size:()I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface org.apache.logging.log4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
3: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.thread:Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread.shutdown:()V
4: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.thread:Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.shutdownTimeout:J
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread.join:(J)V
5: goto 8
StackMap locals:
StackMap stack: java.lang.InterruptedException
6: pop
7: getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "Interrupted while stopping AsyncAppender {}"
aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.getName:()Ljava/lang/String;
invokeinterface org.apache.logging.log4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Object;)V
8: StackMap locals:
StackMap stack:
getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "AsyncAppender stopped. Queue has {} events."
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
invokeinterface java.util.concurrent.BlockingQueue.size:()I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface org.apache.logging.log4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
9: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.asyncQueueFullPolicy:Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;
invokestatic org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy.getDiscardCount:(Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;)J
lconst_0
lcmp
ifle 13
10: getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "AsyncAppender: {} discarded {} events."
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.asyncQueueFullPolicy:Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;
11: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.asyncQueueFullPolicy:Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;
invokestatic org.apache.logging.log4j.core.async.DiscardingAsyncQueueFullPolicy.getDiscardCount:(Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;)J
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
12: invokeinterface org.apache.logging.log4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
13: StackMap locals:
StackMap stack:
aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.setStopped:()V
14: iconst_1
ireturn
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 15 1 timeout J
0 15 3 timeUnit Ljava/util/concurrent/TimeUnit;
Exception table:
from to target type
4 5 6 Class java.lang.InterruptedException
MethodParameters:
Name Flags
timeout final
timeUnit final
public void append(org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.isStarted:()Z
ifne 2
1: new java.lang.IllegalStateException
dup
new java.lang.StringBuilder
dup
ldc "AsyncAppender "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " is not active"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 1
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.includeLocation:Z
invokestatic org.apache.logging.log4j.core.impl.Log4jLogEvent.createMemento:(Lorg/apache/logging/log4j/core/LogEvent;Z)Lorg/apache/logging/log4j/core/impl/Log4jLogEvent;
astore 2
start local 2 3: aload 1
invokeinterface org.apache.logging.log4j.core.LogEvent.getMessage:()Lorg/apache/logging/log4j/message/Message;
invokestatic org.apache.logging.log4j.core.async.InternalAsyncUtil.makeMessageImmutable:(Lorg/apache/logging/log4j/message/Message;)Lorg/apache/logging/log4j/message/Message;
pop
4: aload 0
aload 2
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.transfer:(Lorg/apache/logging/log4j/core/LogEvent;)Z
ifne 15
5: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.blocking:Z
ifeq 13
6: invokestatic org.apache.logging.log4j.spi.AbstractLogger.getRecursionDepth:()I
iconst_1
if_icmple 10
7: invokestatic org.apache.logging.log4j.core.async.AsyncQueueFullMessageUtil.logWarningToStatusLogger:()V
8: aload 0
aload 1
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.logMessageInCurrentThread:(Lorg/apache/logging/log4j/core/LogEvent;)V
9: goto 15
10: StackMap locals: org.apache.logging.log4j.core.impl.Log4jLogEvent
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.asyncQueueFullPolicy:Lorg/apache/logging/log4j/core/async/AsyncQueueFullPolicy;
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.thread:Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread.getId:()J
aload 2
invokevirtual org.apache.logging.log4j.core.impl.Log4jLogEvent.getLevel:()Lorg/apache/logging/log4j/Level;
invokeinterface org.apache.logging.log4j.core.async.AsyncQueueFullPolicy.getRoute:(JLorg/apache/logging/log4j/Level;)Lorg/apache/logging/log4j/core/async/EventRoute;
astore 3
start local 3 11: aload 3
aload 0
aload 2
invokevirtual org.apache.logging.log4j.core.async.EventRoute.logMessage:(Lorg/apache/logging/log4j/core/appender/AsyncAppender;Lorg/apache/logging/log4j/core/LogEvent;)V
end local 3 12: goto 15
13: StackMap locals:
StackMap stack:
aload 0
new java.lang.StringBuilder
dup
ldc "Appender "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " is unable to write primary appenders. queue is full"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.error:(Ljava/lang/String;)V
14: aload 0
iconst_0
aload 2
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.logToErrorAppenderIfNecessary:(ZLorg/apache/logging/log4j/core/LogEvent;)V
15: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 16 1 logEvent Lorg/apache/logging/log4j/core/LogEvent;
3 16 2 memento Lorg/apache/logging/log4j/core/impl/Log4jLogEvent;
11 12 3 route Lorg/apache/logging/log4j/core/async/EventRoute;
MethodParameters:
Name Flags
logEvent final
private boolean transfer(org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
instanceof java.util.concurrent.TransferQueue
ifeq 2
1: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
checkcast java.util.concurrent.TransferQueue
aload 1
invokeinterface java.util.concurrent.TransferQueue.tryTransfer:(Ljava/lang/Object;)Z
goto 3
2: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
aload 1
invokeinterface java.util.concurrent.BlockingQueue.offer:(Ljava/lang/Object;)Z
3: StackMap locals:
StackMap stack: int
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 4 1 memento Lorg/apache/logging/log4j/core/LogEvent;
MethodParameters:
Name Flags
memento final
public void logMessageInCurrentThread(org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 1
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
invokeinterface java.util.concurrent.BlockingQueue.isEmpty:()Z
invokeinterface org.apache.logging.log4j.core.LogEvent.setEndOfBatch:(Z)V
1: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.thread:Lorg/apache/logging/log4j/core/appender/AsyncAppender$AsyncThread;
aload 1
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread.callAppenders:(Lorg/apache/logging/log4j/core/LogEvent;)Z
istore 2
start local 2 2: aload 0
iload 2
aload 1
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.logToErrorAppenderIfNecessary:(ZLorg/apache/logging/log4j/core/LogEvent;)V
3: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 4 1 logEvent Lorg/apache/logging/log4j/core/LogEvent;
2 4 2 appendSuccessful Z
MethodParameters:
Name Flags
logEvent final
public void logMessageInBackgroundThread(org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
aload 1
invokeinterface java.util.concurrent.BlockingQueue.put:(Ljava/lang/Object;)V
1: goto 5
StackMap locals:
StackMap stack: java.lang.InterruptedException
2: pop
3: aload 0
aload 1
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.handleInterruptedException:(Lorg/apache/logging/log4j/core/LogEvent;)Z
istore 2
start local 2 4: aload 0
iload 2
aload 1
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.logToErrorAppenderIfNecessary:(ZLorg/apache/logging/log4j/core/LogEvent;)V
end local 2 5: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 6 1 logEvent Lorg/apache/logging/log4j/core/LogEvent;
4 5 2 appendSuccessful Z
Exception table:
from to target type
0 1 2 Class java.lang.InterruptedException
MethodParameters:
Name Flags
logEvent final
private boolean handleInterruptedException(org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/core/LogEvent;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
aload 1
invokeinterface java.util.concurrent.BlockingQueue.offer:(Ljava/lang/Object;)Z
istore 2
start local 2 1: iload 2
ifne 5
2: getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "Interrupted while waiting for a free slot in the AsyncAppender LogEvent-queue {}"
3: aload 0
invokevirtual org.apache.logging.log4j.core.appender.AsyncAppender.getName:()Ljava/lang/String;
4: invokeinterface org.apache.logging.log4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Object;)V
5: StackMap locals: int
StackMap stack:
invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
invokevirtual java.lang.Thread.interrupt:()V
6: iload 2
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 7 1 memento Lorg/apache/logging/log4j/core/LogEvent;
1 7 2 appendSuccessful Z
MethodParameters:
Name Flags
memento final
private void logToErrorAppenderIfNecessary(boolean, org.apache.logging.log4j.core.LogEvent);
descriptor: (ZLorg/apache/logging/log4j/core/LogEvent;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: iload 1
ifne 2
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.errorAppender:Lorg/apache/logging/log4j/core/config/AppenderControl;
ifnull 2
1: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.errorAppender:Lorg/apache/logging/log4j/core/config/AppenderControl;
aload 2
invokevirtual org.apache.logging.log4j.core.config.AppenderControl.callAppender:(Lorg/apache/logging/log4j/core/LogEvent;)V
2: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
0 3 1 appendSuccessful Z
0 3 2 logEvent Lorg/apache/logging/log4j/core/LogEvent;
MethodParameters:
Name Flags
appendSuccessful final
logEvent final
public static org.apache.logging.log4j.core.appender.AsyncAppender createAppender(org.apache.logging.log4j.core.config.AppenderRef[], java.lang.String, boolean, long, int, java.lang.String, boolean, org.apache.logging.log4j.core.Filter, org.apache.logging.log4j.core.config.Configuration, boolean);
descriptor: ([Lorg/apache/logging/log4j/core/config/AppenderRef;Ljava/lang/String;ZJILjava/lang/String;ZLorg/apache/logging/log4j/core/Filter;Lorg/apache/logging/log4j/core/config/Configuration;Z)Lorg/apache/logging/log4j/core/appender/AsyncAppender;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=15, locals=11, args_size=10
start local 0 start local 1 start local 2 start local 3 start local 5 start local 6 start local 7 start local 8 start local 9 start local 10 0: aload 6
ifnonnull 3
1: getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "No name provided for AsyncAppender"
invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;)V
2: aconst_null
areturn
3: StackMap locals:
StackMap stack:
aload 0
ifnonnull 5
4: getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
ldc "No appender references provided to AsyncAppender {}"
aload 6
invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;)V
5: StackMap locals:
StackMap stack:
new org.apache.logging.log4j.core.appender.AsyncAppender
dup
aload 6
aload 8
aload 0
aload 1
iload 5
iload 2
iload 10
6: lload 3
aload 9
iload 7
new org.apache.logging.log4j.core.async.ArrayBlockingQueueFactory
dup
invokespecial org.apache.logging.log4j.core.async.ArrayBlockingQueueFactory.<init>:()V
aconst_null
7: invokespecial org.apache.logging.log4j.core.appender.AsyncAppender.<init>:(Ljava/lang/String;Lorg/apache/logging/log4j/core/Filter;[Lorg/apache/logging/log4j/core/config/AppenderRef;Ljava/lang/String;IZZJLorg/apache/logging/log4j/core/config/Configuration;ZLorg/apache/logging/log4j/core/async/BlockingQueueFactory;[Lorg/apache/logging/log4j/core/config/Property;)V
areturn
end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 appenderRefs [Lorg/apache/logging/log4j/core/config/AppenderRef;
0 8 1 errorRef Ljava/lang/String;
0 8 2 blocking Z
0 8 3 shutdownTimeout J
0 8 5 size I
0 8 6 name Ljava/lang/String;
0 8 7 includeLocation Z
0 8 8 filter Lorg/apache/logging/log4j/core/Filter;
0 8 9 config Lorg/apache/logging/log4j/core/config/Configuration;
0 8 10 ignoreExceptions Z
RuntimeVisibleAnnotations:
java.lang.Deprecated()
MethodParameters:
Name Flags
appenderRefs final
errorRef final
blocking final
shutdownTimeout final
size final
name final
includeLocation final
filter final
config final
ignoreExceptions final
public static org.apache.logging.log4j.core.appender.AsyncAppender$Builder newBuilder();
descriptor: ()Lorg/apache/logging/log4j/core/appender/AsyncAppender$Builder;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new org.apache.logging.log4j.core.appender.AsyncAppender$Builder
dup
invokespecial org.apache.logging.log4j.core.appender.AsyncAppender$Builder.<init>:()V
areturn
LocalVariableTable:
Start End Slot Name Signature
RuntimeVisibleAnnotations:
org.apache.logging.log4j.core.config.plugins.PluginBuilderFactory()
public java.lang.String[] getAppenderRefStrings();
descriptor: ()[Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.appenderRefs:[Lorg/apache/logging/log4j/core/config/AppenderRef;
arraylength
anewarray java.lang.String
astore 1
start local 1 1: iconst_0
istore 2
start local 2 2: goto 5
3: StackMap locals: java.lang.String[] int
StackMap stack:
aload 1
iload 2
aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.appenderRefs:[Lorg/apache/logging/log4j/core/config/AppenderRef;
iload 2
aaload
invokevirtual org.apache.logging.log4j.core.config.AppenderRef.getRef:()Ljava/lang/String;
aastore
4: iinc 2 1
StackMap locals:
StackMap stack:
5: iload 2
aload 1
arraylength
if_icmplt 3
end local 2 6: aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
1 7 1 result [Ljava/lang/String;
2 6 2 i I
public boolean isIncludeLocation();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.includeLocation:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
public boolean isBlocking();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.blocking:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
public java.lang.String getErrorRef();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.errorRef:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
public int getQueueCapacity();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queueSize:I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
public int getQueueRemainingCapacity();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
invokeinterface java.util.concurrent.BlockingQueue.remainingCapacity:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
public int getQueueSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.appender.AsyncAppender.queue:Ljava/util/concurrent/BlockingQueue;
invokeinterface java.util.concurrent.BlockingQueue.size:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/appender/AsyncAppender;
static org.apache.logging.log4j.Logger access$0();
descriptor: ()Lorg/apache/logging/log4j/Logger;
flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
Code:
stack=1, locals=0, args_size=0
0: getstatic org.apache.logging.log4j.core.appender.AsyncAppender.LOGGER:Lorg/apache/logging/log4j/Logger;
areturn
LocalVariableTable:
Start End Slot Name Signature
}
SourceFile: "AsyncAppender.java"
NestMembers:
org.apache.logging.log4j.core.appender.AsyncAppender$1 org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread org.apache.logging.log4j.core.appender.AsyncAppender$Builder
InnerClasses:
org.apache.logging.log4j.core.appender.AsyncAppender$1
private AsyncThread = org.apache.logging.log4j.core.appender.AsyncAppender$AsyncThread of org.apache.logging.log4j.core.appender.AsyncAppender
public Builder = org.apache.logging.log4j.core.appender.AsyncAppender$Builder of org.apache.logging.log4j.core.appender.AsyncAppender
RuntimeVisibleAnnotations:
org.apache.logging.log4j.core.config.plugins.Plugin(name = "Async", category = "Core", elementType = "appender", printObject = true)