public abstract class ch.qos.logback.core.AppenderBase<E> extends ch.qos.logback.core.spi.ContextAwareBase implements ch.qos.logback.core.Appender<E>
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: ch.qos.logback.core.AppenderBase
  super_class: ch.qos.logback.core.spi.ContextAwareBase
{
  protected volatile boolean started;
    descriptor: Z
    flags: (0x0044) ACC_PROTECTED, ACC_VOLATILE

  private boolean guard;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  protected java.lang.String name;
    descriptor: Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED

  private ch.qos.logback.core.spi.FilterAttachableImpl<E> fai;
    descriptor: Lch/qos/logback/core/spi/FilterAttachableImpl;
    flags: (0x0002) ACC_PRIVATE
    Signature: Lch/qos/logback/core/spi/FilterAttachableImpl<TE;>;

  private int statusRepeatCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int exceptionCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  static final int ALLOWED_REPEATS;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 5

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AppenderBase this
         0: .line 32
            aload 0 /* this */
            invokespecial ch.qos.logback.core.spi.ContextAwareBase.<init>:()V
         1: .line 34
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.started:Z
         2: .line 40
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.guard:Z
         3: .line 47
            aload 0 /* this */
            new ch.qos.logback.core.spi.FilterAttachableImpl
            dup
            invokespecial ch.qos.logback.core.spi.FilterAttachableImpl.<init>:()V
            putfield ch.qos.logback.core.AppenderBase.fai:Lch/qos/logback/core/spi/FilterAttachableImpl;
         4: .line 53
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.statusRepeatCount:I
         5: .line 54
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.exceptionCount:I
         6: .line 32
            return
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lch/qos/logback/core/AppenderBase<TE;>;

  public java.lang.String getName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AppenderBase this
         0: .line 50
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.name:Ljava/lang/String;
            areturn
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AppenderBase<TE;>;

  public synchronized void doAppend();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=4, args_size=2
        start local 0 // ch.qos.logback.core.AppenderBase this
        start local 1 // java.lang.Object eventObject
         0: .line 63
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.guard:Z
            ifeq 2
         1: .line 64
            return
         2: .line 68
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield ch.qos.logback.core.AppenderBase.guard:Z
         3: .line 70
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.started:Z
            ifne 8
         4: .line 71
            aload 0 /* this */
            dup
            getfield ch.qos.logback.core.AppenderBase.statusRepeatCount:I
            dup_x1
            iconst_1
            iadd
            putfield ch.qos.logback.core.AppenderBase.statusRepeatCount:I
            iconst_5
            if_icmpge 6
         5: .line 72
            aload 0 /* this */
            new ch.qos.logback.core.status.WarnStatus
            dup
            new java.lang.StringBuilder
            dup
            ldc "Attempted to append to non started appender ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.name: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;
            aload 0 /* this */
            invokespecial ch.qos.logback.core.status.WarnStatus.<init>:(Ljava/lang/String;Ljava/lang/Object;)V
            invokevirtual ch.qos.logback.core.AppenderBase.addStatus:(Lch/qos/logback/core/status/Status;)V
         6: .line 89
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.guard:Z
         7: .line 74
            return
         8: .line 77
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* eventObject */
            invokevirtual ch.qos.logback.core.AppenderBase.getFilterChainDecision:(Ljava/lang/Object;)Lch/qos/logback/core/spi/FilterReply;
            getstatic ch.qos.logback.core.spi.FilterReply.DENY:Lch/qos/logback/core/spi/FilterReply;
            if_acmpne 11
         9: .line 89
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.guard:Z
        10: .line 78
            return
        11: .line 82
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* eventObject */
            invokevirtual ch.qos.logback.core.AppenderBase.append:(Ljava/lang/Object;)V
        12: .line 84
            goto 20
      StackMap locals:
      StackMap stack: java.lang.Exception
        13: astore 2 /* e */
        start local 2 // java.lang.Exception e
        14: .line 85
            aload 0 /* this */
            dup
            getfield ch.qos.logback.core.AppenderBase.exceptionCount:I
            dup_x1
            iconst_1
            iadd
            putfield ch.qos.logback.core.AppenderBase.exceptionCount:I
            iconst_5
            if_icmpge 16
        15: .line 86
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "Appender ["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "] failed to append."
            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.AppenderBase.addError:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 2 // java.lang.Exception e
        16: .line 89
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.guard:Z
            goto 21
        17: .line 88
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 3
        18: .line 89
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.guard:Z
        19: .line 90
            aload 3
            athrow
        20: .line 89
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.guard:Z
        21: .line 91
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object eventObject
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   22     0         this  Lch/qos/logback/core/AppenderBase<TE;>;
            0   22     1  eventObject  TE;
           14   16     2            e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     6      13  Class java.lang.Exception
           8     9      13  Class java.lang.Exception
          11    12      13  Class java.lang.Exception
           2     6      17  any
           8     9      17  any
          11    16      17  any
    Signature: (TE;)V
    MethodParameters:
             Name  Flags
      eventObject  

  protected abstract void append();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Signature: (TE;)V
    MethodParameters:
             Name  Flags
      eventObject  

  public void setName(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AppenderBase this
        start local 1 // java.lang.String name
         0: .line 99
            aload 0 /* this */
            aload 1 /* name */
            putfield ch.qos.logback.core.AppenderBase.name:Ljava/lang/String;
         1: .line 100
            return
        end local 1 // java.lang.String name
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/AppenderBase<TE;>;
            0    2     1  name  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      name  

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AppenderBase this
         0: .line 103
            aload 0 /* this */
            iconst_1
            putfield ch.qos.logback.core.AppenderBase.started:Z
         1: .line 104
            return
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/AppenderBase<TE;>;

  public void stop();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AppenderBase this
         0: .line 107
            aload 0 /* this */
            iconst_0
            putfield ch.qos.logback.core.AppenderBase.started:Z
         1: .line 108
            return
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/AppenderBase<TE;>;

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

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AppenderBase this
         0: .line 115
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "["
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.name: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;
            areturn
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AppenderBase<TE;>;

  public void addFilter(ch.qos.logback.core.filter.Filter<E>);
    descriptor: (Lch/qos/logback/core/filter/Filter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AppenderBase this
        start local 1 // ch.qos.logback.core.filter.Filter newFilter
         0: .line 119
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.fai:Lch/qos/logback/core/spi/FilterAttachableImpl;
            aload 1 /* newFilter */
            invokevirtual ch.qos.logback.core.spi.FilterAttachableImpl.addFilter:(Lch/qos/logback/core/filter/Filter;)V
         1: .line 120
            return
        end local 1 // ch.qos.logback.core.filter.Filter newFilter
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lch/qos/logback/core/AppenderBase<TE;>;
            0    2     1  newFilter  Lch/qos/logback/core/filter/Filter<TE;>;
    Signature: (Lch/qos/logback/core/filter/Filter<TE;>;)V
    MethodParameters:
           Name  Flags
      newFilter  

  public void clearAllFilters();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AppenderBase this
         0: .line 123
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.fai:Lch/qos/logback/core/spi/FilterAttachableImpl;
            invokevirtual ch.qos.logback.core.spi.FilterAttachableImpl.clearAllFilters:()V
         1: .line 124
            return
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/AppenderBase<TE;>;

  public java.util.List<ch.qos.logback.core.filter.Filter<E>> getCopyOfAttachedFiltersList();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.AppenderBase this
         0: .line 127
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.fai:Lch/qos/logback/core/spi/FilterAttachableImpl;
            invokevirtual ch.qos.logback.core.spi.FilterAttachableImpl.getCopyOfAttachedFiltersList:()Ljava/util/List;
            areturn
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/AppenderBase<TE;>;
    Signature: ()Ljava/util/List<Lch/qos/logback/core/filter/Filter<TE;>;>;

  public ch.qos.logback.core.spi.FilterReply getFilterChainDecision(E);
    descriptor: (Ljava/lang/Object;)Lch/qos/logback/core/spi/FilterReply;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.AppenderBase this
        start local 1 // java.lang.Object event
         0: .line 131
            aload 0 /* this */
            getfield ch.qos.logback.core.AppenderBase.fai:Lch/qos/logback/core/spi/FilterAttachableImpl;
            aload 1 /* event */
            invokevirtual ch.qos.logback.core.spi.FilterAttachableImpl.getFilterChainDecision:(Ljava/lang/Object;)Lch/qos/logback/core/spi/FilterReply;
            areturn
        end local 1 // java.lang.Object event
        end local 0 // ch.qos.logback.core.AppenderBase this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lch/qos/logback/core/AppenderBase<TE;>;
            0    1     1  event  TE;
    Signature: (TE;)Lch/qos/logback/core/spi/FilterReply;
    MethodParameters:
       Name  Flags
      event  
}
Signature: <E:Ljava/lang/Object;>Lch/qos/logback/core/spi/ContextAwareBase;Lch/qos/logback/core/Appender<TE;>;
SourceFile: "AppenderBase.java"