final class io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask extends io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceInTask
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask
  super_class: io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceInTask
{
  private final io.netty.channel.unix.FileDescriptor fd;
    descriptor: Lio/netty/channel/unix/FileDescriptor;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final io.netty.channel.ChannelPromise promise;
    descriptor: Lio/netty/channel/ChannelPromise;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final int offset;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  final io.netty.channel.epoll.AbstractEpollStreamChannel this$0;
    descriptor: Lio/netty/channel/epoll/AbstractEpollStreamChannel;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 999
            ldc Lio/netty/channel/epoll/AbstractEpollStreamChannel;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(io.netty.channel.epoll.AbstractEpollStreamChannel, io.netty.channel.unix.FileDescriptor, int, int, io.netty.channel.ChannelPromise);
    descriptor: (Lio/netty/channel/epoll/AbstractEpollStreamChannel;Lio/netty/channel/unix/FileDescriptor;IILio/netty/channel/ChannelPromise;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=6, args_size=6
        start local 0 // io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask this
        start local 2 // io.netty.channel.unix.FileDescriptor fd
        start local 3 // int offset
        start local 4 // int len
        start local 5 // io.netty.channel.ChannelPromise promise
         0: .line 1004
            aload 0 /* this */
            aload 1
            putfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.this$0:Lio/netty/channel/epoll/AbstractEpollStreamChannel;
         1: .line 1005
            aload 0 /* this */
            aload 1
            iload 4 /* len */
            aload 5 /* promise */
            invokespecial io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceInTask.<init>:(Lio/netty/channel/epoll/AbstractEpollStreamChannel;ILio/netty/channel/ChannelPromise;)V
         2: .line 1006
            aload 0 /* this */
            aload 2 /* fd */
            putfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.fd:Lio/netty/channel/unix/FileDescriptor;
         3: .line 1007
            aload 0 /* this */
            aload 5 /* promise */
            putfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.promise:Lio/netty/channel/ChannelPromise;
         4: .line 1008
            aload 0 /* this */
            iload 3 /* offset */
            putfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.offset:I
         5: .line 1009
            return
        end local 5 // io.netty.channel.ChannelPromise promise
        end local 4 // int len
        end local 3 // int offset
        end local 2 // io.netty.channel.unix.FileDescriptor fd
        end local 0 // io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Lio/netty/channel/epoll/AbstractEpollStreamChannel$SpliceFdTask;
            0    6     2       fd  Lio/netty/channel/unix/FileDescriptor;
            0    6     3   offset  I
            0    6     4      len  I
            0    6     5  promise  Lio/netty/channel/ChannelPromise;
    MethodParameters:
         Name  Flags
      this$0   final
      fd       
      offset   
      len      
      promise  

  public boolean spliceIn(io.netty.channel.RecvByteBufAllocator$Handle);
    descriptor: (Lio/netty/channel/RecvByteBufAllocator$Handle;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=8, args_size=2
        start local 0 // io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask this
        start local 1 // io.netty.channel.RecvByteBufAllocator$Handle handle
         0: .line 1013
            getstatic io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.this$0:Lio/netty/channel/epoll/AbstractEpollStreamChannel;
            invokevirtual io.netty.channel.epoll.AbstractEpollStreamChannel.eventLoop:()Lio/netty/channel/EventLoop;
            invokeinterface io.netty.channel.EventLoop.inEventLoop:()Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 1014
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.len:I
            ifne 4
         2: .line 1015
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.promise:Lio/netty/channel/ChannelPromise;
            invokeinterface io.netty.channel.ChannelPromise.setSuccess:()Lio/netty/channel/ChannelPromise;
            pop
         3: .line 1016
            iconst_1
            ireturn
         4: .line 1020
      StackMap locals:
      StackMap stack:
            invokestatic io.netty.channel.unix.FileDescriptor.pipe:()[Lio/netty/channel/unix/FileDescriptor;
            astore 2 /* pipe */
        start local 2 // io.netty.channel.unix.FileDescriptor[] pipe
         5: .line 1021
            aload 2 /* pipe */
            iconst_0
            aaload
            astore 3 /* pipeIn */
        start local 3 // io.netty.channel.unix.FileDescriptor pipeIn
         6: .line 1022
            aload 2 /* pipe */
            iconst_1
            aaload
            astore 4 /* pipeOut */
        start local 4 // io.netty.channel.unix.FileDescriptor pipeOut
         7: .line 1024
            aload 0 /* this */
            aload 4 /* pipeOut */
            aload 1 /* handle */
            invokevirtual io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.spliceIn:(Lio/netty/channel/unix/FileDescriptor;Lio/netty/channel/RecvByteBufAllocator$Handle;)I
            istore 5 /* splicedIn */
        start local 5 // int splicedIn
         8: .line 1025
            iload 5 /* splicedIn */
            ifle 20
         9: .line 1027
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.len:I
            ldc 2147483647
            if_icmpeq 11
        10: .line 1028
            aload 0 /* this */
            dup
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.len:I
            iload 5 /* splicedIn */
            isub
            putfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.len:I
        11: .line 1031
      StackMap locals: io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask io.netty.channel.RecvByteBufAllocator$Handle io.netty.channel.unix.FileDescriptor[] io.netty.channel.unix.FileDescriptor io.netty.channel.unix.FileDescriptor int
      StackMap stack:
            aload 3 /* pipeIn */
            invokevirtual io.netty.channel.unix.FileDescriptor.intValue:()I
            ldc -1
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.fd:Lio/netty/channel/unix/FileDescriptor;
            invokevirtual io.netty.channel.unix.FileDescriptor.intValue:()I
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.offset:I
            i2l
            iload 5 /* splicedIn */
            i2l
            invokestatic io.netty.channel.epoll.Native.splice:(IJIJJ)I
            istore 6 /* splicedOut */
        start local 6 // int splicedOut
        12: .line 1032
            iload 5 /* splicedIn */
            iload 6 /* splicedOut */
            isub
            istore 5 /* splicedIn */
        end local 6 // int splicedOut
        13: .line 1033
            iload 5 /* splicedIn */
        14: .line 1030
            ifgt 11
        15: .line 1034
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.len:I
            ifne 20
        16: .line 1035
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.promise:Lio/netty/channel/ChannelPromise;
            invokeinterface io.netty.channel.ChannelPromise.setSuccess:()Lio/netty/channel/ChannelPromise;
            pop
        17: .line 1041
            aload 3 /* pipeIn */
            invokestatic io.netty.channel.epoll.AbstractEpollStreamChannel.safeClosePipe:(Lio/netty/channel/unix/FileDescriptor;)V
        18: .line 1042
            aload 4 /* pipeOut */
            invokestatic io.netty.channel.epoll.AbstractEpollStreamChannel.safeClosePipe:(Lio/netty/channel/unix/FileDescriptor;)V
        19: .line 1036
            iconst_1
            ireturn
        20: .line 1041
      StackMap locals:
      StackMap stack:
            aload 3 /* pipeIn */
            invokestatic io.netty.channel.epoll.AbstractEpollStreamChannel.safeClosePipe:(Lio/netty/channel/unix/FileDescriptor;)V
        21: .line 1042
            aload 4 /* pipeOut */
            invokestatic io.netty.channel.epoll.AbstractEpollStreamChannel.safeClosePipe:(Lio/netty/channel/unix/FileDescriptor;)V
        22: .line 1039
            iconst_0
            ireturn
        end local 5 // int splicedIn
        23: .line 1040
      StackMap locals: io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask io.netty.channel.RecvByteBufAllocator$Handle io.netty.channel.unix.FileDescriptor[] io.netty.channel.unix.FileDescriptor io.netty.channel.unix.FileDescriptor
      StackMap stack: java.lang.Throwable
            astore 7
        24: .line 1041
            aload 3 /* pipeIn */
            invokestatic io.netty.channel.epoll.AbstractEpollStreamChannel.safeClosePipe:(Lio/netty/channel/unix/FileDescriptor;)V
        25: .line 1042
            aload 4 /* pipeOut */
            invokestatic io.netty.channel.epoll.AbstractEpollStreamChannel.safeClosePipe:(Lio/netty/channel/unix/FileDescriptor;)V
        26: .line 1043
            aload 7
            athrow
        end local 4 // io.netty.channel.unix.FileDescriptor pipeOut
        end local 3 // io.netty.channel.unix.FileDescriptor pipeIn
        end local 2 // io.netty.channel.unix.FileDescriptor[] pipe
        27: .line 1044
      StackMap locals: io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask io.netty.channel.RecvByteBufAllocator$Handle
      StackMap stack: java.lang.Throwable
            astore 2 /* cause */
        start local 2 // java.lang.Throwable cause
        28: .line 1045
            aload 0 /* this */
            getfield io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask.promise:Lio/netty/channel/ChannelPromise;
            aload 2 /* cause */
            invokeinterface io.netty.channel.ChannelPromise.setFailure:(Ljava/lang/Throwable;)Lio/netty/channel/ChannelPromise;
            pop
        29: .line 1046
            iconst_1
            ireturn
        end local 2 // java.lang.Throwable cause
        end local 1 // io.netty.channel.RecvByteBufAllocator$Handle handle
        end local 0 // io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   30     0        this  Lio/netty/channel/epoll/AbstractEpollStreamChannel$SpliceFdTask;
            0   30     1      handle  Lio/netty/channel/RecvByteBufAllocator$Handle;
            5   27     2        pipe  [Lio/netty/channel/unix/FileDescriptor;
            6   27     3      pipeIn  Lio/netty/channel/unix/FileDescriptor;
            7   27     4     pipeOut  Lio/netty/channel/unix/FileDescriptor;
            8   23     5   splicedIn  I
           12   13     6  splicedOut  I
           28   30     2       cause  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           7    17      23  any
           4    19      27  Class java.lang.Throwable
          20    22      27  Class java.lang.Throwable
          23    27      27  Class java.lang.Throwable
    MethodParameters:
        Name  Flags
      handle  
}
SourceFile: "AbstractEpollStreamChannel.java"
NestHost: io.netty.channel.epoll.AbstractEpollStreamChannel
InnerClasses:
  public abstract Handle = io.netty.channel.RecvByteBufAllocator$Handle of io.netty.channel.RecvByteBufAllocator
  private final SpliceFdTask = io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceFdTask of io.netty.channel.epoll.AbstractEpollStreamChannel
  protected abstract SpliceInTask = io.netty.channel.epoll.AbstractEpollStreamChannel$SpliceInTask of io.netty.channel.epoll.AbstractEpollStreamChannel