public class org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy extends org.apache.logging.log4j.core.AbstractLifeCycle implements org.apache.logging.log4j.core.appender.routing.PurgePolicy, java.lang.Runnable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy
  super_class: org.apache.logging.log4j.core.AbstractLifeCycle
{
  private final long timeToLive;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final long checkInterval;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.ConcurrentMap<java.lang.String, java.lang.Long> appendersUsage;
    descriptor: Ljava/util/concurrent/ConcurrentMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentMap<Ljava/lang/String;Ljava/lang/Long;>;

  private org.apache.logging.log4j.core.appender.routing.RoutingAppender routingAppender;
    descriptor: Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender;
    flags: (0x0002) ACC_PRIVATE

  private final org.apache.logging.log4j.core.config.ConfigurationScheduler scheduler;
    descriptor: Lorg/apache/logging/log4j/core/config/ConfigurationScheduler;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile java.util.concurrent.ScheduledFuture<?> future;
    descriptor: Ljava/util/concurrent/ScheduledFuture;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
    Signature: Ljava/util/concurrent/ScheduledFuture<*>;

  public void <init>(long, long, org.apache.logging.log4j.core.config.ConfigurationScheduler);
    descriptor: (JJLorg/apache/logging/log4j/core/config/ConfigurationScheduler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=4
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
        start local 1 // long timeToLive
        start local 3 // long checkInterval
        start local 5 // org.apache.logging.log4j.core.config.ConfigurationScheduler scheduler
         0: .line 50
            aload 0 /* this */
            invokespecial org.apache.logging.log4j.core.AbstractLifeCycle.<init>:()V
         1: .line 45
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.appendersUsage:Ljava/util/concurrent/ConcurrentMap;
         2: .line 51
            aload 0 /* this */
            lload 1 /* timeToLive */
            putfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.timeToLive:J
         3: .line 52
            aload 0 /* this */
            lload 3 /* checkInterval */
            putfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.checkInterval:J
         4: .line 53
            aload 0 /* this */
            aload 5 /* scheduler */
            putfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.scheduler:Lorg/apache/logging/log4j/core/config/ConfigurationScheduler;
         5: .line 54
            return
        end local 5 // org.apache.logging.log4j.core.config.ConfigurationScheduler scheduler
        end local 3 // long checkInterval
        end local 1 // long timeToLive
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    6     0           this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;
            0    6     1     timeToLive  J
            0    6     3  checkInterval  J
            0    6     5      scheduler  Lorg/apache/logging/log4j/core/config/ConfigurationScheduler;
    MethodParameters:
               Name  Flags
      timeToLive     final
      checkInterval  final
      scheduler      final

  public void initialize(org.apache.logging.log4j.core.appender.routing.RoutingAppender);
    descriptor: (Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
        start local 1 // org.apache.logging.log4j.core.appender.routing.RoutingAppender routingAppender
         0: .line 58
            aload 0 /* this */
            aload 1 /* routingAppender */
            putfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.routingAppender:Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender;
         1: .line 59
            return
        end local 1 // org.apache.logging.log4j.core.appender.routing.RoutingAppender routingAppender
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;
            0    2     1  routingAppender  Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender;
    MethodParameters:
                 Name  Flags
      routingAppender  final

  public boolean stop(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=3
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 63
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.setStopping:()V
         1: .line 64
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.future:Ljava/util/concurrent/ScheduledFuture;
            invokevirtual org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.stop:(Ljava/util/concurrent/Future;)Z
            istore 4 /* stopped */
        start local 4 // boolean stopped
         2: .line 65
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.setStopped:()V
         3: .line 66
            iload 4 /* stopped */
            ireturn
        end local 4 // boolean stopped
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long timeout
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;
            0    4     1   timeout  J
            0    4     3  timeUnit  Ljava/util/concurrent/TimeUnit;
            2    4     4   stopped  Z
    MethodParameters:
          Name  Flags
      timeout   final
      timeUnit  final

  public void purge();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=7, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
         0: .line 74
            invokestatic java.lang.System.currentTimeMillis:()J
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.timeToLive:J
            lsub
            lstore 1 /* createTime */
        start local 1 // long createTime
         1: .line 75
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.appendersUsage:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 8
      StackMap locals: org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy long top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 3 /* entry */
        start local 3 // java.util.Map$Entry entry
         3: .line 76
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lstore 5 /* entryValue */
        start local 5 // long entryValue
         4: .line 77
            lload 5 /* entryValue */
            lload 1 /* createTime */
            lcmp
            ifge 8
         5: .line 78
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.appendersUsage:Ljava/util/concurrent/ConcurrentMap;
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            lload 5 /* entryValue */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.concurrent.ConcurrentMap.remove:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 8
         6: .line 79
            getstatic org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Removing appender {}"
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            invokeinterface org.apache.logging.log4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         7: .line 80
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.routingAppender:Lorg/apache/logging/log4j/core/appender/routing/RoutingAppender;
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual org.apache.logging.log4j.core.appender.routing.RoutingAppender.deleteAppender:(Ljava/lang/String;)V
        end local 5 // long entryValue
        end local 3 // java.util.Map$Entry entry
         8: .line 75
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         9: .line 84
            return
        end local 1 // long createTime
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0        this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;
            1   10     1  createTime  J
            3    8     3       entry  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;
            4    8     5  entryValue  J

  public void update(java.lang.String, org.apache.logging.log4j.core.LogEvent);
    descriptor: (Ljava/lang/String;Lorg/apache/logging/log4j/core/LogEvent;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
        start local 1 // java.lang.String key
        start local 2 // org.apache.logging.log4j.core.LogEvent event
         0: .line 88
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 3 /* now */
        start local 3 // long now
         1: .line 89
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.appendersUsage:Ljava/util/concurrent/ConcurrentMap;
            aload 1 /* key */
            lload 3 /* now */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.concurrent.ConcurrentMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 90
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.future:Ljava/util/concurrent/ScheduledFuture;
            ifnonnull 10
         3: .line 91
            aload 0 /* this */
            dup
            astore 5
            monitorenter
         4: .line 92
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.future:Ljava/util/concurrent/ScheduledFuture;
            ifnonnull 6
         5: .line 93
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.scheduleNext:()V
         6: .line 91
      StackMap locals: long org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy
      StackMap stack:
            aload 5
            monitorexit
         7: goto 10
      StackMap locals:
      StackMap stack: java.lang.Throwable
         8: aload 5
            monitorexit
         9: athrow
        10: .line 98
      StackMap locals:
      StackMap stack:
            return
        end local 3 // long now
        end local 2 // org.apache.logging.log4j.core.LogEvent event
        end local 1 // java.lang.String key
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   11     0   this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;
            0   11     1    key  Ljava/lang/String;
            0   11     2  event  Lorg/apache/logging/log4j/core/LogEvent;
            1   11     3    now  J
      Exception table:
        from    to  target  type
           4     7       8  any
           8     9       8  any
    MethodParameters:
       Name  Flags
      key    final
      event  final

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
         0: .line 102
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.purge:()V
         1: .line 103
            aload 0 /* this */
            invokevirtual org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.scheduleNext:()V
         2: .line 104
            return
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;

  private void scheduleNext();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=5, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
         0: .line 107
            ldc 9223372036854775807
            lstore 1 /* updateTime */
        start local 1 // long updateTime
         1: .line 108
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.appendersUsage:Ljava/util/concurrent/ConcurrentMap;
            invokeinterface java.util.concurrent.ConcurrentMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 5
      StackMap locals: org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy long top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 3 /* entry */
        start local 3 // java.util.Map$Entry entry
         3: .line 109
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lload 1 /* updateTime */
            lcmp
            ifge 5
         4: .line 110
            aload 3 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Long
            invokevirtual java.lang.Long.longValue:()J
            lstore 1 /* updateTime */
        end local 3 // java.util.Map$Entry entry
         5: .line 108
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 114
            lload 1 /* updateTime */
            ldc 9223372036854775807
            lcmp
            ifge 10
         7: .line 115
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.timeToLive:J
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 1 /* updateTime */
            lsub
            lsub
            lstore 3 /* interval */
        start local 3 // long interval
         8: .line 116
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.scheduler:Lorg/apache/logging/log4j/core/config/ConfigurationScheduler;
            aload 0 /* this */
            lload 3 /* interval */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual org.apache.logging.log4j.core.config.ConfigurationScheduler.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
            putfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.future:Ljava/util/concurrent/ScheduledFuture;
        end local 3 // long interval
         9: .line 117
            goto 11
        10: .line 119
      StackMap locals: org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy long
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.scheduler:Lorg/apache/logging/log4j/core/config/ConfigurationScheduler;
            aload 0 /* this */
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.checkInterval:J
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual org.apache.logging.log4j.core.config.ConfigurationScheduler.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
            putfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.future:Ljava/util/concurrent/ScheduledFuture;
        11: .line 121
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long updateTime
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   12     0        this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;
            1   12     1  updateTime  J
            3    5     3       entry  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Long;>;
            8    9     3    interval  J

  public static org.apache.logging.log4j.core.appender.routing.PurgePolicy createPurgePolicy(java.lang.String, java.lang.String, java.lang.String, org.apache.logging.log4j.core.config.Configuration);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Lorg/apache/logging/log4j/core/config/Configuration;)Lorg/apache/logging/log4j/core/appender/routing/PurgePolicy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=7, locals=9, args_size=4
        start local 0 // java.lang.String timeToLive
        start local 1 // java.lang.String checkInterval
        start local 2 // java.lang.String timeUnit
        start local 3 // org.apache.logging.log4j.core.config.Configuration configuration
         0: .line 138
            aload 0 /* timeToLive */
            ifnonnull 3
         1: .line 139
            getstatic org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "A timeToLive value is required"
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;)V
         2: .line 140
            aconst_null
            areturn
         3: .line 143
      StackMap locals:
      StackMap stack:
            aload 2 /* timeUnit */
            ifnonnull 6
         4: .line 144
            getstatic java.util.concurrent.TimeUnit.MINUTES:Ljava/util/concurrent/TimeUnit;
            astore 4 /* units */
        start local 4 // java.util.concurrent.TimeUnit units
         5: .line 145
            goto 11
        end local 4 // java.util.concurrent.TimeUnit units
         6: .line 147
      StackMap locals:
      StackMap stack:
            aload 2 /* timeUnit */
            invokevirtual java.lang.String.toUpperCase:()Ljava/lang/String;
            invokestatic java.util.concurrent.TimeUnit.valueOf:(Ljava/lang/String;)Ljava/util/concurrent/TimeUnit;
            astore 4 /* units */
        start local 4 // java.util.concurrent.TimeUnit units
         7: .line 148
            goto 11
        end local 4 // java.util.concurrent.TimeUnit units
      StackMap locals:
      StackMap stack: java.lang.Exception
         8: astore 5 /* ex */
        start local 5 // java.lang.Exception ex
         9: .line 149
            getstatic org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "Invalid timeUnit value {}. timeUnit set to MINUTES"
            aload 2 /* timeUnit */
            aload 5 /* ex */
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        10: .line 150
            getstatic java.util.concurrent.TimeUnit.MINUTES:Ljava/util/concurrent/TimeUnit;
            astore 4 /* units */
        end local 5 // java.lang.Exception ex
        start local 4 // java.util.concurrent.TimeUnit units
        11: .line 154
      StackMap locals: java.util.concurrent.TimeUnit
      StackMap stack:
            aload 4 /* units */
            aload 0 /* timeToLive */
            invokestatic java.lang.Long.parseLong:(Ljava/lang/String;)J
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            lstore 5 /* ttl */
        start local 5 // long ttl
        12: .line 155
            lload 5 /* ttl */
            lconst_0
            lcmp
            ifge 15
        13: .line 156
            getstatic org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "timeToLive must be positive. timeToLive set to 0"
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;)V
        14: .line 157
            lconst_0
            lstore 5 /* ttl */
        15: .line 161
      StackMap locals: long
      StackMap stack:
            aload 1 /* checkInterval */
            ifnonnull 18
        16: .line 162
            lload 5 /* ttl */
            lstore 7 /* ci */
        start local 7 // long ci
        17: .line 163
            goto 22
        end local 7 // long ci
        18: .line 164
      StackMap locals:
      StackMap stack:
            aload 4 /* units */
            aload 1 /* checkInterval */
            invokestatic java.lang.Long.parseLong:(Ljava/lang/String;)J
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            lstore 7 /* ci */
        start local 7 // long ci
        19: .line 165
            lload 7 /* ci */
            lconst_0
            lcmp
            ifge 22
        20: .line 166
            getstatic org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.LOGGER:Lorg/apache/logging/log4j/Logger;
            ldc "checkInterval must be positive. checkInterval set equal to timeToLive = {}"
            lload 5 /* ttl */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface org.apache.logging.log4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;)V
        21: .line 167
            lload 5 /* ttl */
            lstore 7 /* ci */
        22: .line 171
      StackMap locals: long
      StackMap stack:
            new org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy
            dup
            lload 5 /* ttl */
            lload 7 /* ci */
            aload 3 /* configuration */
            invokeinterface org.apache.logging.log4j.core.config.Configuration.getScheduler:()Lorg/apache/logging/log4j/core/config/ConfigurationScheduler;
            invokespecial org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.<init>:(JJLorg/apache/logging/log4j/core/config/ConfigurationScheduler;)V
            areturn
        end local 7 // long ci
        end local 5 // long ttl
        end local 4 // java.util.concurrent.TimeUnit units
        end local 3 // org.apache.logging.log4j.core.config.Configuration configuration
        end local 2 // java.lang.String timeUnit
        end local 1 // java.lang.String checkInterval
        end local 0 // java.lang.String timeToLive
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   23     0     timeToLive  Ljava/lang/String;
            0   23     1  checkInterval  Ljava/lang/String;
            0   23     2       timeUnit  Ljava/lang/String;
            0   23     3  configuration  Lorg/apache/logging/log4j/core/config/Configuration;
            5    6     4          units  Ljava/util/concurrent/TimeUnit;
            7    8     4          units  Ljava/util/concurrent/TimeUnit;
           11   23     4          units  Ljava/util/concurrent/TimeUnit;
            9   11     5             ex  Ljava/lang/Exception;
           12   23     5            ttl  J
           17   18     7             ci  J
           19   23     7             ci  J
      Exception table:
        from    to  target  type
           6     7       8  Class java.lang.Exception
    RuntimeVisibleAnnotations: 
      org.apache.logging.log4j.core.config.plugins.PluginFactory()
    RuntimeVisibleParameterAnnotations: 
      0:
        org.apache.logging.log4j.core.config.plugins.PluginAttribute(value = "timeToLive")
      1:
        org.apache.logging.log4j.core.config.plugins.PluginAttribute(value = "checkInterval")
      2:
        org.apache.logging.log4j.core.config.plugins.PluginAttribute(value = "timeUnit")
      3:
        org.apache.logging.log4j.core.config.plugins.PluginConfiguration()
    MethodParameters:
               Name  Flags
      timeToLive     final
      checkInterval  final
      timeUnit       final
      configuration  final

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
         0: .line 176
            new java.lang.StringBuilder
            dup
            ldc "timeToLive="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy.timeToLive:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 0 // org.apache.logging.log4j.core.appender.routing.IdlePurgePolicy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/logging/log4j/core/appender/routing/IdlePurgePolicy;
}
SourceFile: "IdlePurgePolicy.java"
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map
    RuntimeVisibleAnnotations: 
      org.apache.logging.log4j.core.config.plugins.Plugin(name = "IdlePurgePolicy", category = "Core", printObject = true)
      org.apache.logging.log4j.core.config.Scheduled()