public class org.apache.logging.log4j.core.config.LockingReliabilityStrategy 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.LockingReliabilityStrategy
  super_class: java.lang.Object
{
  private final org.apache.logging.log4j.core.config.LoggerConfig loggerConfig;
    descriptor: Lorg/apache/logging/log4j/core/config/LoggerConfig;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.ReadWriteLock reconfigureLock;
    descriptor: Ljava/util/concurrent/locks/ReadWriteLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile boolean isStopping;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  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=3, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.core.config.LoggerConfig loggerConfig
         0: .line 38
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 35
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantReadWriteLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
            putfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.reconfigureLock:Ljava/util/concurrent/locks/ReadWriteLock;
         2: .line 36
            aload 0 /* this */
            iconst_0
            putfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.isStopping:Z
         3: .line 39
            aload 0 /* this */
            aload 1 /* loggerConfig */
            ldc "loggerConfig was 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.LockingReliabilityStrategy.loggerConfig:Lorg/apache/logging/log4j/core/config/LoggerConfig;
         4: .line 40
            return
        end local 1 // org.apache.logging.log4j.core.config.LoggerConfig loggerConfig
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    5     0          this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;
            0    5     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 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.util.Supplier reconfigured
        start local 2 // java.lang.String loggerName
        start local 3 // java.lang.String fqcn
        start local 4 // org.apache.logging.log4j.Marker marker
        start local 5 // org.apache.logging.log4j.Level level
        start local 6 // org.apache.logging.log4j.message.Message data
        start local 7 // java.lang.Throwable t
         0: .line 53
            aload 0 /* this */
            aload 1 /* reconfigured */
            invokevirtual org.apache.logging.log4j.core.config.LockingReliabilityStrategy.getActiveLoggerConfig:(Lorg/apache/logging/log4j/util/Supplier;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
            astore 8 /* config */
        start local 8 // org.apache.logging.log4j.core.config.LoggerConfig config
         1: .line 55
            aload 8 /* config */
            aload 2 /* loggerName */
            aload 3 /* fqcn */
            aload 4 /* marker */
            aload 5 /* level */
            aload 6 /* data */
            aload 7 /* t */
            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: .line 56
            goto 6
      StackMap locals: org.apache.logging.log4j.core.config.LockingReliabilityStrategy 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: .line 57
            aload 8 /* config */
            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: .line 58
            aload 9
            athrow
         6: .line 57
      StackMap locals:
      StackMap stack:
            aload 8 /* config */
            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: .line 59
            return
        end local 8 // org.apache.logging.log4j.core.config.LoggerConfig config
        end local 7 // java.lang.Throwable t
        end local 6 // org.apache.logging.log4j.message.Message data
        end local 5 // org.apache.logging.log4j.Level level
        end local 4 // org.apache.logging.log4j.Marker marker
        end local 3 // java.lang.String fqcn
        end local 2 // java.lang.String loggerName
        end local 1 // org.apache.logging.log4j.util.Supplier reconfigured
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    8     0          this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;
            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 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.util.Supplier reconfigured
        start local 2 // org.apache.logging.log4j.core.LogEvent event
         0: .line 69
            aload 0 /* this */
            aload 1 /* reconfigured */
            invokevirtual org.apache.logging.log4j.core.config.LockingReliabilityStrategy.getActiveLoggerConfig:(Lorg/apache/logging/log4j/util/Supplier;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
            astore 3 /* config */
        start local 3 // org.apache.logging.log4j.core.config.LoggerConfig config
         1: .line 71
            aload 3 /* config */
            aload 2 /* event */
            invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.log:(Lorg/apache/logging/log4j/core/LogEvent;)V
         2: .line 72
            goto 6
      StackMap locals: org.apache.logging.log4j.core.config.LockingReliabilityStrategy 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: .line 73
            aload 3 /* config */
            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: .line 74
            aload 4
            athrow
         6: .line 73
      StackMap locals:
      StackMap stack:
            aload 3 /* config */
            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: .line 75
            return
        end local 3 // org.apache.logging.log4j.core.config.LoggerConfig config
        end local 2 // org.apache.logging.log4j.core.LogEvent event
        end local 1 // org.apache.logging.log4j.util.Supplier reconfigured
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    8     0          this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;
            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 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.util.Supplier next
         0: .line 86
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.loggerConfig:Lorg/apache/logging/log4j/core/config/LoggerConfig;
            astore 2 /* result */
        start local 2 // org.apache.logging.log4j.core.config.LoggerConfig result
         1: .line 87
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.config.LockingReliabilityStrategy.beforeLogEvent:()Z
            ifne 4
         2: .line 88
            aload 1 /* next */
            invokeinterface org.apache.logging.log4j.util.Supplier.get:()Ljava/lang/Object;
            checkcast org.apache.logging.log4j.core.config.LoggerConfig
            astore 2 /* result */
         3: .line 89
            aload 2 /* result */
            invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.getReliabilityStrategy:()Lorg/apache/logging/log4j/core/config/ReliabilityStrategy;
            aload 1 /* next */
            invokeinterface org.apache.logging.log4j.core.config.ReliabilityStrategy.getActiveLoggerConfig:(Lorg/apache/logging/log4j/util/Supplier;)Lorg/apache/logging/log4j/core/config/LoggerConfig;
            areturn
         4: .line 91
      StackMap locals: org.apache.logging.log4j.core.config.LoggerConfig
      StackMap stack:
            aload 2 /* result */
            areturn
        end local 2 // org.apache.logging.log4j.core.config.LoggerConfig result
        end local 1 // org.apache.logging.log4j.util.Supplier next
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;
            0    5     1    next  Lorg/apache/logging/log4j/util/Supplier<Lorg/apache/logging/log4j/core/config/LoggerConfig;>;
            1    5     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 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
         0: .line 95
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.reconfigureLock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 96
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.isStopping:Z
            ifeq 4
         2: .line 97
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.reconfigureLock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         3: .line 98
            iconst_0
            ireturn
         4: .line 100
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;

  public void afterLogEvent();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
         0: .line 105
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.reconfigureLock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.readLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         1: .line 106
            return
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;

  public void beforeStopAppenders();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
         0: .line 115
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.reconfigureLock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 117
            aload 0 /* this */
            iconst_1
            putfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.isStopping:Z
         2: .line 118
            goto 6
      StackMap locals:
      StackMap stack: java.lang.Throwable
         3: astore 1
         4: .line 119
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.reconfigureLock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         5: .line 120
            aload 1
            athrow
         6: .line 119
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.LockingReliabilityStrategy.reconfigureLock:Ljava/util/concurrent/locks/ReadWriteLock;
            invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         7: .line 121
            return
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;
      Exception table:
        from    to  target  type
           1     3       3  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 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.core.config.Configuration configuration
         0: .line 133
            return
        end local 1 // org.apache.logging.log4j.core.config.Configuration configuration
        end local 0 // org.apache.logging.log4j.core.config.LockingReliabilityStrategy this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    1     0           this  Lorg/apache/logging/log4j/core/config/LockingReliabilityStrategy;
            0    1     1  configuration  Lorg/apache/logging/log4j/core/config/Configuration;
    MethodParameters:
               Name  Flags
      configuration  final
}
SourceFile: "LockingReliabilityStrategy.java"