public abstract class ch.qos.logback.core.sift.SiftingAppenderBase<E> extends ch.qos.logback.core.AppenderBase<E>
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: ch.qos.logback.core.sift.SiftingAppenderBase
  super_class: ch.qos.logback.core.AppenderBase
{
  protected ch.qos.logback.core.sift.AppenderTracker<E> appenderTracker;
    descriptor: Lch/qos/logback/core/sift/AppenderTracker;
    flags: (0x0004) ACC_PROTECTED
    Signature: Lch/qos/logback/core/sift/AppenderTracker<TE;>;

  ch.qos.logback.core.sift.AppenderFactory<E> appenderFactory;
    descriptor: Lch/qos/logback/core/sift/AppenderFactory;
    flags: (0x0000) 
    Signature: Lch/qos/logback/core/sift/AppenderFactory<TE;>;

  ch.qos.logback.core.util.Duration timeout;
    descriptor: Lch/qos/logback/core/util/Duration;
    flags: (0x0000) 

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

  ch.qos.logback.core.sift.Discriminator<E> discriminator;
    descriptor: Lch/qos/logback/core/sift/Discriminator;
    flags: (0x0000) 
    Signature: Lch/qos/logback/core/sift/Discriminator<TE;>;

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
         0: .line 30
            aload 0 /* this */
            invokespecial ch.qos.logback.core.AppenderBase.<init>:()V
         1: .line 34
            aload 0 /* this */
            new ch.qos.logback.core.util.Duration
            dup
            ldc 1800000
            invokespecial ch.qos.logback.core.util.Duration.<init>:(J)V
            putfield ch.qos.logback.core.sift.SiftingAppenderBase.timeout:Lch/qos/logback/core/util/Duration;
         2: .line 35
            aload 0 /* this */
            ldc 2147483647
            putfield ch.qos.logback.core.sift.SiftingAppenderBase.maxAppenderCount:I
         3: .line 30
            return
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;

  public ch.qos.logback.core.util.Duration getTimeout();
    descriptor: ()Lch/qos/logback/core/util/Duration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
         0: .line 40
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.timeout:Lch/qos/logback/core/util/Duration;
            areturn
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;

  public void setTimeout(ch.qos.logback.core.util.Duration);
    descriptor: (Lch/qos/logback/core/util/Duration;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
        start local 1 // ch.qos.logback.core.util.Duration timeout
         0: .line 44
            aload 0 /* this */
            aload 1 /* timeout */
            putfield ch.qos.logback.core.sift.SiftingAppenderBase.timeout:Lch/qos/logback/core/util/Duration;
         1: .line 45
            return
        end local 1 // ch.qos.logback.core.util.Duration timeout
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
            0    2     1  timeout  Lch/qos/logback/core/util/Duration;
    MethodParameters:
         Name  Flags
      timeout  

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

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

  public void setAppenderFactory(ch.qos.logback.core.sift.AppenderFactory<E>);
    descriptor: (Lch/qos/logback/core/sift/AppenderFactory;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
        start local 1 // ch.qos.logback.core.sift.AppenderFactory appenderFactory
         0: .line 60
            aload 0 /* this */
            aload 1 /* appenderFactory */
            putfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderFactory:Lch/qos/logback/core/sift/AppenderFactory;
         1: .line 61
            return
        end local 1 // ch.qos.logback.core.sift.AppenderFactory appenderFactory
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
            0    2     1  appenderFactory  Lch/qos/logback/core/sift/AppenderFactory<TE;>;
    Signature: (Lch/qos/logback/core/sift/AppenderFactory<TE;>;)V
    MethodParameters:
                 Name  Flags
      appenderFactory  

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
         0: .line 65
            iconst_0
            istore 1 /* errors */
        start local 1 // int errors
         1: .line 66
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.discriminator:Lch/qos/logback/core/sift/Discriminator;
            ifnonnull 4
         2: .line 67
            aload 0 /* this */
            ldc "Missing discriminator. Aborting"
            invokevirtual ch.qos.logback.core.sift.SiftingAppenderBase.addError:(Ljava/lang/String;)V
         3: .line 68
            iinc 1 /* errors */ 1
         4: .line 70
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.discriminator:Lch/qos/logback/core/sift/Discriminator;
            invokeinterface ch.qos.logback.core.sift.Discriminator.isStarted:()Z
            ifne 7
         5: .line 71
            aload 0 /* this */
            ldc "Discriminator has not started successfully. Aborting"
            invokevirtual ch.qos.logback.core.sift.SiftingAppenderBase.addError:(Ljava/lang/String;)V
         6: .line 72
            iinc 1 /* errors */ 1
         7: .line 74
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderFactory:Lch/qos/logback/core/sift/AppenderFactory;
            ifnonnull 11
         8: .line 75
            aload 0 /* this */
            ldc "AppenderFactory has not been set. Aborting"
            invokevirtual ch.qos.logback.core.sift.SiftingAppenderBase.addError:(Ljava/lang/String;)V
         9: .line 76
            iinc 1 /* errors */ 1
        10: .line 77
            goto 14
        11: .line 78
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new ch.qos.logback.core.sift.AppenderTracker
            dup
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.context:Lch/qos/logback/core/Context;
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderFactory:Lch/qos/logback/core/sift/AppenderFactory;
            invokespecial ch.qos.logback.core.sift.AppenderTracker.<init>:(Lch/qos/logback/core/Context;Lch/qos/logback/core/sift/AppenderFactory;)V
            putfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
        12: .line 79
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.maxAppenderCount:I
            invokevirtual ch.qos.logback.core.sift.AppenderTracker.setMaxComponents:(I)V
        13: .line 80
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.timeout:Lch/qos/logback/core/util/Duration;
            invokevirtual ch.qos.logback.core.util.Duration.getMilliseconds:()J
            invokevirtual ch.qos.logback.core.sift.AppenderTracker.setTimeout:(J)V
        14: .line 82
      StackMap locals:
      StackMap stack:
            iload 1 /* errors */
            ifne 16
        15: .line 83
            aload 0 /* this */
            invokespecial ch.qos.logback.core.AppenderBase.start:()V
        16: .line 85
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int errors
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   17     0    this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
            1   17     1  errors  I

  public void stop();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
         0: .line 89
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
            invokevirtual ch.qos.logback.core.sift.AppenderTracker.allComponents:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 3
      StackMap locals: ch.qos.logback.core.sift.SiftingAppenderBase top java.util.Iterator
      StackMap stack:
         1: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast ch.qos.logback.core.Appender
            astore 1 /* appender */
        start local 1 // ch.qos.logback.core.Appender appender
         2: .line 90
            aload 1 /* appender */
            invokeinterface ch.qos.logback.core.Appender.stop:()V
        end local 1 // ch.qos.logback.core.Appender appender
         3: .line 89
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 92
            return
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
            2    3     1  appender  Lch/qos/logback/core/Appender<TE;>;

  protected abstract long getTimestamp();
    descriptor: (Ljava/lang/Object;)J
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Signature: (TE;)J
    MethodParameters:
       Name  Flags
      event  

  protected void append();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
        start local 1 // java.lang.Object event
         0: .line 98
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.sift.SiftingAppenderBase.isStarted:()Z
            ifne 2
         1: .line 99
            return
         2: .line 101
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.discriminator:Lch/qos/logback/core/sift/Discriminator;
            aload 1 /* event */
            invokeinterface ch.qos.logback.core.sift.Discriminator.getDiscriminatingValue:(Ljava/lang/Object;)Ljava/lang/String;
            astore 2 /* discriminatingValue */
        start local 2 // java.lang.String discriminatingValue
         3: .line 102
            aload 0 /* this */
            aload 1 /* event */
            invokevirtual ch.qos.logback.core.sift.SiftingAppenderBase.getTimestamp:(Ljava/lang/Object;)J
            lstore 3 /* timestamp */
        start local 3 // long timestamp
         4: .line 104
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
            aload 2 /* discriminatingValue */
            lload 3 /* timestamp */
            invokevirtual ch.qos.logback.core.sift.AppenderTracker.getOrCreate:(Ljava/lang/String;J)Ljava/lang/Object;
            checkcast ch.qos.logback.core.Appender
            astore 5 /* appender */
        start local 5 // ch.qos.logback.core.Appender appender
         5: .line 106
            aload 0 /* this */
            aload 1 /* event */
            invokevirtual ch.qos.logback.core.sift.SiftingAppenderBase.eventMarksEndOfLife:(Ljava/lang/Object;)Z
            ifeq 7
         6: .line 107
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
            aload 2 /* discriminatingValue */
            invokevirtual ch.qos.logback.core.sift.AppenderTracker.endOfLife:(Ljava/lang/String;)V
         7: .line 109
      StackMap locals: java.lang.String long ch.qos.logback.core.Appender
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
            lload 3 /* timestamp */
            invokevirtual ch.qos.logback.core.sift.AppenderTracker.removeStaleComponents:(J)V
         8: .line 110
            aload 5 /* appender */
            aload 1 /* event */
            invokeinterface ch.qos.logback.core.Appender.doAppend:(Ljava/lang/Object;)V
         9: .line 111
            return
        end local 5 // ch.qos.logback.core.Appender appender
        end local 3 // long timestamp
        end local 2 // java.lang.String discriminatingValue
        end local 1 // java.lang.Object event
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   10     0                 this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
            0   10     1                event  TE;
            3   10     2  discriminatingValue  Ljava/lang/String;
            4   10     3            timestamp  J
            5   10     5             appender  Lch/qos/logback/core/Appender<TE;>;
    Signature: (TE;)V
    MethodParameters:
       Name  Flags
      event  

  protected abstract boolean eventMarksEndOfLife();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Signature: (TE;)Z
    MethodParameters:
       Name  Flags
      event  

  public ch.qos.logback.core.sift.Discriminator<E> getDiscriminator();
    descriptor: ()Lch/qos/logback/core/sift/Discriminator;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
         0: .line 116
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.discriminator:Lch/qos/logback/core/sift/Discriminator;
            areturn
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
    Signature: ()Lch/qos/logback/core/sift/Discriminator<TE;>;

  public void setDiscriminator(ch.qos.logback.core.sift.Discriminator<E>);
    descriptor: (Lch/qos/logback/core/sift/Discriminator;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
        start local 1 // ch.qos.logback.core.sift.Discriminator discriminator
         0: .line 120
            aload 0 /* this */
            aload 1 /* discriminator */
            putfield ch.qos.logback.core.sift.SiftingAppenderBase.discriminator:Lch/qos/logback/core/sift/Discriminator;
         1: .line 121
            return
        end local 1 // ch.qos.logback.core.sift.Discriminator discriminator
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    2     0           this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
            0    2     1  discriminator  Lch/qos/logback/core/sift/Discriminator<TE;>;
    Signature: (Lch/qos/logback/core/sift/Discriminator<TE;>;)V
    MethodParameters:
               Name  Flags
      discriminator  

  public ch.qos.logback.core.sift.AppenderTracker<E> getAppenderTracker();
    descriptor: ()Lch/qos/logback/core/sift/AppenderTracker;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
         0: .line 133
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.appenderTracker:Lch/qos/logback/core/sift/AppenderTracker;
            areturn
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
    Signature: ()Lch/qos/logback/core/sift/AppenderTracker<TE;>;

  public java.lang.String getDiscriminatorKey();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
         0: .line 137
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.discriminator:Lch/qos/logback/core/sift/Discriminator;
            ifnull 2
         1: .line 138
            aload 0 /* this */
            getfield ch.qos.logback.core.sift.SiftingAppenderBase.discriminator:Lch/qos/logback/core/sift/Discriminator;
            invokeinterface ch.qos.logback.core.sift.Discriminator.getKey:()Ljava/lang/String;
            areturn
         2: .line 140
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 0 // ch.qos.logback.core.sift.SiftingAppenderBase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lch/qos/logback/core/sift/SiftingAppenderBase<TE;>;
}
Signature: <E:Ljava/lang/Object;>Lch/qos/logback/core/AppenderBase<TE;>;
SourceFile: "SiftingAppenderBase.java"