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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.core.config.LoggerConfig loggerConfig
         0: .line 46
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 40
            aload 0 /* this */
            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: .line 41
            aload 0 /* this */
            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: .line 42
            aload 0 /* this */
            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: .line 43
            aload 0 /* this */
            aload 0 /* this */
            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: .line 47
            aload 0 /* this */
            aload 1 /* loggerConfig */
            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: .line 48
            return
        end local 1 // org.apache.logging.log4j.core.config.LoggerConfig loggerConfig
        end local 0 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy 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 61
            aload 0 /* this */
            aload 1 /* reconfigured */
            invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.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 63
            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 64
            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: .line 65
            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 66
            aload 9
            athrow
         6: .line 65
      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 67
            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.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.util.Supplier reconfigured
        start local 2 // org.apache.logging.log4j.core.LogEvent event
         0: .line 77
            aload 0 /* this */
            aload 1 /* reconfigured */
            invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.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 79
            aload 3 /* config */
            aload 2 /* event */
            invokevirtual org.apache.logging.log4j.core.config.LoggerConfig.log:(Lorg/apache/logging/log4j/core/LogEvent;)V
         2: .line 80
            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: .line 81
            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 82
            aload 4
            athrow
         6: .line 81
      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 83
            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.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.util.Supplier next
         0: .line 94
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.loggerConfig:Lorg/apache/logging/log4j/core/config/LoggerConfig;
            astore 2 /* result */
        start local 2 // org.apache.logging.log4j.core.config.LoggerConfig result
         1: .line 95
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.beforeLogEvent:()Z
            ifne 6
         2: .line 96
            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 97
            aload 2 /* result */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.loggerConfig:Lorg/apache/logging/log4j/core/config/LoggerConfig;
            if_acmpne 4
            aload 2 /* result */
            goto 5
      StackMap locals: org.apache.logging.log4j.core.config.LoggerConfig
      StackMap stack:
         4: 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;
      StackMap locals:
      StackMap stack: org.apache.logging.log4j.core.config.LoggerConfig
         5: areturn
         6: .line 99
      StackMap locals:
      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.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
         0: .line 103
            aload 0 /* this */
            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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
         0: .line 108
            aload 0 /* this */
            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 /* this */
            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: .line 109
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.signalCompletionIfShutdown:()V
         2: .line 111
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
         0: .line 114
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
            astore 1 /* lock */
        start local 1 // java.util.concurrent.locks.Lock lock
         1: .line 115
            aload 1 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         2: .line 117
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.noLogEvents:Ljava/util/concurrent/locks/Condition;
            invokeinterface java.util.concurrent.locks.Condition.signalAll:()V
         3: .line 118
            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: .line 119
            aload 1 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 120
            aload 2
            athrow
         7: .line 119
      StackMap locals:
      StackMap stack:
            aload 1 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         8: .line 121
            return
        end local 1 // java.util.concurrent.locks.Lock lock
        end local 0 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
         0: .line 130
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.waitForCompletion:()V
         1: .line 131
            return
        end local 0 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
         0: .line 137
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         1: .line 139
            aload 0 /* this */
            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: .line 140
            iconst_0
            istore 1 /* retries */
        start local 1 // int retries
         3: .line 142
            goto 12
         4: .line 145
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            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: .line 159
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
         6: .line 146
            return
         7: .line 150
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.noLogEvents:Ljava/util/concurrent/locks/Condition;
            iload 1 /* retries */
            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: .line 151
            goto 12
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         9: pop
        10: .line 152
            iinc 1 /* retries */ 1
            iload 1 /* retries */
            iconst_3
            if_icmple 12
        11: .line 153
            goto 17
        12: .line 142
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            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 // int retries
        13: .line 158
            goto 17
      StackMap locals: org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy
      StackMap stack: java.lang.Throwable
        14: astore 2
        15: .line 159
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        16: .line 160
            aload 2
            athrow
        17: .line 159
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy.shutdownLock:Ljava/util/concurrent/locks/Lock;
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        18: .line 161
            return
        end local 0 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
      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 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
        start local 1 // org.apache.logging.log4j.core.config.Configuration configuration
         0: .line 173
            return
        end local 1 // org.apache.logging.log4j.core.config.Configuration configuration
        end local 0 // org.apache.logging.log4j.core.config.AwaitCompletionReliabilityStrategy this
      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"