public class ch.qos.logback.core.AsyncAppenderBase<E> extends ch.qos.logback.core.UnsynchronizedAppenderBase<E> implements ch.qos.logback.core.spi.AppenderAttachable<E>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: ch.qos.logback.core.AsyncAppenderBase
  super_class: ch.qos.logback.core.UnsynchronizedAppenderBase
{
  ch.qos.logback.core.spi.AppenderAttachableImpl<E> aai;
    descriptor: Lch/qos/logback/core/spi/AppenderAttachableImpl;
    flags: (0x0000) 
    Signature: Lch/qos/logback/core/spi/AppenderAttachableImpl<TE;>;

  java.util.concurrent.BlockingQueue<E> blockingQueue;
    descriptor: Ljava/util/concurrent/BlockingQueue;
    flags: (0x0000) 
    Signature: Ljava/util/concurrent/BlockingQueue<TE;>;

  public static final int DEFAULT_QUEUE_SIZE;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 256

  int queueSize;
    descriptor: I
    flags: (0x0000) 

  int appenderCount;
    descriptor: I
    flags: (0x0000) 

  static final int UNDEFINED;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: -1

  int discardingThreshold;
    descriptor: I
    flags: (0x0000) 

  boolean neverBlock;
    descriptor: Z
    flags: (0x0000) 

  ch.qos.logback.core.AsyncAppenderBase<E>.Worker worker;
    descriptor: Lch/qos/logback/core/AsyncAppenderBase$Worker;
    flags: (0x0000) 
    Signature: Lch/qos/logback/core/AsyncAppenderBase<TE;>.Worker;

  public static final int DEFAULT_MAX_FLUSH_TIME;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 1000

  int maxFlushTime;
    descriptor: I
    flags: (0x0000) 

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 40
            aload 0 /* this */
            invokespecial ch.qos.logback.core.UnsynchronizedAppenderBase.<init>:()V
         1: .line 42
            aload 0 /* this */
            new ch.qos.logback.core.spi.AppenderAttachableImpl
            dup
            invokespecial ch.qos.logback.core.spi.AppenderAttachableImpl.<init>:()V
            putfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
         2: .line 49
            aload 0 /* this */
            sipush 256
            putfield ch.qos.logback.core.AsyncAppenderBase.queueSize:I
         3: .line 51
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AsyncAppenderBase.appenderCount:I
         4: .line 54
            aload 0 /* this */
            iconst_m1
            putfield ch.qos.logback.core.AsyncAppenderBase.discardingThreshold:I
         5: .line 55
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AsyncAppenderBase.neverBlock:Z
         6: .line 57
            aload 0 /* this */
            new ch.qos.logback.core.AsyncAppenderBase$Worker
            dup
            aload 0 /* this */
            invokespecial ch.qos.logback.core.AsyncAppenderBase$Worker.<init>:(Lch/qos/logback/core/AsyncAppenderBase;)V
            putfield ch.qos.logback.core.AsyncAppenderBase.worker:Lch/qos/logback/core/AsyncAppenderBase$Worker;
         7: .line 65
            aload 0 /* this */
            sipush 1000
            putfield ch.qos.logback.core.AsyncAppenderBase.maxFlushTime:I
         8: .line 40
            return
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  protected boolean isDiscardable();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // java.lang.Object eventObject
         0: .line 78
            iconst_0
            ireturn
        end local 1 // java.lang.Object eventObject
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    1     0         this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    1     1  eventObject  TE;
    Signature: (TE;)Z
    MethodParameters:
             Name  Flags
      eventObject  

  protected void preprocess();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=0, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // java.lang.Object eventObject
         0: .line 88
            return
        end local 1 // java.lang.Object eventObject
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    1     0         this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    1     1  eventObject  TE;
    Signature: (TE;)V
    MethodParameters:
             Name  Flags
      eventObject  

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 92
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.isStarted:()Z
            ifeq 2
         1: .line 93
            return
         2: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.appenderCount:I
            ifne 5
         3: .line 95
            aload 0 /* this */
            ldc "No attached appenders found."
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addError:(Ljava/lang/String;)V
         4: .line 96
            return
         5: .line 98
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.queueSize:I
            iconst_1
            if_icmpge 8
         6: .line 99
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Invalid queue size ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.queueSize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addError:(Ljava/lang/String;)V
         7: .line 100
            return
         8: .line 102
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.util.concurrent.ArrayBlockingQueue
            dup
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.queueSize:I
            invokespecial java.util.concurrent.ArrayBlockingQueue.<init>:(I)V
            putfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
         9: .line 104
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.discardingThreshold:I
            iconst_m1
            if_icmpne 11
        10: .line 105
            aload 0 /* this */
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.queueSize:I
            iconst_5
            idiv
            putfield ch.qos.logback.core.AsyncAppenderBase.discardingThreshold:I
        11: .line 106
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Setting discardingThreshold to "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.discardingThreshold:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addInfo:(Ljava/lang/String;)V
        12: .line 107
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.worker:Lch/qos/logback/core/AsyncAppenderBase$Worker;
            iconst_1
            invokevirtual ch.qos.logback.core.AsyncAppenderBase$Worker.setDaemon:(Z)V
        13: .line 108
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.worker:Lch/qos/logback/core/AsyncAppenderBase$Worker;
            new java.lang.StringBuilder
            dup
            ldc "AsyncAppender-Worker-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase$Worker.setName:(Ljava/lang/String;)V
        14: .line 110
            aload 0 /* this */
            invokespecial ch.qos.logback.core.UnsynchronizedAppenderBase.start:()V
        15: .line 111
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.worker:Lch/qos/logback/core/AsyncAppenderBase$Worker;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase$Worker.start:()V
        16: .line 112
            return
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   17     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public void stop();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 116
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.isStarted:()Z
            ifne 2
         1: .line 117
            return
         2: .line 122
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokespecial ch.qos.logback.core.UnsynchronizedAppenderBase.stop:()V
         3: .line 126
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.worker:Lch/qos/logback/core/AsyncAppenderBase$Worker;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase$Worker.interrupt:()V
         4: .line 128
            new ch.qos.logback.core.util.InterruptUtil
            dup
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.context:Lch/qos/logback/core/Context;
            invokespecial ch.qos.logback.core.util.InterruptUtil.<init>:(Lch/qos/logback/core/Context;)V
            astore 1 /* interruptUtil */
        start local 1 // ch.qos.logback.core.util.InterruptUtil interruptUtil
         5: .line 131
            aload 1 /* interruptUtil */
            invokevirtual ch.qos.logback.core.util.InterruptUtil.maskInterruptFlag:()V
         6: .line 133
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.worker:Lch/qos/logback/core/AsyncAppenderBase$Worker;
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.maxFlushTime:I
            i2l
            invokevirtual ch.qos.logback.core.AsyncAppenderBase$Worker.join:(J)V
         7: .line 136
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.worker:Lch/qos/logback/core/AsyncAppenderBase$Worker;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase$Worker.isAlive:()Z
            ifeq 12
         8: .line 137
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Max queue flush timeout ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.maxFlushTime:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " ms) exceeded. Approximately "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
            invokeinterface java.util.concurrent.BlockingQueue.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         9: .line 138
            ldc " queued events were possibly discarded."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 137
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addWarn:(Ljava/lang/String;)V
        11: .line 139
            goto 21
        12: .line 140
      StackMap locals: ch.qos.logback.core.util.InterruptUtil
      StackMap stack:
            aload 0 /* this */
            ldc "Queue flush finished successfully within timeout."
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addInfo:(Ljava/lang/String;)V
        13: .line 143
            goto 21
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
        14: astore 2 /* e */
        start local 2 // java.lang.InterruptedException e
        15: .line 144
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
            invokeinterface java.util.concurrent.BlockingQueue.size:()I
            istore 3 /* remaining */
        start local 3 // int remaining
        16: .line 145
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Failed to join worker thread. "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 3 /* remaining */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " queued events may be discarded."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* e */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addError:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 3 // int remaining
        end local 2 // java.lang.InterruptedException e
        17: .line 147
            aload 1 /* interruptUtil */
            invokevirtual ch.qos.logback.core.util.InterruptUtil.unmaskInterruptFlag:()V
            goto 22
        18: .line 146
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 4
        19: .line 147
            aload 1 /* interruptUtil */
            invokevirtual ch.qos.logback.core.util.InterruptUtil.unmaskInterruptFlag:()V
        20: .line 148
            aload 4
            athrow
        21: .line 147
      StackMap locals:
      StackMap stack:
            aload 1 /* interruptUtil */
            invokevirtual ch.qos.logback.core.util.InterruptUtil.unmaskInterruptFlag:()V
        22: .line 149
      StackMap locals:
      StackMap stack:
            return
        end local 1 // ch.qos.logback.core.util.InterruptUtil interruptUtil
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   23     0           this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            5   23     1  interruptUtil  Lch/qos/logback/core/util/InterruptUtil;
           15   17     2              e  Ljava/lang/InterruptedException;
           16   17     3      remaining  I
      Exception table:
        from    to  target  type
           5    13      14  Class java.lang.InterruptedException
           5    17      18  any

  protected void append();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // java.lang.Object eventObject
         0: .line 157
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.isQueueBelowDiscardingThreshold:()Z
            ifeq 2
            aload 0 /* this */
            aload 1 /* eventObject */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.isDiscardable:(Ljava/lang/Object;)Z
            ifeq 2
         1: .line 158
            return
         2: .line 160
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* eventObject */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.preprocess:(Ljava/lang/Object;)V
         3: .line 161
            aload 0 /* this */
            aload 1 /* eventObject */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.put:(Ljava/lang/Object;)V
         4: .line 162
            return
        end local 1 // java.lang.Object eventObject
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    5     1  eventObject  TE;
    Signature: (TE;)V
    MethodParameters:
             Name  Flags
      eventObject  

  private boolean isQueueBelowDiscardingThreshold();
    descriptor: ()Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 165
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
            invokeinterface java.util.concurrent.BlockingQueue.remainingCapacity:()I
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.discardingThreshold:I
            if_icmpge 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  private void put();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // java.lang.Object eventObject
         0: .line 169
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.neverBlock:Z
            ifeq 3
         1: .line 170
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
            aload 1 /* eventObject */
            invokeinterface java.util.concurrent.BlockingQueue.offer:(Ljava/lang/Object;)Z
            pop
         2: .line 171
            goto 4
         3: .line 172
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* eventObject */
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.putUninterruptibly:(Ljava/lang/Object;)V
         4: .line 174
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object eventObject
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    5     1  eventObject  TE;
    Signature: (TE;)V
    MethodParameters:
             Name  Flags
      eventObject  

  private void putUninterruptibly();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // java.lang.Object eventObject
         0: .line 177
            iconst_0
            istore 2 /* interrupted */
        start local 2 // boolean interrupted
         1: .line 181
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
            aload 1 /* eventObject */
            invokeinterface java.util.concurrent.BlockingQueue.put:(Ljava/lang/Object;)V
         2: .line 182
            goto 10
         3: .line 183
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
            pop
         4: .line 184
            iconst_1
            istore 2 /* interrupted */
         5: .line 179
            goto 1
         6: .line 187
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 3
         7: .line 188
            iload 2 /* interrupted */
            ifeq 9
         8: .line 189
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
         9: .line 191
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3
            athrow
        10: .line 188
      StackMap locals:
      StackMap stack:
            iload 2 /* interrupted */
            ifeq 12
        11: .line 189
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        12: .line 192
      StackMap locals:
      StackMap stack:
            return
        end local 2 // boolean interrupted
        end local 1 // java.lang.Object eventObject
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   13     0         this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0   13     1  eventObject  TE;
            1   13     2  interrupted  Z
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.InterruptedException
           1     6       6  any
    Signature: (TE;)V
    MethodParameters:
             Name  Flags
      eventObject  

  public int getQueueSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 195
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.queueSize:I
            ireturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public void setQueueSize(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // int queueSize
         0: .line 199
            aload 0 /* this */
            iload 1 /* queueSize */
            putfield ch.qos.logback.core.AsyncAppenderBase.queueSize:I
         1: .line 200
            return
        end local 1 // int queueSize
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    2     1  queueSize  I
    MethodParameters:
           Name  Flags
      queueSize  

  public int getDiscardingThreshold();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 203
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.discardingThreshold:I
            ireturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public void setDiscardingThreshold(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // int discardingThreshold
         0: .line 207
            aload 0 /* this */
            iload 1 /* discardingThreshold */
            putfield ch.qos.logback.core.AsyncAppenderBase.discardingThreshold:I
         1: .line 208
            return
        end local 1 // int discardingThreshold
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    2     0                 this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    2     1  discardingThreshold  I
    MethodParameters:
                     Name  Flags
      discardingThreshold  

  public int getMaxFlushTime();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 211
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.maxFlushTime:I
            ireturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public void setMaxFlushTime(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // int maxFlushTime
         0: .line 215
            aload 0 /* this */
            iload 1 /* maxFlushTime */
            putfield ch.qos.logback.core.AsyncAppenderBase.maxFlushTime:I
         1: .line 216
            return
        end local 1 // int maxFlushTime
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    2     0          this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    2     1  maxFlushTime  I
    MethodParameters:
              Name  Flags
      maxFlushTime  

  public int getNumberOfElementsInQueue();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 224
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
            invokeinterface java.util.concurrent.BlockingQueue.size:()I
            ireturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public void setNeverBlock(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // boolean neverBlock
         0: .line 228
            aload 0 /* this */
            iload 1 /* neverBlock */
            putfield ch.qos.logback.core.AsyncAppenderBase.neverBlock:Z
         1: .line 229
            return
        end local 1 // boolean neverBlock
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    2     1  neverBlock  Z
    MethodParameters:
            Name  Flags
      neverBlock  

  public boolean isNeverBlock();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 232
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.neverBlock:Z
            ireturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public int getRemainingCapacity();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 242
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.blockingQueue:Ljava/util/concurrent/BlockingQueue;
            invokeinterface java.util.concurrent.BlockingQueue.remainingCapacity:()I
            ireturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public void addAppender(ch.qos.logback.core.Appender<E>);
    descriptor: (Lch/qos/logback/core/Appender;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // ch.qos.logback.core.Appender newAppender
         0: .line 246
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.appenderCount:I
            ifne 5
         1: .line 247
            aload 0 /* this */
            dup
            getfield ch.qos.logback.core.AsyncAppenderBase.appenderCount:I
            iconst_1
            iadd
            putfield ch.qos.logback.core.AsyncAppenderBase.appenderCount:I
         2: .line 248
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Attaching appender named ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* newAppender */
            invokeinterface ch.qos.logback.core.Appender.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "] to AsyncAppender."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addInfo:(Ljava/lang/String;)V
         3: .line 249
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
            aload 1 /* newAppender */
            invokevirtual ch.qos.logback.core.spi.AppenderAttachableImpl.addAppender:(Lch/qos/logback/core/Appender;)V
         4: .line 250
            goto 7
         5: .line 251
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "One and only one appender may be attached to AsyncAppender."
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addWarn:(Ljava/lang/String;)V
         6: .line 252
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Ignoring additional appender named ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* newAppender */
            invokeinterface ch.qos.logback.core.Appender.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual ch.qos.logback.core.AsyncAppenderBase.addWarn:(Ljava/lang/String;)V
         7: .line 254
      StackMap locals:
      StackMap stack:
            return
        end local 1 // ch.qos.logback.core.Appender newAppender
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0         this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    8     1  newAppender  Lch/qos/logback/core/Appender<TE;>;
    Signature: (Lch/qos/logback/core/Appender<TE;>;)V
    MethodParameters:
             Name  Flags
      newAppender  

  public java.util.Iterator<ch.qos.logback.core.Appender<E>> iteratorForAppenders();
    descriptor: ()Ljava/util/Iterator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 257
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
            invokevirtual ch.qos.logback.core.spi.AppenderAttachableImpl.iteratorForAppenders:()Ljava/util/Iterator;
            areturn
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
    Signature: ()Ljava/util/Iterator<Lch/qos/logback/core/Appender<TE;>;>;

  public ch.qos.logback.core.Appender<E> getAppender(java.lang.String);
    descriptor: (Ljava/lang/String;)Lch/qos/logback/core/Appender;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // java.lang.String name
         0: .line 261
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
            aload 1 /* name */
            invokevirtual ch.qos.logback.core.spi.AppenderAttachableImpl.getAppender:(Ljava/lang/String;)Lch/qos/logback/core/Appender;
            areturn
        end local 1 // java.lang.String name
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    1     1  name  Ljava/lang/String;
    Signature: (Ljava/lang/String;)Lch/qos/logback/core/Appender<TE;>;
    MethodParameters:
      Name  Flags
      name  

  public boolean isAttached(ch.qos.logback.core.Appender<E>);
    descriptor: (Lch/qos/logback/core/Appender;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // ch.qos.logback.core.Appender eAppender
         0: .line 265
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
            aload 1 /* eAppender */
            invokevirtual ch.qos.logback.core.spi.AppenderAttachableImpl.isAttached:(Lch/qos/logback/core/Appender;)Z
            ireturn
        end local 1 // ch.qos.logback.core.Appender eAppender
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    1     1  eAppender  Lch/qos/logback/core/Appender<TE;>;
    Signature: (Lch/qos/logback/core/Appender<TE;>;)Z
    MethodParameters:
           Name  Flags
      eAppender  

  public void detachAndStopAllAppenders();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
         0: .line 269
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
            invokevirtual ch.qos.logback.core.spi.AppenderAttachableImpl.detachAndStopAllAppenders:()V
         1: .line 270
            return
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;

  public boolean detachAppender(ch.qos.logback.core.Appender<E>);
    descriptor: (Lch/qos/logback/core/Appender;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // ch.qos.logback.core.Appender eAppender
         0: .line 273
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
            aload 1 /* eAppender */
            invokevirtual ch.qos.logback.core.spi.AppenderAttachableImpl.detachAppender:(Lch/qos/logback/core/Appender;)Z
            ireturn
        end local 1 // ch.qos.logback.core.Appender eAppender
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    1     1  eAppender  Lch/qos/logback/core/Appender<TE;>;
    Signature: (Lch/qos/logback/core/Appender<TE;>;)Z
    MethodParameters:
           Name  Flags
      eAppender  

  public boolean detachAppender(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AsyncAppenderBase this
        start local 1 // java.lang.String name
         0: .line 277
            aload 0 /* this */
            getfield ch.qos.logback.core.AsyncAppenderBase.aai:Lch/qos/logback/core/spi/AppenderAttachableImpl;
            aload 1 /* name */
            invokevirtual ch.qos.logback.core.spi.AppenderAttachableImpl.detachAppender:(Ljava/lang/String;)Z
            ireturn
        end local 1 // java.lang.String name
        end local 0 // ch.qos.logback.core.AsyncAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AsyncAppenderBase<TE;>;
            0    1     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  
}
Signature: <E:Ljava/lang/Object;>Lch/qos/logback/core/UnsynchronizedAppenderBase<TE;>;Lch/qos/logback/core/spi/AppenderAttachable<TE;>;
SourceFile: "AsyncAppenderBase.java"
NestMembers:
  ch.qos.logback.core.AsyncAppenderBase$Worker
InnerClasses:
  Worker = ch.qos.logback.core.AsyncAppenderBase$Worker of ch.qos.logback.core.AsyncAppenderBase