public abstract class ch.qos.logback.core.spi.AbstractComponentTracker<C> implements ch.qos.logback.core.spi.ComponentTracker<C>
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: ch.qos.logback.core.spi.AbstractComponentTracker
  super_class: java.lang.Object
{
  private static final boolean ACCESS_ORDERED;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  public static final long LINGERING_TIMEOUT;
    descriptor: J
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 10000

  public static final long WAIT_BETWEEN_SUCCESSIVE_REMOVAL_ITERATIONS;
    descriptor: J
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 1000

  protected int maxComponents;
    descriptor: I
    flags: (0x0004) ACC_PROTECTED

  protected long timeout;
    descriptor: J
    flags: (0x0004) ACC_PROTECTED

  java.util.LinkedHashMap<java.lang.String, ch.qos.logback.core.spi.AbstractComponentTracker$Entry<C>> liveMap;
    descriptor: Ljava/util/LinkedHashMap;
    flags: (0x0000) 
    Signature: Ljava/util/LinkedHashMap<Ljava/lang/String;Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;>;

  java.util.LinkedHashMap<java.lang.String, ch.qos.logback.core.spi.AbstractComponentTracker$Entry<C>> lingerersMap;
    descriptor: Ljava/util/LinkedHashMap;
    flags: (0x0000) 
    Signature: Ljava/util/LinkedHashMap<Ljava/lang/String;Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;>;

  long lastCheck;
    descriptor: J
    flags: (0x0000) 

  private ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator<C> byExcedent;
    descriptor: Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
    flags: (0x0002) ACC_PRIVATE
    Signature: Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator<TC;>;

  private ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator<C> byTimeout;
    descriptor: Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
    flags: (0x0002) ACC_PRIVATE
    Signature: Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator<TC;>;

  private ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator<C> byLingering;
    descriptor: Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
    flags: (0x0002) ACC_PRIVATE
    Signature: Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator<TC;>;

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
         0: .line 31
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 42
            aload 0 /* this */
            ldc 2147483647
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.maxComponents:I
         2: .line 43
            aload 0 /* this */
            ldc 1800000
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.timeout:J
         3: .line 46
            aload 0 /* this */
            new java.util.LinkedHashMap
            dup
            bipush 32
            ldc 0.75
            iconst_1
            invokespecial java.util.LinkedHashMap.<init>:(IFZ)V
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
         4: .line 49
            aload 0 /* this */
            new java.util.LinkedHashMap
            dup
            bipush 16
            ldc 0.75
            iconst_1
            invokespecial java.util.LinkedHashMap.<init>:(IFZ)V
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.lingerersMap:Ljava/util/LinkedHashMap;
         5: .line 50
            aload 0 /* this */
            lconst_0
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.lastCheck:J
         6: .line 187
            aload 0 /* this */
            new ch.qos.logback.core.spi.AbstractComponentTracker$1
            dup
            aload 0 /* this */
            invokespecial ch.qos.logback.core.spi.AbstractComponentTracker$1.<init>:(Lch/qos/logback/core/spi/AbstractComponentTracker;)V
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.byExcedent:Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
         7: .line 193
            aload 0 /* this */
            new ch.qos.logback.core.spi.AbstractComponentTracker$2
            dup
            aload 0 /* this */
            invokespecial ch.qos.logback.core.spi.AbstractComponentTracker$2.<init>:(Lch/qos/logback/core/spi/AbstractComponentTracker;)V
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.byTimeout:Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
         8: .line 198
            aload 0 /* this */
            new ch.qos.logback.core.spi.AbstractComponentTracker$3
            dup
            aload 0 /* this */
            invokespecial ch.qos.logback.core.spi.AbstractComponentTracker$3.<init>:(Lch/qos/logback/core/spi/AbstractComponentTracker;)V
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.byLingering:Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
         9: .line 31
            return
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;

  protected abstract void processPriorToRemoval();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Signature: (TC;)V
    MethodParameters:
           Name  Flags
      component  

  protected abstract C buildComponent(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/Object;
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Signature: (Ljava/lang/String;)TC;
    MethodParameters:
      Name  Flags
      key   

  protected abstract boolean isComponentStale();
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
    Signature: (TC;)Z
    MethodParameters:
      Name  Flags
      c     

  public int getComponentCount();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
         0: .line 77
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.size:()I
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.lingerersMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.size:()I
            iadd
            ireturn
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;

  private ch.qos.logback.core.spi.AbstractComponentTracker$Entry<C> getFromEitherMap(java.lang.String);
    descriptor: (Ljava/lang/String;)Lch/qos/logback/core/spi/AbstractComponentTracker$Entry;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // java.lang.String key
         0: .line 87
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            aload 1 /* key */
            invokevirtual java.util.LinkedHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast ch.qos.logback.core.spi.AbstractComponentTracker$Entry
            astore 2 /* entry */
        start local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
         1: .line 88
            aload 2 /* entry */
            ifnull 3
         2: .line 89
            aload 2 /* entry */
            areturn
         3: .line 91
      StackMap locals: ch.qos.logback.core.spi.AbstractComponentTracker$Entry
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.lingerersMap:Ljava/util/LinkedHashMap;
            aload 1 /* key */
            invokevirtual java.util.LinkedHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast ch.qos.logback.core.spi.AbstractComponentTracker$Entry
            areturn
        end local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        end local 1 // java.lang.String key
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    4     1    key  Ljava/lang/String;
            1    4     2  entry  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
    Signature: (Ljava/lang/String;)Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
    MethodParameters:
      Name  Flags
      key   

  public synchronized C find(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/Object;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // java.lang.String key
         0: .line 105
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.getFromEitherMap:(Ljava/lang/String;)Lch/qos/logback/core/spi/AbstractComponentTracker$Entry;
            astore 2 /* entry */
        start local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
         1: .line 106
            aload 2 /* entry */
            ifnonnull 3
         2: .line 107
            aconst_null
            areturn
         3: .line 109
      StackMap locals: ch.qos.logback.core.spi.AbstractComponentTracker$Entry
      StackMap stack:
            aload 2 /* entry */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.component:Ljava/lang/Object;
            areturn
        end local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        end local 1 // java.lang.String key
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    4     1    key  Ljava/lang/String;
            1    4     2  entry  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
    Signature: (Ljava/lang/String;)TC;
    MethodParameters:
      Name  Flags
      key   

  public synchronized C getOrCreate(java.lang.String, );
    descriptor: (Ljava/lang/String;J)Ljava/lang/Object;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=6, args_size=3
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // java.lang.String key
        start local 2 // long timestamp
         0: .line 122
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.getFromEitherMap:(Ljava/lang/String;)Lch/qos/logback/core/spi/AbstractComponentTracker$Entry;
            astore 4 /* entry */
        start local 4 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
         1: .line 123
            aload 4 /* entry */
            ifnonnull 6
         2: .line 124
            aload 0 /* this */
            aload 1 /* key */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.buildComponent:(Ljava/lang/String;)Ljava/lang/Object;
            astore 5 /* c */
        start local 5 // java.lang.Object c
         3: .line 125
            new ch.qos.logback.core.spi.AbstractComponentTracker$Entry
            dup
            aload 1 /* key */
            aload 5 /* c */
            lload 2 /* timestamp */
            invokespecial ch.qos.logback.core.spi.AbstractComponentTracker$Entry.<init>:(Ljava/lang/String;Ljava/lang/Object;J)V
            astore 4 /* entry */
         4: .line 127
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            aload 1 /* key */
            aload 4 /* entry */
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // java.lang.Object c
         5: .line 128
            goto 7
         6: .line 129
      StackMap locals: ch.qos.logback.core.spi.AbstractComponentTracker$Entry
      StackMap stack:
            aload 4 /* entry */
            lload 2 /* timestamp */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker$Entry.setTimestamp:(J)V
         7: .line 131
      StackMap locals:
      StackMap stack:
            aload 4 /* entry */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.component:Ljava/lang/Object;
            areturn
        end local 4 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        end local 2 // long timestamp
        end local 1 // java.lang.String key
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    8     0       this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    8     1        key  Ljava/lang/String;
            0    8     2  timestamp  J
            1    8     4      entry  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
            3    5     5          c  TC;
    Signature: (Ljava/lang/String;J)TC;
    MethodParameters:
           Name  Flags
      key        
      timestamp  

  public void endOfLife(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // java.lang.String key
         0: .line 140
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            aload 1 /* key */
            invokevirtual java.util.LinkedHashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast ch.qos.logback.core.spi.AbstractComponentTracker$Entry
            astore 2 /* entry */
        start local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
         1: .line 141
            aload 2 /* entry */
            ifnonnull 3
         2: .line 142
            return
         3: .line 143
      StackMap locals: ch.qos.logback.core.spi.AbstractComponentTracker$Entry
      StackMap stack:
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.lingerersMap:Ljava/util/LinkedHashMap;
            aload 1 /* key */
            aload 2 /* entry */
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 144
            return
        end local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        end local 1 // java.lang.String key
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    5     1    key  Ljava/lang/String;
            1    5     2  entry  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
    MethodParameters:
      Name  Flags
      key   

  public synchronized void removeStaleComponents(long);
    descriptor: (J)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // long now
         0: .line 153
            aload 0 /* this */
            lload 1 /* now */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.isTooSoonForRemovalIteration:(J)Z
            ifeq 2
         1: .line 154
            return
         2: .line 155
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.removeExcedentComponents:()V
         3: .line 156
            aload 0 /* this */
            lload 1 /* now */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.removeStaleComponentsFromMainMap:(J)V
         4: .line 157
            aload 0 /* this */
            lload 1 /* now */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.removeStaleComponentsFromLingerersMap:(J)V
         5: .line 158
            return
        end local 1 // long now
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    6     1   now  J
    MethodParameters:
      Name  Flags
      now   

  private void removeExcedentComponents();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
         0: .line 161
            aload 0 /* this */
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            lconst_0
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.byExcedent:Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.genericStaleComponentRemover:(Ljava/util/LinkedHashMap;JLch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;)V
         1: .line 162
            return
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;

  private void removeStaleComponentsFromMainMap(long);
    descriptor: (J)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // long now
         0: .line 165
            aload 0 /* this */
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            lload 1 /* now */
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.byTimeout:Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.genericStaleComponentRemover:(Ljava/util/LinkedHashMap;JLch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;)V
         1: .line 166
            return
        end local 1 // long now
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    2     1   now  J
    MethodParameters:
      Name  Flags
      now   

  private void removeStaleComponentsFromLingerersMap(long);
    descriptor: (J)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // long now
         0: .line 169
            aload 0 /* this */
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.lingerersMap:Ljava/util/LinkedHashMap;
            lload 1 /* now */
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.byLingering:Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.genericStaleComponentRemover:(Ljava/util/LinkedHashMap;JLch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;)V
         1: .line 170
            return
        end local 1 // long now
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    2     1   now  J
    MethodParameters:
      Name  Flags
      now   

  private void genericStaleComponentRemover(java.util.LinkedHashMap<java.lang.String, ch.qos.logback.core.spi.AbstractComponentTracker$Entry<C>>, long, ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator<C>);
    descriptor: (Ljava/util/LinkedHashMap;JLch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=9, args_size=4
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // java.util.LinkedHashMap map
        start local 2 // long now
        start local 4 // ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator removalPredicator
         0: .line 173
            aload 1 /* map */
            invokevirtual java.util.LinkedHashMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5 /* iter */
        start local 5 // java.util.Iterator iter
         1: .line 174
            goto 8
         2: .line 175
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 5 /* iter */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 6 /* mapEntry */
        start local 6 // java.util.Map$Entry mapEntry
         3: .line 176
            aload 6 /* mapEntry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast ch.qos.logback.core.spi.AbstractComponentTracker$Entry
            astore 7 /* entry */
        start local 7 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
         4: .line 177
            aload 4 /* removalPredicator */
            aload 7 /* entry */
            lload 2 /* now */
            invokeinterface ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator.isSlatedForRemoval:(Lch/qos/logback/core/spi/AbstractComponentTracker$Entry;J)Z
            ifeq 9
         5: .line 178
            aload 5 /* iter */
            invokeinterface java.util.Iterator.remove:()V
         6: .line 179
            aload 7 /* entry */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.component:Ljava/lang/Object;
            astore 8 /* c */
        start local 8 // java.lang.Object c
         7: .line 180
            aload 0 /* this */
            aload 8 /* c */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.processPriorToRemoval:(Ljava/lang/Object;)V
        end local 8 // java.lang.Object c
        end local 7 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        end local 6 // java.util.Map$Entry mapEntry
         8: .line 174
      StackMap locals:
      StackMap stack:
            aload 5 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         9: .line 185
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.util.Iterator iter
        end local 4 // ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator removalPredicator
        end local 2 // long now
        end local 1 // java.util.LinkedHashMap map
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   10     0               this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0   10     1                map  Ljava/util/LinkedHashMap<Ljava/lang/String;Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;>;
            0   10     2                now  J
            0   10     4  removalPredicator  Lch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator<TC;>;
            1   10     5               iter  Ljava/util/Iterator<Ljava/util/Map$Entry<Ljava/lang/String;Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;>;>;
            3    8     6           mapEntry  Ljava/util/Map$Entry<Ljava/lang/String;Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;>;
            4    8     7              entry  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
            7    8     8                  c  TC;
    Signature: (Ljava/util/LinkedHashMap<Ljava/lang/String;Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;>;JLch/qos/logback/core/spi/AbstractComponentTracker$RemovalPredicator<TC;>;)V
    MethodParameters:
                   Name  Flags
      map                
      now                
      removalPredicator  

  private boolean isTooSoonForRemovalIteration(long);
    descriptor: (J)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // long now
         0: .line 205
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.lastCheck:J
            ldc 1000
            ladd
            lload 1 /* now */
            lcmp
            ifle 2
         1: .line 206
            iconst_1
            ireturn
         2: .line 208
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            lload 1 /* now */
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.lastCheck:J
         3: .line 209
            iconst_0
            ireturn
        end local 1 // long now
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    4     1   now  J
    MethodParameters:
      Name  Flags
      now   

  private boolean isEntryStale(ch.qos.logback.core.spi.AbstractComponentTracker$Entry<C>, );
    descriptor: (Lch/qos/logback/core/spi/AbstractComponentTracker$Entry;J)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=3
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        start local 2 // long now
         0: .line 215
            aload 1 /* entry */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.component:Ljava/lang/Object;
            astore 4 /* c */
        start local 4 // java.lang.Object c
         1: .line 216
            aload 0 /* this */
            aload 4 /* c */
            invokevirtual ch.qos.logback.core.spi.AbstractComponentTracker.isComponentStale:(Ljava/lang/Object;)Z
            ifeq 3
         2: .line 217
            iconst_1
            ireturn
         3: .line 219
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 1 /* entry */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.timestamp:J
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.timeout:J
            ladd
            lload 2 /* now */
            lcmp
            ifge 4
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         4: iconst_0
            ireturn
        end local 4 // java.lang.Object c
        end local 2 // long now
        end local 1 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    5     1  entry  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
            0    5     2    now  J
            1    5     4      c  TC;
    Signature: (Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;J)Z
    MethodParameters:
       Name  Flags
      entry  
      now    

  private boolean isEntryDoneLingering(ch.qos.logback.core.spi.AbstractComponentTracker$Entry<C>, );
    descriptor: (Lch/qos/logback/core/spi/AbstractComponentTracker$Entry;J)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        start local 2 // long now
         0: .line 223
            aload 1 /* entry */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.timestamp:J
            ldc 10000
            ladd
            lload 2 /* now */
            lcmp
            ifge 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 2 // long now
        end local 1 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry entry
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    2     1  entry  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
            0    2     2    now  J
    Signature: (Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;J)Z
    MethodParameters:
       Name  Flags
      entry  
      now    

  public java.util.Set<java.lang.String> allKeys();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
         0: .line 227
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.keySet:()Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 1 /* allKeys */
        start local 1 // java.util.HashSet allKeys
         1: .line 228
            aload 1 /* allKeys */
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.lingerersMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.keySet:()Ljava/util/Set;
            invokevirtual java.util.HashSet.addAll:(Ljava/util/Collection;)Z
            pop
         2: .line 229
            aload 1 /* allKeys */
            areturn
        end local 1 // java.util.HashSet allKeys
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            1    3     1  allKeys  Ljava/util/HashSet<Ljava/lang/String;>;
    Signature: ()Ljava/util/Set<Ljava/lang/String;>;

  public java.util.Collection<C> allComponents();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
         0: .line 233
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* allComponents */
        start local 1 // java.util.List allComponents
         1: .line 234
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.liveMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: ch.qos.logback.core.spi.AbstractComponentTracker java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast ch.qos.logback.core.spi.AbstractComponentTracker$Entry
            astore 2 /* e */
        start local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry e
         3: .line 235
            aload 1 /* allComponents */
            aload 2 /* e */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.component:Ljava/lang/Object;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry e
         4: .line 234
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 236
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.lingerersMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 8
      StackMap locals:
      StackMap stack:
         6: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast ch.qos.logback.core.spi.AbstractComponentTracker$Entry
            astore 2 /* e */
        start local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry e
         7: .line 237
            aload 1 /* allComponents */
            aload 2 /* e */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker$Entry.component:Ljava/lang/Object;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // ch.qos.logback.core.spi.AbstractComponentTracker$Entry e
         8: .line 236
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
         9: .line 239
            aload 1 /* allComponents */
            areturn
        end local 1 // java.util.List allComponents
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   10     0           this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            1   10     1  allComponents  Ljava/util/List<TC;>;
            3    4     2              e  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
            7    8     2              e  Lch/qos/logback/core/spi/AbstractComponentTracker$Entry<TC;>;
    Signature: ()Ljava/util/Collection<TC;>;

  public long getTimeout();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
         0: .line 243
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.timeout:J
            lreturn
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;

  public void setTimeout(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // long timeout
         0: .line 247
            aload 0 /* this */
            lload 1 /* timeout */
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.timeout:J
         1: .line 248
            return
        end local 1 // long timeout
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    2     1  timeout  J
    MethodParameters:
         Name  Flags
      timeout  

  public int getMaxComponents();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
         0: .line 251
            aload 0 /* this */
            getfield ch.qos.logback.core.spi.AbstractComponentTracker.maxComponents:I
            ireturn
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;

  public void setMaxComponents(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
        start local 1 // int maxComponents
         0: .line 255
            aload 0 /* this */
            iload 1 /* maxComponents */
            putfield ch.qos.logback.core.spi.AbstractComponentTracker.maxComponents:I
         1: .line 256
            return
        end local 1 // int maxComponents
        end local 0 // ch.qos.logback.core.spi.AbstractComponentTracker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    2     0           this  Lch/qos/logback/core/spi/AbstractComponentTracker<TC;>;
            0    2     1  maxComponents  I
    MethodParameters:
               Name  Flags
      maxComponents  
}
Signature: <C:Ljava/lang/Object;>Ljava/lang/Object;Lch/qos/logback/core/spi/ComponentTracker<TC;>;
SourceFile: "AbstractComponentTracker.java"
NestMembers:
  ch.qos.logback.core.spi.AbstractComponentTracker$1  ch.qos.logback.core.spi.AbstractComponentTracker$2  ch.qos.logback.core.spi.AbstractComponentTracker$3  ch.qos.logback.core.spi.AbstractComponentTracker$Entry  ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator
InnerClasses:
  ch.qos.logback.core.spi.AbstractComponentTracker$1
  ch.qos.logback.core.spi.AbstractComponentTracker$2
  ch.qos.logback.core.spi.AbstractComponentTracker$3
  private Entry = ch.qos.logback.core.spi.AbstractComponentTracker$Entry of ch.qos.logback.core.spi.AbstractComponentTracker
  private abstract RemovalPredicator = ch.qos.logback.core.spi.AbstractComponentTracker$RemovalPredicator of ch.qos.logback.core.spi.AbstractComponentTracker
  public abstract Entry = java.util.Map$Entry of java.util.Map