class io.undertow.conduits.IdleTimeoutConduit$1 implements java.lang.Runnable
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.undertow.conduits.IdleTimeoutConduit$1
  super_class: java.lang.Object
{
  final io.undertow.conduits.IdleTimeoutConduit this$0;
    descriptor: Lio/undertow/conduits/IdleTimeoutConduit;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(io.undertow.conduits.IdleTimeoutConduit);
    descriptor: (Lio/undertow/conduits/IdleTimeoutConduit;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.undertow.conduits.IdleTimeoutConduit$1 this
         0: .line 60
            aload 0 /* this */
            aload 1
            putfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // io.undertow.conduits.IdleTimeoutConduit$1 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/undertow/conduits/IdleTimeoutConduit$1;
    MethodParameters:
        Name  Flags
      this$0  final

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=3, args_size=1
        start local 0 // io.undertow.conduits.IdleTimeoutConduit$1 this
         0: .line 63
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            aconst_null
            putfield io.undertow.conduits.IdleTimeoutConduit.handle:Lorg/xnio/XnioExecutor$Key;
         1: .line 64
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.expireTime:J
            ldc -1
            lcmp
            ifne 3
         2: .line 65
            return
         3: .line 67
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 1 /* current */
        start local 1 // long current
         4: .line 68
            lload 1 /* current */
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.expireTime:J
            lcmp
            ifge 7
         5: .line 70
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            invokevirtual io.undertow.conduits.IdleTimeoutConduit.getWriteThread:()Lorg/xnio/XnioIoThread;
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.timeoutCommand:Ljava/lang/Runnable;
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.expireTime:J
            lload 1 /* current */
            lsub
            ldc 100
            ladd
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokestatic io.undertow.util.WorkerUtils.executeAfter:(Lorg/xnio/XnioIoThread;Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lorg/xnio/XnioExecutor$Key;
            putfield io.undertow.conduits.IdleTimeoutConduit.handle:Lorg/xnio/XnioExecutor$Key;
         6: .line 71
            return
         7: .line 74
      StackMap locals: long
      StackMap stack:
            getstatic io.undertow.UndertowLogger.REQUEST_LOGGER:Lio/undertow/UndertowLogger;
            ldc "Timing out channel due to inactivity"
            invokeinterface io.undertow.UndertowLogger.trace:(Ljava/lang/Object;)V
         8: .line 75
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            iconst_1
            putfield io.undertow.conduits.IdleTimeoutConduit.timedOut:Z
         9: .line 76
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            invokevirtual io.undertow.conduits.IdleTimeoutConduit.doClose:()V
        10: .line 77
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.sink:Lorg/xnio/conduits/StreamSinkConduit;
            invokeinterface org.xnio.conduits.StreamSinkConduit.isWriteResumed:()Z
            ifeq 13
        11: .line 78
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.writeReadyHandler:Lorg/xnio/conduits/WriteReadyHandler;
            ifnull 13
        12: .line 79
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.writeReadyHandler:Lorg/xnio/conduits/WriteReadyHandler;
            invokeinterface org.xnio.conduits.WriteReadyHandler.writeReady:()V
        13: .line 82
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.source:Lorg/xnio/conduits/StreamSourceConduit;
            invokeinterface org.xnio.conduits.StreamSourceConduit.isReadResumed:()Z
            ifeq 16
        14: .line 83
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.readReadyHandler:Lorg/xnio/conduits/ReadReadyHandler;
            ifnull 16
        15: .line 84
            aload 0 /* this */
            getfield io.undertow.conduits.IdleTimeoutConduit$1.this$0:Lio/undertow/conduits/IdleTimeoutConduit;
            getfield io.undertow.conduits.IdleTimeoutConduit.readReadyHandler:Lorg/xnio/conduits/ReadReadyHandler;
            invokeinterface org.xnio.conduits.ReadReadyHandler.readReady:()V
        16: .line 87
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long current
        end local 0 // io.undertow.conduits.IdleTimeoutConduit$1 this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   17     0     this  Lio/undertow/conduits/IdleTimeoutConduit$1;
            4   17     1  current  J
}
SourceFile: "IdleTimeoutConduit.java"
EnclosingMethod: io.undertow.conduits.IdleTimeoutConduit
NestHost: io.undertow.conduits.IdleTimeoutConduit
InnerClasses:
  io.undertow.conduits.IdleTimeoutConduit$1
  public abstract Key = org.xnio.XnioExecutor$Key of org.xnio.XnioExecutor