public class org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy implements org.apache.logging.log4j.core.config.ReliabilityStrategy
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy
super_class: java.lang.Object
{
private static final int MAX_RETRIES;
descriptor: I
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 3
private final java.util.concurrent.atomic.AtomicInteger counter;
descriptor: Ljava/util/concurrent/atomic/AtomicInteger;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.atomic.AtomicBoolean shutdown;
descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.locks.Lock shutdownLock;
descriptor: Ljava/util/concurrent/locks/Lock;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.locks.Condition noLogEvents;
descriptor: Ljava/util/concurrent/locks/Condition;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.apache.logging.log4j.core.config.LoggerConfig loggerConfig;
descriptor: Lorg/apache/logging/log4j/core/config/LoggerConfig;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
public void <init>(org.apache.logging.log4j.core.config.LoggerConfig);
descriptor: (Lorg/apache/logging/log4j/core/config/LoggerConfig;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.concurrent.atomic.AtomicInteger
dup
invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
putfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.counter:Ljava/util/concurrent/atomic/AtomicInteger;
2: aload 0
new java.util.concurrent.atomic.AtomicBoolean
dup
iconst_0
invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:(Z)V
putfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdown:Ljava/util/concurrent/atomic/AtomicBoolean;
3: aload 0
new java.util.concurrent.locks.ReentrantLock
dup
invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
putfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
4: aload 0
aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.newCondition:()Ljava/util/concurrent/locks/Condition;
putfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.noLogEvents:Ljava/util/concurrent/locks/Condition;
5: aload 0
aload 1
ldc "loggerConfig is null"
invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.config.LoggerConfig
putfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.loggerConfig:Lorg/apache/logging/log4j/core/config/LoggerConfig;
6: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
0 7 1 loggerConfig Lorg/apache/logging/log4j/core/config/LoggerConfig;
MethodParameters:
Name Flags
loggerConfig final
public void log(org.apache.logging.log4j.util.Supplier<org.apache.logging.log4j.core.config.LoggerConfig>, java.lang.String, java.lang.String, org.apache.logging.log4j.Marker, org.apache.logging.log4j.Level, org.apache.logging.log4j.message.Message, java.lang.Throwable);
descriptor: (Lorg/apache/logging/log4j/util/Supplier;Ljava/lang/String;Ljava/lang/String;Lorg/apache/logging/log4j/Marker;Lorg/apache/logging/log4j/Level;Lorg/apache/logging/log4j/message/Message;Ljava/lang/Throwable;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=10, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: aload 0
aload 1
invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.getActiveLoggerConfig:(Lorg/apache/logging/log4j/util/Supplier;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
astore 8
start local 8 1: aload 8
aload 2
aload 3
aload 4
aload 5
aload 6
aload 7
invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.log:(Ljava/lang/String;Ljava/lang/String;Lorg/apache/logging/log4j/Marker;Lorg/apache/logging/log4j/Level;Lorg/apache/logging/log4j/message/Message;Ljava/lang/Throwable;)V
2: goto 6
StackMap locals: org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy org.apache.logging.log4j.util.Supplier java.lang.String java.lang.String org.apache.logging.log4j.Marker org.apache.logging.log4j.Level org.apache.logging.log4j.message.Message java.lang.Throwable org.apache.logging.log4j.core.config.LoggerConfig
StackMap stack: java.lang.Throwable
3: astore 9
4: aload 8
invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.getReliabilityStrategy:()Lorg/apache/logging/log4j/core/config/ReliabilityStrategy;
invokeinterface org.apache.logging.log4j.core.config.ReliabilityStrategy.afterLogEvent:()V
5: aload 9
athrow
6: StackMap locals:
StackMap stack:
aload 8
invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.getReliabilityStrategy:()Lorg/apache/logging/log4j/core/config/ReliabilityStrategy;
invokeinterface org.apache.logging.log4j.core.config.ReliabilityStrategy.afterLogEvent:()V
7: return
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 8 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
0 8 1 reconfigured Lorg/apache/logging/log4j/util/Supplier<Lorg/apache/logging/log4j/core/config/LoggerConfig;>;
0 8 2 loggerName Ljava/lang/String;
0 8 3 fqcn Ljava/lang/String;
0 8 4 marker Lorg/apache/logging/log4j/Marker;
0 8 5 level Lorg/apache/logging/log4j/Level;
0 8 6 data Lorg/apache/logging/log4j/message/Message;
0 8 7 t Ljava/lang/Throwable;
1 8 8 config Lorg/apache/logging/log4j/core/config/LoggerConfig;
Exception table:
from to target type
1 3 3 any
Signature: (Lorg/apache/logging/log4j/util/Supplier<Lorg/apache/logging/log4j/core/config/LoggerConfig;>;Ljava/lang/String;Ljava/lang/String;Lorg/apache/logging/log4j/Marker;Lorg/apache/logging/log4j/Level;Lorg/apache/logging/log4j/message/Message;Ljava/lang/Throwable;)V
MethodParameters:
Name Flags
reconfigured final
loggerName final
fqcn final
marker final
level final
data final
t final
public void log(org.apache.logging.log4j.util.Supplier<org.apache.logging.log4j.core.config.LoggerConfig>, org.apache.logging.log4j.core.LogEvent);
descriptor: (Lorg/apache/logging/log4j/util/Supplier;Lorg/apache/logging/log4j/core/LogEvent;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.getActiveLoggerConfig:(Lorg/apache/logging/log4j/util/Supplier;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
astore 3
start local 3 1: aload 3
aload 2
invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.log:(Lorg/apache/logging/log4j/core/LogEvent;)V
2: goto 6
StackMap locals: org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy org.apache.logging.log4j.util.Supplier org.apache.logging.log4j.core.LogEvent org.apache.logging.log4j.core.config.LoggerConfig
StackMap stack: java.lang.Throwable
3: astore 4
4: aload 3
invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.getReliabilityStrategy:()Lorg/apache/logging/log4j/core/config/ReliabilityStrategy;
invokeinterface org.apache.logging.log4j.core.config.ReliabilityStrategy.afterLogEvent:()V
5: aload 4
athrow
6: StackMap locals:
StackMap stack:
aload 3
invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.getReliabilityStrategy:()Lorg/apache/logging/log4j/core/config/ReliabilityStrategy;
invokeinterface org.apache.logging.log4j.core.config.ReliabilityStrategy.afterLogEvent:()V
7: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
0 8 1 reconfigured Lorg/apache/logging/log4j/util/Supplier<Lorg/apache/logging/log4j/core/config/LoggerConfig;>;
0 8 2 event Lorg/apache/logging/log4j/core/LogEvent;
1 8 3 config Lorg/apache/logging/log4j/core/config/LoggerConfig;
Exception table:
from to target type
1 3 3 any
Signature: (Lorg/apache/logging/log4j/util/Supplier<Lorg/apache/logging/log4j/core/config/LoggerConfig;>;Lorg/apache/logging/log4j/core/LogEvent;)V
MethodParameters:
Name Flags
reconfigured final
event final
public org.apache.logging.log4j.core.config.LoggerConfig getActiveLoggerConfig(org.apache.logging.log4j.util.Supplier<org.apache.logging.log4j.core.config.LoggerConfig>);
descriptor: (Lorg/apache/logging/log4j/util/Supplier;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.loggerConfig:Lorg/apache/logging/log4j/core/config/LoggerConfig;
astore 2
start local 2 1: aload 0
invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.beforeLogEvent:()Z
ifne 6
2: aload 1
invokeinterface org.apache.logging.log4j.util.Supplier.get:()Ljava/lang/Object;
checkcast org.apache.logging.log4j.core.config.LoggerConfig
astore 2
3: aload 2
aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.loggerConfig:Lorg/apache/logging/log4j/core/config/LoggerConfig;
if_acmpne 4
aload 2
goto 5
StackMap locals: org.apache.logging.log4j.core.config.LoggerConfig
StackMap stack:
4: aload 2
invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.getReliabilityStrategy:()Lorg/apache/logging/log4j/core/config/ReliabilityStrategy;
aload 1
invokeinterface org.apache.logging.log4j.core.config.ReliabilityStrategy.getActiveLoggerConfig:(Lorg/apache/logging/log4j/util/Supplier;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
StackMap locals:
StackMap stack: org.apache.logging.log4j.core.config.LoggerConfig
5: areturn
6: StackMap locals:
StackMap stack:
aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
0 7 1 next Lorg/apache/logging/log4j/util/Supplier<Lorg/apache/logging/log4j/core/config/LoggerConfig;>;
1 7 2 result Lorg/apache/logging/log4j/core/config/LoggerConfig;
Signature: (Lorg/apache/logging/log4j/util/Supplier<Lorg/apache/logging/log4j/core/config/LoggerConfig;>;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
MethodParameters:
Name Flags
next final
private boolean beforeLogEvent();
descriptor: ()Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.counter:Ljava/util/concurrent/atomic/AtomicInteger;
invokevirtual java.util.concurrent.atomic.AtomicInteger.incrementAndGet:()I
ifle 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
public void afterLogEvent();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.counter:Ljava/util/concurrent/atomic/AtomicInteger;
invokevirtual java.util.concurrent.atomic.AtomicInteger.decrementAndGet:()I
ifne 2
aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdown:Ljava/util/concurrent/atomic/AtomicBoolean;
invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
ifeq 2
1: aload 0
invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.signalCompletionIfShutdown:()V
2: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
private void signalCompletionIfShutdown();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=3, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
astore 1
start local 1 1: aload 1
invokeinterface java.util.concurrent.locks.Lock.lock:()V
2: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.noLogEvents:Ljava/util/concurrent/locks/Condition;
invokeinterface java.util.concurrent.locks.Condition.signalAll:()V
3: goto 7
StackMap locals: org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy java.util.concurrent.locks.Lock
StackMap stack: java.lang.Throwable
4: astore 2
5: aload 1
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
6: aload 2
athrow
7: StackMap locals:
StackMap stack:
aload 1
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
8: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
1 9 1 lock Ljava/util/concurrent/locks/Lock;
Exception table:
from to target type
2 4 4 any
public void beforeStopAppenders();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.waitForCompletion:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
private void waitForCompletion();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=3, args_size=1
start local 0 0: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.lock:()V
1: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdown:Ljava/util/concurrent/atomic/AtomicBoolean;
iconst_0
iconst_1
invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
ifeq 17
2: iconst_0
istore 1
start local 1 3: goto 12
4: StackMap locals: int
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.counter:Ljava/util/concurrent/atomic/AtomicInteger;
invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
ifge 7
5: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
6: return
7: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.noLogEvents:Ljava/util/concurrent/locks/Condition;
iload 1
iconst_1
iadd
i2l
getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
invokeinterface java.util.concurrent.locks.Condition.await:(JLjava/util/concurrent/TimeUnit;)Z
pop
8: goto 12
StackMap locals:
StackMap stack: java.lang.InterruptedException
9: pop
10: iinc 1 1
iload 1
iconst_3
if_icmple 12
11: goto 17
12: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.counter:Ljava/util/concurrent/atomic/AtomicInteger;
iconst_0
ldc -2147483648
invokevirtual java.util.concurrent.atomic.AtomicInteger.compareAndSet:(II)Z
ifeq 4
end local 1 13: goto 17
StackMap locals: org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy
StackMap stack: java.lang.Throwable
14: astore 2
15: aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
16: aload 2
athrow
17: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
18: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
3 13 1 retries I
Exception table:
from to target type
7 8 9 Class java.lang.InterruptedException
1 5 14 any
7 14 14 any
public void beforeStopConfiguration(org.apache.logging.log4j.core.config.Configuration);
descriptor: (Lorg/apache/logging/log4j/core/config/Configuration;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=0, locals=2, args_size=2
start local 0 start local 1 0: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/apache/logging/log4j/core/config/AwaitCompletionReliabilityStrategy;
0 1 1 configuration Lorg/apache/logging/log4j/core/config/Configuration;
MethodParameters:
Name Flags
configuration final
}
SourceFile: "AwaitCompletionReliabilityStrategy.java"