final class org.xnio.nio.QueuedNioTcpServer extends org.xnio.nio.AbstractNioChannel<org.xnio.nio.QueuedNioTcpServer> implements org.xnio.channels.AcceptingChannel<org.xnio.StreamConnection>, org.xnio.channels.AcceptListenerSettable<org.xnio.nio.QueuedNioTcpServer>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: org.xnio.nio.QueuedNioTcpServer
  super_class: org.xnio.nio.AbstractNioChannel
{
  private static final java.lang.String FQCN;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private volatile org.xnio.ChannelListener<? super org.xnio.nio.QueuedNioTcpServer> acceptListener;
    descriptor: Lorg/xnio/ChannelListener;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
    Signature: Lorg/xnio/ChannelListener<-Lorg/xnio/nio/QueuedNioTcpServer;>;

  private final org.xnio.nio.QueuedNioTcpServerHandle handle;
    descriptor: Lorg/xnio/nio/QueuedNioTcpServerHandle;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.xnio.nio.WorkerThread thread;
    descriptor: Lorg/xnio/nio/WorkerThread;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.nio.channels.ServerSocketChannel channel;
    descriptor: Ljava/nio/channels/ServerSocketChannel;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.net.ServerSocket socket;
    descriptor: Ljava/net/ServerSocket;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.xnio.ManagementRegistration mbeanHandle;
    descriptor: Lorg/xnio/ManagementRegistration;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.List<java.util.concurrent.BlockingQueue<java.nio.channels.SocketChannel>> acceptQueues;
    descriptor: Ljava/util/List;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/List<Ljava/util/concurrent/BlockingQueue<Ljava/nio/channels/SocketChannel;>;>;

  private static final java.util.Set<org.xnio.Option<?>> options;
    descriptor: Ljava/util/Set;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Set<Lorg/xnio/Option<*>;>;

  private volatile int keepAlive;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile int oobInline;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile int tcpNoDelay;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile int sendBuffer;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile long connectionStatus;
    descriptor: J
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile int readTimeout;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile int writeTimeout;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private static final long CONN_LOW_MASK;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 2147483647

  private static final long CONN_LOW_BIT;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  private static final long CONN_LOW_ONE;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  private static final long CONN_HIGH_MASK;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 4611686016279904256

  private static final long CONN_HIGH_BIT;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 31

  private static final long CONN_HIGH_ONE;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 2147483648

  private int openConnections;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private volatile boolean suspendedDueToWatermark;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile boolean suspended;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<org.xnio.nio.QueuedNioTcpServer> keepAliveUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lorg/xnio/nio/QueuedNioTcpServer;>;

  private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<org.xnio.nio.QueuedNioTcpServer> oobInlineUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lorg/xnio/nio/QueuedNioTcpServer;>;

  private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<org.xnio.nio.QueuedNioTcpServer> tcpNoDelayUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lorg/xnio/nio/QueuedNioTcpServer;>;

  private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<org.xnio.nio.QueuedNioTcpServer> sendBufferUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lorg/xnio/nio/QueuedNioTcpServer;>;

  private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<org.xnio.nio.QueuedNioTcpServer> readTimeoutUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lorg/xnio/nio/QueuedNioTcpServer;>;

  private static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<org.xnio.nio.QueuedNioTcpServer> writeTimeoutUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lorg/xnio/nio/QueuedNioTcpServer;>;

  private static final java.util.concurrent.atomic.AtomicLongFieldUpdater<org.xnio.nio.QueuedNioTcpServer> connectionStatusUpdater;
    descriptor: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater<Lorg/xnio/nio/QueuedNioTcpServer;>;

  private final java.lang.Runnable acceptTask;
    descriptor: Ljava/lang/Runnable;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.Runnable connectionClosedTask;
    descriptor: Ljava/lang/Runnable;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  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=2, locals=0, args_size=0
         0: .line 60
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            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 org.xnio.nio.QueuedNioTcpServer.$assertionsDisabled:Z
         3: .line 61
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            putstatic org.xnio.nio.QueuedNioTcpServer.FQCN:Ljava/lang/String;
         4: .line 74
            invokestatic org.xnio.Option.setBuilder:()Lorg/xnio/Option$SetBuilder;
         5: .line 75
            getstatic org.xnio.Options.REUSE_ADDRESSES:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
         6: .line 76
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
         7: .line 77
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
         8: .line 78
            getstatic org.xnio.Options.KEEP_ALIVE:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
         9: .line 79
            getstatic org.xnio.Options.TCP_OOB_INLINE:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
        10: .line 80
            getstatic org.xnio.Options.TCP_NODELAY:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
        11: .line 81
            getstatic org.xnio.Options.CONNECTION_HIGH_WATER:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
        12: .line 82
            getstatic org.xnio.Options.CONNECTION_LOW_WATER:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
        13: .line 83
            getstatic org.xnio.Options.READ_TIMEOUT:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
        14: .line 84
            getstatic org.xnio.Options.WRITE_TIMEOUT:Lorg/xnio/Option;
            invokevirtual org.xnio.Option$SetBuilder.add:(Lorg/xnio/Option;)Lorg/xnio/Option$SetBuilder;
        15: .line 85
            invokevirtual org.xnio.Option$SetBuilder.create:()Ljava/util/Set;
        16: .line 74
            putstatic org.xnio.nio.QueuedNioTcpServer.options:Ljava/util/Set;
        17: .line 118
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            ldc "keepAlive"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            putstatic org.xnio.nio.QueuedNioTcpServer.keepAliveUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        18: .line 119
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            ldc "oobInline"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            putstatic org.xnio.nio.QueuedNioTcpServer.oobInlineUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        19: .line 120
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            ldc "tcpNoDelay"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            putstatic org.xnio.nio.QueuedNioTcpServer.tcpNoDelayUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        20: .line 121
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            ldc "sendBuffer"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            putstatic org.xnio.nio.QueuedNioTcpServer.sendBufferUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        21: .line 122
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            ldc "readTimeout"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            putstatic org.xnio.nio.QueuedNioTcpServer.readTimeoutUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        22: .line 123
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            ldc "writeTimeout"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            putstatic org.xnio.nio.QueuedNioTcpServer.writeTimeoutUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        23: .line 125
            ldc Lorg/xnio/nio/QueuedNioTcpServer;
            ldc "connectionStatus"
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            putstatic org.xnio.nio.QueuedNioTcpServer.connectionStatusUpdater:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(org.xnio.nio.NioXnioWorker, java.nio.channels.ServerSocketChannel, org.xnio.OptionMap);
    descriptor: (Lorg/xnio/nio/NioXnioWorker;Ljava/nio/channels/ServerSocketChannel;Lorg/xnio/OptionMap;)V
    flags: (0x0000) 
    Code:
      stack=8, locals=10, args_size=4
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // org.xnio.nio.NioXnioWorker worker
        start local 2 // java.nio.channels.ServerSocketChannel channel
        start local 3 // org.xnio.OptionMap optionMap
         0: .line 151
            aload 0 /* this */
            aload 1 /* worker */
            invokespecial org.xnio.nio.AbstractNioChannel.<init>:(Lorg/xnio/nio/NioXnioWorker;)V
         1: .line 94
            aload 0 /* this */
            iconst_m1
            putfield org.xnio.nio.QueuedNioTcpServer.sendBuffer:I
         2: .line 96
            aload 0 /* this */
            ldc 4611686018427387903
            putfield org.xnio.nio.QueuedNioTcpServer.connectionStatus:J
         3: .line 126
            aload 0 /* this */
            new org.xnio.nio.QueuedNioTcpServer$1
            dup
            aload 0 /* this */
            invokespecial org.xnio.nio.QueuedNioTcpServer$1.<init>:(Lorg/xnio/nio/QueuedNioTcpServer;)V
            putfield org.xnio.nio.QueuedNioTcpServer.acceptTask:Ljava/lang/Runnable;
         4: .line 138
            aload 0 /* this */
            new org.xnio.nio.QueuedNioTcpServer$2
            dup
            aload 0 /* this */
            invokespecial org.xnio.nio.QueuedNioTcpServer$2.<init>:(Lorg/xnio/nio/QueuedNioTcpServer;)V
            putfield org.xnio.nio.QueuedNioTcpServer.connectionClosedTask:Ljava/lang/Runnable;
         5: .line 152
            aload 0 /* this */
            aload 2 /* channel */
            putfield org.xnio.nio.QueuedNioTcpServer.channel:Ljava/nio/channels/ServerSocketChannel;
         6: .line 153
            aload 0 /* this */
            aload 1 /* worker */
            invokevirtual org.xnio.nio.NioXnioWorker.getAcceptThread:()Lorg/xnio/nio/WorkerThread;
            putfield org.xnio.nio.QueuedNioTcpServer.thread:Lorg/xnio/nio/WorkerThread;
         7: .line 154
            aload 1 /* worker */
            invokevirtual org.xnio.nio.NioXnioWorker.getAll:()[Lorg/xnio/nio/WorkerThread;
            astore 4 /* workerThreads */
        start local 4 // org.xnio.nio.WorkerThread[] workerThreads
         8: .line 155
            new java.util.ArrayList
            dup
            aload 4 /* workerThreads */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 5 /* acceptQueues */
        start local 5 // java.util.List acceptQueues
         9: .line 156
            iconst_0
            istore 6 /* i */
        start local 6 // int i
        10: goto 13
        11: .line 157
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.NioXnioWorker java.nio.channels.ServerSocketChannel org.xnio.OptionMap org.xnio.nio.WorkerThread[] java.util.List int
      StackMap stack:
            aload 5 /* acceptQueues */
            iload 6 /* i */
            new java.util.concurrent.LinkedBlockingQueue
            dup
            invokespecial java.util.concurrent.LinkedBlockingQueue.<init>:()V
            invokeinterface java.util.List.add:(ILjava/lang/Object;)V
        12: .line 156
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 6 /* i */
            aload 4 /* workerThreads */
            arraylength
            if_icmplt 11
        end local 6 // int i
        14: .line 159
            aload 0 /* this */
            aload 5 /* acceptQueues */
            putfield org.xnio.nio.QueuedNioTcpServer.acceptQueues:Ljava/util/List;
        15: .line 160
            aload 0 /* this */
            aload 2 /* channel */
            invokevirtual java.nio.channels.ServerSocketChannel.socket:()Ljava/net/ServerSocket;
            putfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
        16: .line 161
            aload 3 /* optionMap */
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 21
        17: .line 162
            aload 3 /* optionMap */
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            ldc 65536
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            istore 6 /* sendBufferSize */
        start local 6 // int sendBufferSize
        18: .line 163
            iload 6 /* sendBufferSize */
            iconst_1
            if_icmpge 20
        19: .line 164
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "sendBufferSize"
            invokeinterface org.xnio.nio.Log.parameterOutOfRange:(Ljava/lang/String;)Ljava/lang/IllegalArgumentException;
            athrow
        20: .line 166
      StackMap locals:
      StackMap stack:
            getstatic org.xnio.nio.QueuedNioTcpServer.sendBufferUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 6 /* sendBufferSize */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.set:(Ljava/lang/Object;I)V
        end local 6 // int sendBufferSize
        21: .line 168
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.KEEP_ALIVE:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 25
        22: .line 169
            getstatic org.xnio.nio.QueuedNioTcpServer.keepAliveUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            aload 3 /* optionMap */
            getstatic org.xnio.Options.KEEP_ALIVE:Lorg/xnio/Option;
            iconst_0
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;Z)Z
            ifeq 23
            iconst_1
            goto 24
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.NioXnioWorker java.nio.channels.ServerSocketChannel org.xnio.OptionMap org.xnio.nio.WorkerThread[] java.util.List
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer
        23: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.NioXnioWorker java.nio.channels.ServerSocketChannel org.xnio.OptionMap org.xnio.nio.WorkerThread[] java.util.List
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer int
        24: invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
        25: .line 171
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.TCP_OOB_INLINE:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 29
        26: .line 172
            getstatic org.xnio.nio.QueuedNioTcpServer.oobInlineUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            aload 3 /* optionMap */
            getstatic org.xnio.Options.TCP_OOB_INLINE:Lorg/xnio/Option;
            iconst_0
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;Z)Z
            ifeq 27
            iconst_1
            goto 28
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.NioXnioWorker java.nio.channels.ServerSocketChannel org.xnio.OptionMap org.xnio.nio.WorkerThread[] java.util.List
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer
        27: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.NioXnioWorker java.nio.channels.ServerSocketChannel org.xnio.OptionMap org.xnio.nio.WorkerThread[] java.util.List
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer int
        28: invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
        29: .line 174
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.TCP_NODELAY:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 33
        30: .line 175
            getstatic org.xnio.nio.QueuedNioTcpServer.tcpNoDelayUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            aload 3 /* optionMap */
            getstatic org.xnio.Options.TCP_NODELAY:Lorg/xnio/Option;
            iconst_0
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;Z)Z
            ifeq 31
            iconst_1
            goto 32
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.NioXnioWorker java.nio.channels.ServerSocketChannel org.xnio.OptionMap org.xnio.nio.WorkerThread[] java.util.List
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer
        31: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.NioXnioWorker java.nio.channels.ServerSocketChannel org.xnio.OptionMap org.xnio.nio.WorkerThread[] java.util.List
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer int
        32: invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
        33: .line 177
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.READ_TIMEOUT:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 35
        34: .line 178
            getstatic org.xnio.nio.QueuedNioTcpServer.readTimeoutUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            aload 3 /* optionMap */
            getstatic org.xnio.Options.READ_TIMEOUT:Lorg/xnio/Option;
            iconst_0
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
        35: .line 180
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.WRITE_TIMEOUT:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 37
        36: .line 181
            getstatic org.xnio.nio.QueuedNioTcpServer.writeTimeoutUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            aload 3 /* optionMap */
            getstatic org.xnio.Options.WRITE_TIMEOUT:Lorg/xnio/Option;
            iconst_0
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
        37: .line 185
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.CONNECTION_HIGH_WATER:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifne 38
            aload 3 /* optionMap */
            getstatic org.xnio.Options.CONNECTION_LOW_WATER:Lorg/xnio/Option;
            invokevirtual org.xnio.OptionMap.contains:(Lorg/xnio/Option;)Z
            ifeq 47
        38: .line 186
      StackMap locals:
      StackMap stack:
            aload 3 /* optionMap */
            getstatic org.xnio.Options.CONNECTION_HIGH_WATER:Lorg/xnio/Option;
            ldc 2147483647
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            istore 6 /* highWater */
        start local 6 // int highWater
        39: .line 187
            aload 3 /* optionMap */
            getstatic org.xnio.Options.CONNECTION_LOW_WATER:Lorg/xnio/Option;
            iload 6 /* highWater */
            invokevirtual org.xnio.OptionMap.get:(Lorg/xnio/Option;I)I
            istore 7 /* lowWater */
        start local 7 // int lowWater
        40: .line 188
            iload 6 /* highWater */
            ifgt 42
        41: .line 189
            invokestatic org.xnio.nio.QueuedNioTcpServer.badHighWater:()Ljava/lang/IllegalArgumentException;
            athrow
        42: .line 191
      StackMap locals: int int
      StackMap stack:
            iload 7 /* lowWater */
            ifle 43
            iload 7 /* lowWater */
            iload 6 /* highWater */
            if_icmple 44
        43: .line 192
      StackMap locals:
      StackMap stack:
            iload 6 /* highWater */
            invokestatic org.xnio.nio.QueuedNioTcpServer.badLowWater:(I)Ljava/lang/IllegalArgumentException;
            athrow
        44: .line 194
      StackMap locals:
      StackMap stack:
            iload 6 /* highWater */
            i2l
            bipush 31
            lshl
            iload 7 /* lowWater */
            i2l
            iconst_0
            lshl
            lor
            lstore 8 /* highLowWater */
        start local 8 // long highLowWater
        45: .line 195
            getstatic org.xnio.nio.QueuedNioTcpServer.connectionStatusUpdater:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 8 /* highLowWater */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.lazySet:(Ljava/lang/Object;J)V
        end local 8 // long highLowWater
        46: .line 196
            goto 50
        end local 7 // int lowWater
        end local 6 // int highWater
        47: .line 197
      StackMap locals:
      StackMap stack:
            ldc 2147483647
            istore 6 /* highWater */
        start local 6 // int highWater
        48: .line 198
            ldc 2147483647
            istore 7 /* lowWater */
        start local 7 // int lowWater
        49: .line 199
            getstatic org.xnio.nio.QueuedNioTcpServer.connectionStatusUpdater:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            ldc 4611686018427387903
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.lazySet:(Ljava/lang/Object;J)V
        50: .line 201
      StackMap locals: int int
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.thread:Lorg/xnio/nio/WorkerThread;
            aload 2 /* channel */
            invokevirtual org.xnio.nio.WorkerThread.registerChannel:(Ljava/nio/channels/spi/AbstractSelectableChannel;)Ljava/nio/channels/SelectionKey;
            astore 8 /* key */
        start local 8 // java.nio.channels.SelectionKey key
        51: .line 202
            aload 0 /* this */
            new org.xnio.nio.QueuedNioTcpServerHandle
            dup
            aload 0 /* this */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.thread:Lorg/xnio/nio/WorkerThread;
            aload 8 /* key */
            iload 6 /* highWater */
            iload 7 /* lowWater */
            invokespecial org.xnio.nio.QueuedNioTcpServerHandle.<init>:(Lorg/xnio/nio/QueuedNioTcpServer;Lorg/xnio/nio/WorkerThread;Ljava/nio/channels/SelectionKey;II)V
            putfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
        52: .line 203
            aload 8 /* key */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            invokevirtual java.nio.channels.SelectionKey.attach:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        53: .line 204
            aload 0 /* this */
            aload 1 /* worker */
        54: .line 205
            new org.xnio.nio.QueuedNioTcpServer$3
            dup
            aload 0 /* this */
            aload 1 /* worker */
            invokespecial org.xnio.nio.QueuedNioTcpServer$3.<init>:(Lorg/xnio/nio/QueuedNioTcpServer;Lorg/xnio/nio/NioXnioWorker;)V
        55: .line 204
            invokevirtual org.xnio.nio.NioXnioWorker.registerServerMXBean:(Lorg/xnio/management/XnioServerMXBean;)Lorg/xnio/ManagementRegistration;
            putfield org.xnio.nio.QueuedNioTcpServer.mbeanHandle:Lorg/xnio/ManagementRegistration;
        56: .line 237
            return
        end local 8 // java.nio.channels.SelectionKey key
        end local 7 // int lowWater
        end local 6 // int highWater
        end local 5 // java.util.List acceptQueues
        end local 4 // org.xnio.nio.WorkerThread[] workerThreads
        end local 3 // org.xnio.OptionMap optionMap
        end local 2 // java.nio.channels.ServerSocketChannel channel
        end local 1 // org.xnio.nio.NioXnioWorker worker
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   57     0            this  Lorg/xnio/nio/QueuedNioTcpServer;
            0   57     1          worker  Lorg/xnio/nio/NioXnioWorker;
            0   57     2         channel  Ljava/nio/channels/ServerSocketChannel;
            0   57     3       optionMap  Lorg/xnio/OptionMap;
            8   57     4   workerThreads  [Lorg/xnio/nio/WorkerThread;
            9   57     5    acceptQueues  Ljava/util/List<Ljava/util/concurrent/BlockingQueue<Ljava/nio/channels/SocketChannel;>;>;
           10   14     6               i  I
           18   21     6  sendBufferSize  I
           39   47     6       highWater  I
           48   57     6       highWater  I
           40   47     7        lowWater  I
           49   57     7        lowWater  I
           45   46     8    highLowWater  J
           51   57     8             key  Ljava/nio/channels/SelectionKey;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
           Name  Flags
      worker     final
      channel    final
      optionMap  final

  private static java.lang.IllegalArgumentException badLowWater(int);
    descriptor: (I)Ljava/lang/IllegalArgumentException;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // int highWater
         0: .line 240
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Low water must be greater than 0 and less than or equal to high water ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 0 /* highWater */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            areturn
        end local 0 // int highWater
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0  highWater  I
    MethodParameters:
           Name  Flags
      highWater  final

  private static java.lang.IllegalArgumentException badHighWater();
    descriptor: ()Ljava/lang/IllegalArgumentException;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 244
            new java.lang.IllegalArgumentException
            dup
            ldc "High water must be greater than 0"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void close();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 249
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.channel:Ljava/nio/channels/ServerSocketChannel;
            invokevirtual java.nio.channels.ServerSocketChannel.close:()V
         1: .line 250
            goto 6
      StackMap locals:
      StackMap stack: java.lang.Throwable
         2: astore 1
         3: .line 251
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            iconst_1
            invokevirtual org.xnio.nio.QueuedNioTcpServerHandle.cancelKey:(Z)V
         4: .line 252
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.mbeanHandle:Lorg/xnio/ManagementRegistration;
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/lang/AutoCloseable;)V
         5: .line 253
            aload 1
            athrow
         6: .line 251
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            iconst_1
            invokevirtual org.xnio.nio.QueuedNioTcpServerHandle.cancelKey:(Z)V
         7: .line 252
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.mbeanHandle:Lorg/xnio/ManagementRegistration;
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/lang/AutoCloseable;)V
         8: .line 254
            return
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/xnio/nio/QueuedNioTcpServer;
      Exception table:
        from    to  target  type
           0     2       2  any
    Exceptions:
      throws java.io.IOException

  public boolean supportsOption(org.xnio.Option<?>);
    descriptor: (Lorg/xnio/Option;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // org.xnio.Option option
         0: .line 257
            getstatic org.xnio.nio.QueuedNioTcpServer.options:Ljava/util/Set;
            aload 1 /* option */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // org.xnio.Option option
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/xnio/nio/QueuedNioTcpServer;
            0    1     1  option  Lorg/xnio/Option<*>;
    Signature: (Lorg/xnio/Option<*>;)Z
    MethodParameters:
        Name  Flags
      option  final

  public <T> T getOption(org.xnio.Option<T>);
    descriptor: (Lorg/xnio/Option;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // org.xnio.Option option
         0: .line 261
            aload 1 /* option */
            getstatic org.xnio.Options.REUSE_ADDRESSES:Lorg/xnio/Option;
            if_acmpne 2
         1: .line 262
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.getReuseAddress:()Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
         2: .line 263
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            if_acmpne 4
         3: .line 264
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.getReceiveBufferSize:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
         4: .line 265
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            if_acmpne 9
         5: .line 266
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.sendBuffer:I
            istore 2 /* value */
        start local 2 // int value
         6: .line 267
            iload 2 /* value */
            iconst_m1
            if_icmpne 7
            aconst_null
            goto 8
      StackMap locals: int
      StackMap stack:
         7: aload 1 /* option */
            iload 2 /* value */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
      StackMap locals:
      StackMap stack: java.lang.Object
         8: areturn
        end local 2 // int value
         9: .line 268
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.KEEP_ALIVE:Lorg/xnio/Option;
            if_acmpne 13
        10: .line 269
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.keepAlive:I
            ifeq 11
            iconst_1
            goto 12
      StackMap locals:
      StackMap stack: org.xnio.Option
        11: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option
      StackMap stack: org.xnio.Option int
        12: invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        13: .line 270
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.TCP_OOB_INLINE:Lorg/xnio/Option;
            if_acmpne 17
        14: .line 271
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.oobInline:I
            ifeq 15
            iconst_1
            goto 16
      StackMap locals:
      StackMap stack: org.xnio.Option
        15: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option
      StackMap stack: org.xnio.Option int
        16: invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        17: .line 272
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.TCP_NODELAY:Lorg/xnio/Option;
            if_acmpne 21
        18: .line 273
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.tcpNoDelay:I
            ifeq 19
            iconst_1
            goto 20
      StackMap locals:
      StackMap stack: org.xnio.Option
        19: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option
      StackMap stack: org.xnio.Option int
        20: invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        21: .line 274
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.READ_TIMEOUT:Lorg/xnio/Option;
            if_acmpne 23
        22: .line 275
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.readTimeout:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        23: .line 276
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.WRITE_TIMEOUT:Lorg/xnio/Option;
            if_acmpne 25
        24: .line 277
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.writeTimeout:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        25: .line 278
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.CONNECTION_HIGH_WATER:Lorg/xnio/Option;
            if_acmpne 27
        26: .line 279
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.connectionStatus:J
            invokestatic org.xnio.nio.QueuedNioTcpServer.getHighWater:(J)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        27: .line 280
      StackMap locals:
      StackMap stack:
            aload 1 /* option */
            getstatic org.xnio.Options.CONNECTION_LOW_WATER:Lorg/xnio/Option;
            if_acmpne 29
        28: .line 281
            aload 1 /* option */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.connectionStatus:J
            invokestatic org.xnio.nio.QueuedNioTcpServer.getLowWater:(J)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        29: .line 283
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 1 // org.xnio.Option option
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   30     0    this  Lorg/xnio/nio/QueuedNioTcpServer;
            0   30     1  option  Lorg/xnio/Option<TT;>;
            6    9     2   value  I
    Exceptions:
      throws org.xnio.channels.UnsupportedOptionException, java.io.IOException
    Signature: <T:Ljava/lang/Object;>(Lorg/xnio/Option<TT;>;)TT;
    MethodParameters:
        Name  Flags
      option  final

  public <T> T setOption(org.xnio.Option<T>, );
    descriptor: (Lorg/xnio/Option;Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // org.xnio.Option option
        start local 2 // java.lang.Object value
         0: .line 289
            aload 1 /* option */
            getstatic org.xnio.Options.REUSE_ADDRESSES:Lorg/xnio/Option;
            if_acmpne 4
         1: .line 290
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.getReuseAddress:()Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            astore 3 /* old */
        start local 3 // java.lang.Object old
         2: .line 291
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
            getstatic org.xnio.Options.REUSE_ADDRESSES:Lorg/xnio/Option;
            aload 2 /* value */
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            invokevirtual java.net.ServerSocket.setReuseAddress:(Z)V
         3: .line 292
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
         4: aload 1 /* option */
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            if_acmpne 11
         5: .line 293
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.getReceiveBufferSize:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            astore 3 /* old */
        start local 3 // java.lang.Object old
         6: .line 294
            getstatic org.xnio.Options.RECEIVE_BUFFER:Lorg/xnio/Option;
            aload 2 /* value */
            ldc 65536
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 4 /* newValue */
        start local 4 // int newValue
         7: .line 295
            iload 4 /* newValue */
            iconst_1
            if_icmpge 9
         8: .line 296
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "RECEIVE_BUFFER"
            invokeinterface org.xnio.nio.Log.optionOutOfRange:(Ljava/lang/String;)Ljava/lang/IllegalArgumentException;
            athrow
         9: .line 298
      StackMap locals: java.lang.Object int
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
            iload 4 /* newValue */
            invokevirtual java.net.ServerSocket.setReceiveBufferSize:(I)V
        end local 4 // int newValue
        10: .line 299
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
        11: aload 1 /* option */
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            if_acmpne 20
        12: .line 300
            getstatic org.xnio.Options.SEND_BUFFER:Lorg/xnio/Option;
            aload 2 /* value */
            ldc 65536
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 4 /* newValue */
        start local 4 // int newValue
        13: .line 301
            iload 4 /* newValue */
            iconst_1
            if_icmpge 15
        14: .line 302
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "SEND_BUFFER"
            invokeinterface org.xnio.nio.Log.optionOutOfRange:(Ljava/lang/String;)Ljava/lang/IllegalArgumentException;
            athrow
        15: .line 304
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object top int
      StackMap stack:
            getstatic org.xnio.nio.QueuedNioTcpServer.sendBufferUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 4 /* newValue */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndSet:(Ljava/lang/Object;I)I
            istore 5 /* oldValue */
        start local 5 // int oldValue
        16: .line 305
            iload 5 /* oldValue */
            iconst_m1
            if_icmpne 17
            aconst_null
            goto 18
      StackMap locals: int
      StackMap stack:
        17: iload 5 /* oldValue */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
      StackMap locals:
      StackMap stack: java.lang.Integer
        18: astore 3 /* old */
        end local 5 // int oldValue
        end local 4 // int newValue
        start local 3 // java.lang.Object old
        19: .line 306
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object
      StackMap stack:
        20: aload 1 /* option */
            getstatic org.xnio.Options.KEEP_ALIVE:Lorg/xnio/Option;
            if_acmpne 27
        21: .line 307
            getstatic org.xnio.nio.QueuedNioTcpServer.keepAliveUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            getstatic org.xnio.Options.KEEP_ALIVE:Lorg/xnio/Option;
            aload 2 /* value */
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 22
            iconst_1
            goto 23
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer
        22: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer int
        23: invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndSet:(Ljava/lang/Object;I)I
            ifeq 24
            iconst_1
            goto 25
      StackMap locals:
      StackMap stack:
        24: iconst_0
      StackMap locals:
      StackMap stack: int
        25: invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            astore 3 /* old */
        start local 3 // java.lang.Object old
        26: .line 308
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
        27: aload 1 /* option */
            getstatic org.xnio.Options.TCP_OOB_INLINE:Lorg/xnio/Option;
            if_acmpne 34
        28: .line 309
            getstatic org.xnio.nio.QueuedNioTcpServer.oobInlineUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            getstatic org.xnio.Options.TCP_OOB_INLINE:Lorg/xnio/Option;
            aload 2 /* value */
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 29
            iconst_1
            goto 30
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer
        29: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer int
        30: invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndSet:(Ljava/lang/Object;I)I
            ifeq 31
            iconst_1
            goto 32
      StackMap locals:
      StackMap stack:
        31: iconst_0
      StackMap locals:
      StackMap stack: int
        32: invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            astore 3 /* old */
        start local 3 // java.lang.Object old
        33: .line 310
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
        34: aload 1 /* option */
            getstatic org.xnio.Options.TCP_NODELAY:Lorg/xnio/Option;
            if_acmpne 41
        35: .line 311
            getstatic org.xnio.nio.QueuedNioTcpServer.tcpNoDelayUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            getstatic org.xnio.Options.TCP_NODELAY:Lorg/xnio/Option;
            aload 2 /* value */
            getstatic java.lang.Boolean.FALSE:Ljava/lang/Boolean;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 36
            iconst_1
            goto 37
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer
        36: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.Option java.lang.Object
      StackMap stack: java.util.concurrent.atomic.AtomicIntegerFieldUpdater org.xnio.nio.QueuedNioTcpServer int
        37: invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndSet:(Ljava/lang/Object;I)I
            ifeq 38
            iconst_1
            goto 39
      StackMap locals:
      StackMap stack:
        38: iconst_0
      StackMap locals:
      StackMap stack: int
        39: invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            astore 3 /* old */
        start local 3 // java.lang.Object old
        40: .line 312
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
        41: aload 1 /* option */
            getstatic org.xnio.Options.READ_TIMEOUT:Lorg/xnio/Option;
            if_acmpne 44
        42: .line 313
            getstatic org.xnio.nio.QueuedNioTcpServer.readTimeoutUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            getstatic org.xnio.Options.READ_TIMEOUT:Lorg/xnio/Option;
            aload 2 /* value */
            iconst_0
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndSet:(Ljava/lang/Object;I)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            astore 3 /* old */
        start local 3 // java.lang.Object old
        43: .line 314
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
        44: aload 1 /* option */
            getstatic org.xnio.Options.WRITE_TIMEOUT:Lorg/xnio/Option;
            if_acmpne 47
        45: .line 315
            getstatic org.xnio.nio.QueuedNioTcpServer.writeTimeoutUpdater:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            getstatic org.xnio.Options.WRITE_TIMEOUT:Lorg/xnio/Option;
            aload 2 /* value */
            iconst_0
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndSet:(Ljava/lang/Object;I)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            astore 3 /* old */
        start local 3 // java.lang.Object old
        46: .line 316
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
        47: aload 1 /* option */
            getstatic org.xnio.Options.CONNECTION_HIGH_WATER:Lorg/xnio/Option;
            if_acmpne 50
        48: .line 317
            aload 0 /* this */
            iconst_m1
            getstatic org.xnio.Options.CONNECTION_HIGH_WATER:Lorg/xnio/Option;
            aload 2 /* value */
            ldc 2147483647
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            invokevirtual org.xnio.nio.QueuedNioTcpServer.updateWaterMark:(II)J
            invokestatic org.xnio.nio.QueuedNioTcpServer.getHighWater:(J)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            astore 3 /* old */
        start local 3 // java.lang.Object old
        49: .line 318
            goto 54
        end local 3 // java.lang.Object old
      StackMap locals:
      StackMap stack:
        50: aload 1 /* option */
            getstatic org.xnio.Options.CONNECTION_LOW_WATER:Lorg/xnio/Option;
            if_acmpne 53
        51: .line 319
            aload 0 /* this */
            getstatic org.xnio.Options.CONNECTION_LOW_WATER:Lorg/xnio/Option;
            aload 2 /* value */
            ldc 2147483647
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            iconst_m1
            invokevirtual org.xnio.nio.QueuedNioTcpServer.updateWaterMark:(II)J
            invokestatic org.xnio.nio.QueuedNioTcpServer.getLowWater:(J)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            astore 3 /* old */
        start local 3 // java.lang.Object old
        52: .line 320
            goto 54
        end local 3 // java.lang.Object old
        53: .line 321
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        start local 3 // java.lang.Object old
        54: .line 323
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 1 /* option */
            aload 3 /* old */
            invokevirtual org.xnio.Option.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 3 // java.lang.Object old
        end local 2 // java.lang.Object value
        end local 1 // org.xnio.Option option
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   55     0      this  Lorg/xnio/nio/QueuedNioTcpServer;
            0   55     1    option  Lorg/xnio/Option<TT;>;
            0   55     2     value  TT;
            2    4     3       old  Ljava/lang/Object;
            6   11     3       old  Ljava/lang/Object;
           19   20     3       old  Ljava/lang/Object;
           26   27     3       old  Ljava/lang/Object;
           33   34     3       old  Ljava/lang/Object;
           40   41     3       old  Ljava/lang/Object;
           43   44     3       old  Ljava/lang/Object;
           46   47     3       old  Ljava/lang/Object;
           49   50     3       old  Ljava/lang/Object;
           52   53     3       old  Ljava/lang/Object;
           54   55     3       old  Ljava/lang/Object;
            7   10     4  newValue  I
           13   19     4  newValue  I
           16   19     5  oldValue  I
    Exceptions:
      throws java.lang.IllegalArgumentException, java.io.IOException
    Signature: <T:Ljava/lang/Object;>(Lorg/xnio/Option<TT;>;TT;)TT;
    MethodParameters:
        Name  Flags
      option  final
      value   final

  private long updateWaterMark(int, int);
    descriptor: (II)J
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=11, args_size=3
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // int reqNewLowWater
        start local 2 // int reqNewHighWater
         0: .line 328
            getstatic org.xnio.nio.QueuedNioTcpServer.$assertionsDisabled:Z
            ifne 1
            iload 1 /* reqNewLowWater */
            iconst_m1
            if_icmpne 1
            iload 2 /* reqNewHighWater */
            iconst_m1
            if_icmpne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 330
      StackMap locals:
      StackMap stack:
            getstatic org.xnio.nio.QueuedNioTcpServer.$assertionsDisabled:Z
            ifne 2
            iload 1 /* reqNewLowWater */
            iconst_m1
            if_icmpeq 2
            iload 2 /* reqNewHighWater */
            iconst_m1
            if_icmpeq 2
            iload 1 /* reqNewLowWater */
            iload 2 /* reqNewHighWater */
            if_icmple 2
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 337
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.connectionStatus:J
            lstore 3 /* oldVal */
        start local 3 // long oldVal
         3: .line 338
            lload 3 /* oldVal */
            invokestatic org.xnio.nio.QueuedNioTcpServer.getLowWater:(J)I
            istore 8 /* oldLowWater */
        start local 8 // int oldLowWater
         4: .line 339
            lload 3 /* oldVal */
            invokestatic org.xnio.nio.QueuedNioTcpServer.getHighWater:(J)I
            istore 7 /* oldHighWater */
        start local 7 // int oldHighWater
         5: .line 340
            iload 1 /* reqNewLowWater */
            iconst_m1
            if_icmpne 6
            iload 8 /* oldLowWater */
            goto 7
      StackMap locals: org.xnio.nio.QueuedNioTcpServer int int long top top int int
      StackMap stack:
         6: iload 1 /* reqNewLowWater */
      StackMap locals:
      StackMap stack: int
         7: istore 9 /* newLowWater */
        start local 9 // int newLowWater
         8: .line 341
            iload 2 /* reqNewHighWater */
            iconst_m1
            if_icmpne 9
            iload 7 /* oldHighWater */
            goto 10
      StackMap locals: int
      StackMap stack:
         9: iload 2 /* reqNewHighWater */
      StackMap locals:
      StackMap stack: int
        10: istore 10 /* newHighWater */
        start local 10 // int newHighWater
        11: .line 343
            iload 1 /* reqNewLowWater */
            iconst_m1
            if_icmpeq 14
            iload 9 /* newLowWater */
            iload 10 /* newHighWater */
            if_icmple 14
        12: .line 344
            iload 9 /* newLowWater */
            istore 10 /* newHighWater */
        13: .line 345
            goto 16
      StackMap locals: int
      StackMap stack:
        14: iload 2 /* reqNewHighWater */
            iconst_m1
            if_icmpeq 16
            iload 10 /* newHighWater */
            iload 9 /* newLowWater */
            if_icmpge 16
        15: .line 346
            iload 10 /* newHighWater */
            istore 9 /* newLowWater */
        16: .line 349
      StackMap locals:
      StackMap stack:
            iload 8 /* oldLowWater */
            iload 9 /* newLowWater */
            if_icmpne 18
            iload 7 /* oldHighWater */
            iload 10 /* newHighWater */
            if_icmpne 18
        17: .line 350
            lload 3 /* oldVal */
            lreturn
        18: .line 352
      StackMap locals:
      StackMap stack:
            iload 9 /* newLowWater */
            i2l
            iconst_0
            lshl
            iload 10 /* newHighWater */
            i2l
            bipush 31
            lshl
            lor
            lstore 5 /* newVal */
        start local 5 // long newVal
        19: .line 353
            getstatic org.xnio.nio.QueuedNioTcpServer.connectionStatusUpdater:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 3 /* oldVal */
            lload 5 /* newVal */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.compareAndSet:(Ljava/lang/Object;JJ)Z
            ifeq 2
        20: .line 354
            aload 0 /* this */
            invokevirtual org.xnio.nio.QueuedNioTcpServer.getIoThread:()Lorg/xnio/XnioIoThread;
            new org.xnio.nio.QueuedNioTcpServer$4
            dup
            aload 0 /* this */
            invokespecial org.xnio.nio.QueuedNioTcpServer$4.<init>:(Lorg/xnio/nio/QueuedNioTcpServer;)V
            invokevirtual org.xnio.XnioIoThread.execute:(Ljava/lang/Runnable;)V
        21: .line 367
            lload 3 /* oldVal */
            lreturn
        end local 10 // int newHighWater
        end local 9 // int newLowWater
        end local 8 // int oldLowWater
        end local 7 // int oldHighWater
        end local 5 // long newVal
        end local 3 // long oldVal
        end local 2 // int reqNewHighWater
        end local 1 // int reqNewLowWater
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   22     0             this  Lorg/xnio/nio/QueuedNioTcpServer;
            0   22     1   reqNewLowWater  I
            0   22     2  reqNewHighWater  I
            3   22     3           oldVal  J
           19   22     5           newVal  J
            5   22     7     oldHighWater  I
            4   22     8      oldLowWater  I
            8   22     9      newLowWater  I
           11   22    10     newHighWater  I
    MethodParameters:
                 Name  Flags
      reqNewLowWater   
      reqNewHighWater  

  private static int getHighWater(long);
    descriptor: (J)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // long value
         0: .line 371
            lload 0 /* value */
            ldc 4611686016279904256
            land
            bipush 31
            lshr
            l2i
            ireturn
        end local 0 // long value
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0  value  J
    MethodParameters:
       Name  Flags
      value  final

  private static int getLowWater(long);
    descriptor: (J)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // long value
         0: .line 375
            lload 0 /* value */
            ldc 2147483647
            land
            iconst_0
            lshr
            l2i
            ireturn
        end local 0 // long value
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0  value  J
    MethodParameters:
       Name  Flags
      value  final

  public org.xnio.nio.NioSocketStreamConnection accept();
    descriptor: ()Lorg/xnio/nio/NioSocketStreamConnection;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=9, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 379
            invokestatic org.xnio.nio.WorkerThread.getCurrent:()Lorg/xnio/nio/WorkerThread;
            astore 1 /* current */
        start local 1 // org.xnio.nio.WorkerThread current
         1: .line 380
            aload 1 /* current */
            ifnonnull 3
         2: .line 381
            aconst_null
            areturn
         3: .line 383
      StackMap locals: org.xnio.nio.WorkerThread
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.acceptQueues:Ljava/util/List;
            aload 1 /* current */
            invokevirtual org.xnio.nio.WorkerThread.getNumber:()I
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.util.concurrent.BlockingQueue
            astore 2 /* socketChannels */
        start local 2 // java.util.concurrent.BlockingQueue socketChannels
         4: .line 385
            iconst_0
            istore 4 /* ok */
        start local 4 // boolean ok
         5: .line 387
            aload 2 /* socketChannels */
            invokeinterface java.util.concurrent.BlockingQueue.poll:()Ljava/lang/Object;
            checkcast java.nio.channels.SocketChannel
            astore 3 /* accepted */
        start local 3 // java.nio.channels.SocketChannel accepted
         6: .line 388
            aload 3 /* accepted */
            ifnull 24
         7: .line 389
            aload 1 /* current */
            aload 3 /* accepted */
            invokevirtual org.xnio.nio.WorkerThread.registerChannel:(Ljava/nio/channels/spi/AbstractSelectableChannel;)Ljava/nio/channels/SelectionKey;
            astore 5 /* selectionKey */
        start local 5 // java.nio.channels.SelectionKey selectionKey
         8: .line 390
            new org.xnio.nio.NioSocketStreamConnection
            dup
            aload 1 /* current */
            aload 5 /* selectionKey */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            invokespecial org.xnio.nio.NioSocketStreamConnection.<init>:(Lorg/xnio/nio/WorkerThread;Ljava/nio/channels/SelectionKey;Lorg/xnio/nio/ChannelClosed;)V
            astore 6 /* newConnection */
        start local 6 // org.xnio.nio.NioSocketStreamConnection newConnection
         9: .line 391
            aload 6 /* newConnection */
            getstatic org.xnio.Options.READ_TIMEOUT:Lorg/xnio/Option;
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.readTimeout:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.nio.NioSocketStreamConnection.setOption:(Lorg/xnio/Option;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        10: .line 392
            aload 6 /* newConnection */
            getstatic org.xnio.Options.WRITE_TIMEOUT:Lorg/xnio/Option;
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.writeTimeout:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual org.xnio.nio.NioSocketStreamConnection.setOption:(Lorg/xnio/Option;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        11: .line 393
            iconst_1
            istore 4 /* ok */
        12: .line 394
            aload 6 /* newConnection */
            astore 8
        13: .line 396
            iload 4 /* ok */
            ifne 16
        14: .line 397
            aload 3 /* accepted */
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
        15: .line 398
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            invokevirtual org.xnio.nio.QueuedNioTcpServerHandle.freeConnection:()V
        16: .line 394
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.WorkerThread java.util.concurrent.BlockingQueue java.nio.channels.SocketChannel int java.nio.channels.SelectionKey org.xnio.nio.NioSocketStreamConnection top org.xnio.nio.NioSocketStreamConnection
      StackMap stack:
            aload 8
            areturn
        end local 6 // org.xnio.nio.NioSocketStreamConnection newConnection
        end local 5 // java.nio.channels.SelectionKey selectionKey
        17: .line 395
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.WorkerThread java.util.concurrent.BlockingQueue java.nio.channels.SocketChannel int
      StackMap stack: java.lang.Throwable
            astore 7
        18: .line 396
            iload 4 /* ok */
            ifne 21
        19: .line 397
            aload 3 /* accepted */
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
        20: .line 398
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            invokevirtual org.xnio.nio.QueuedNioTcpServerHandle.freeConnection:()V
        21: .line 400
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.WorkerThread java.util.concurrent.BlockingQueue java.nio.channels.SocketChannel int top top java.lang.Throwable
      StackMap stack:
            aload 7
            athrow
        end local 3 // java.nio.channels.SocketChannel accepted
        22: .line 401
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.WorkerThread java.util.concurrent.BlockingQueue top int
      StackMap stack: java.io.IOException
            pop
        23: .line 402
            aconst_null
            areturn
        start local 3 // java.nio.channels.SocketChannel accepted
        24: .line 405
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.WorkerThread java.util.concurrent.BlockingQueue java.nio.channels.SocketChannel int
      StackMap stack:
            aconst_null
            areturn
        end local 4 // boolean ok
        end local 3 // java.nio.channels.SocketChannel accepted
        end local 2 // java.util.concurrent.BlockingQueue socketChannels
        end local 1 // org.xnio.nio.WorkerThread current
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   25     0            this  Lorg/xnio/nio/QueuedNioTcpServer;
            1   25     1         current  Lorg/xnio/nio/WorkerThread;
            4   25     2  socketChannels  Ljava/util/concurrent/BlockingQueue<Ljava/nio/channels/SocketChannel;>;
            6   22     3        accepted  Ljava/nio/channels/SocketChannel;
           24   25     3        accepted  Ljava/nio/channels/SocketChannel;
            5   25     4              ok  Z
            8   17     5    selectionKey  Ljava/nio/channels/SelectionKey;
            9   17     6   newConnection  Lorg/xnio/nio/NioSocketStreamConnection;
      Exception table:
        from    to  target  type
           7    13      17  any
           5    16      22  Class java.io.IOException
          17    22      22  Class java.io.IOException
    Exceptions:
      throws java.io.IOException

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 409
            ldc "TCP server (NIO) <%s>"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            invokevirtual java.lang.Object.hashCode:()I
            invokestatic java.lang.Integer.toHexString:(I)Ljava/lang/String;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/QueuedNioTcpServer;

  public org.xnio.ChannelListener<? super org.xnio.nio.QueuedNioTcpServer> getAcceptListener();
    descriptor: ()Lorg/xnio/ChannelListener;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 413
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.acceptListener:Lorg/xnio/ChannelListener;
            areturn
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/QueuedNioTcpServer;
    Signature: ()Lorg/xnio/ChannelListener<-Lorg/xnio/nio/QueuedNioTcpServer;>;

  public void setAcceptListener(org.xnio.ChannelListener<? super org.xnio.nio.QueuedNioTcpServer>);
    descriptor: (Lorg/xnio/ChannelListener;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // org.xnio.ChannelListener acceptListener
         0: .line 417
            aload 0 /* this */
            aload 1 /* acceptListener */
            putfield org.xnio.nio.QueuedNioTcpServer.acceptListener:Lorg/xnio/ChannelListener;
         1: .line 418
            return
        end local 1 // org.xnio.ChannelListener acceptListener
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/xnio/nio/QueuedNioTcpServer;
            0    2     1  acceptListener  Lorg/xnio/ChannelListener<-Lorg/xnio/nio/QueuedNioTcpServer;>;
    Signature: (Lorg/xnio/ChannelListener<-Lorg/xnio/nio/QueuedNioTcpServer;>;)V
    MethodParameters:
                Name  Flags
      acceptListener  final

  public org.xnio.ChannelListener$Setter<org.xnio.nio.QueuedNioTcpServer> getAcceptSetter();
    descriptor: ()Lorg/xnio/ChannelListener$Setter;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 421
            new org.xnio.channels.AcceptListenerSettable$Setter
            dup
            aload 0 /* this */
            invokespecial org.xnio.channels.AcceptListenerSettable$Setter.<init>:(Lorg/xnio/channels/AcceptListenerSettable;)V
            areturn
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/QueuedNioTcpServer;
    Signature: ()Lorg/xnio/ChannelListener$Setter<Lorg/xnio/nio/QueuedNioTcpServer;>;

  public boolean isOpen();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 425
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.channel:Ljava/nio/channels/ServerSocketChannel;
            invokevirtual java.nio.channels.ServerSocketChannel.isOpen:()Z
            ireturn
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/QueuedNioTcpServer;

  public java.net.SocketAddress getLocalAddress();
    descriptor: ()Ljava/net/SocketAddress;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 429
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.socket:Ljava/net/ServerSocket;
            invokevirtual java.net.ServerSocket.getLocalSocketAddress:()Ljava/net/SocketAddress;
            areturn
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/QueuedNioTcpServer;

  public <A extends java.net.SocketAddress> A getLocalAddress(java.lang.Class<A>);
    descriptor: (Ljava/lang/Class;)Ljava/net/SocketAddress;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // java.lang.Class type
         0: .line 433
            aload 0 /* this */
            invokevirtual org.xnio.nio.QueuedNioTcpServer.getLocalAddress:()Ljava/net/SocketAddress;
            astore 2 /* address */
        start local 2 // java.net.SocketAddress address
         1: .line 434
            aload 1 /* type */
            aload 2 /* address */
            invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
            ifeq 2
            aload 1 /* type */
            aload 2 /* address */
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.net.SocketAddress
            goto 3
      StackMap locals: java.net.SocketAddress
      StackMap stack:
         2: aconst_null
      StackMap locals:
      StackMap stack: java.net.SocketAddress
         3: areturn
        end local 2 // java.net.SocketAddress address
        end local 1 // java.lang.Class type
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lorg/xnio/nio/QueuedNioTcpServer;
            0    4     1     type  Ljava/lang/Class<TA;>;
            1    4     2  address  Ljava/net/SocketAddress;
    Signature: <A:Ljava/net/SocketAddress;>(Ljava/lang/Class<TA;>;)TA;
    MethodParameters:
      Name  Flags
      type  final

  public void suspendAccepts();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 438
            aload 0 /* this */
            dup
            astore 1
            monitorenter
         1: .line 439
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            bipush 16
            invokevirtual org.xnio.nio.QueuedNioTcpServerHandle.suspend:(I)V
         2: .line 440
            aload 0 /* this */
            iconst_1
            putfield org.xnio.nio.QueuedNioTcpServer.suspended:Z
         3: .line 438
            aload 1
            monitorexit
         4: goto 7
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.QueuedNioTcpServer
      StackMap stack: java.lang.Throwable
         5: aload 1
            monitorexit
         6: athrow
         7: .line 442
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/xnio/nio/QueuedNioTcpServer;
      Exception table:
        from    to  target  type
           1     4       5  any
           5     6       5  any

  public void resumeAccepts();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 445
            aload 0 /* this */
            dup
            astore 1
            monitorenter
         1: .line 446
            aload 0 /* this */
            iconst_0
            putfield org.xnio.nio.QueuedNioTcpServer.suspended:Z
         2: .line 447
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            bipush 16
            invokevirtual org.xnio.nio.QueuedNioTcpServerHandle.resume:(I)V
         3: .line 445
            aload 1
            monitorexit
         4: goto 7
      StackMap locals: org.xnio.nio.QueuedNioTcpServer org.xnio.nio.QueuedNioTcpServer
      StackMap stack: java.lang.Throwable
         5: aload 1
            monitorexit
         6: athrow
         7: .line 449
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/xnio/nio/QueuedNioTcpServer;
      Exception table:
        from    to  target  type
           1     4       5  any
           5     6       5  any

  public boolean isAcceptResumed();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 452
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.suspended:Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_1
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/xnio/nio/QueuedNioTcpServer;

  public void wakeupAccepts();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 456
            getstatic org.xnio.nio.Log.tcpServerLog:Lorg/xnio/nio/Log;
            getstatic org.xnio.nio.QueuedNioTcpServer.FQCN:Ljava/lang/String;
            getstatic org.jboss.logging.Logger$Level.TRACE:Lorg/jboss/logging/Logger$Level;
            aconst_null
            ldc "Wake up accepts on %s"
            aload 0 /* this */
            invokeinterface org.xnio.nio.Log.logf:(Ljava/lang/String;Lorg/jboss/logging/Logger$Level;Ljava/lang/Throwable;Ljava/lang/String;Ljava/lang/Object;)V
         1: .line 457
            aload 0 /* this */
            invokevirtual org.xnio.nio.QueuedNioTcpServer.resumeAccepts:()V
         2: .line 458
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.handle:Lorg/xnio/nio/QueuedNioTcpServerHandle;
            bipush 16
            invokevirtual org.xnio.nio.QueuedNioTcpServerHandle.wakeup:(I)V
         3: .line 459
            return
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/xnio/nio/QueuedNioTcpServer;

  public void awaitAcceptable();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 462
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "awaitAcceptable"
            invokeinterface org.xnio.nio.Log.unsupported:(Ljava/lang/String;)Ljava/lang/UnsupportedOperationException;
            athrow
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/QueuedNioTcpServer;
    Exceptions:
      throws java.io.IOException

  public void awaitAcceptable(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
        start local 1 // long time
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 466
            getstatic org.xnio.nio.Log.log:Lorg/xnio/nio/Log;
            ldc "awaitAcceptable"
            invokeinterface org.xnio.nio.Log.unsupported:(Ljava/lang/String;)Ljava/lang/UnsupportedOperationException;
            athrow
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long time
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/xnio/nio/QueuedNioTcpServer;
            0    1     1      time  J
            0    1     3  timeUnit  Ljava/util/concurrent/TimeUnit;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
          Name  Flags
      time      final
      timeUnit  final

  public org.xnio.XnioExecutor getAcceptThread();
    descriptor: ()Lorg/xnio/XnioExecutor;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 471
            aload 0 /* this */
            invokevirtual org.xnio.nio.QueuedNioTcpServer.getIoThread:()Lorg/xnio/XnioIoThread;
            areturn
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/xnio/nio/QueuedNioTcpServer;
    RuntimeVisibleAnnotations: 
      java.lang.Deprecated()

  void handleReady();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=7, locals=13, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 477
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.channel:Ljava/nio/channels/ServerSocketChannel;
            invokevirtual java.nio.channels.ServerSocketChannel.accept:()Ljava/nio/channels/SocketChannel;
            astore 1 /* accepted */
        start local 1 // java.nio.channels.SocketChannel accepted
         1: .line 478
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.suspendedDueToWatermark:Z
            ifeq 9
         2: .line 479
            getstatic org.xnio.nio.Log.tcpServerLog:Lorg/xnio/nio/Log;
            getstatic org.xnio.nio.QueuedNioTcpServer.FQCN:Ljava/lang/String;
            getstatic org.jboss.logging.Logger$Level.DEBUG:Lorg/jboss/logging/Logger$Level;
            aconst_null
            ldc "Exceeding connection high water limit (%s). Closing this new accepting request %s"
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.connectionStatus:J
            invokestatic org.xnio.nio.QueuedNioTcpServer.getHighWater:(J)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 1 /* accepted */
            invokeinterface org.xnio.nio.Log.logf:(Ljava/lang/String;Lorg/jboss/logging/Logger$Level;Ljava/lang/Throwable;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 480
            aload 1 /* accepted */
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
         4: .line 481
            return
        end local 1 // java.nio.channels.SocketChannel accepted
         5: .line 483
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 2 /* e */
        start local 2 // java.io.IOException e
         6: .line 484
            getstatic org.xnio.nio.Log.tcpServerLog:Lorg/xnio/nio/Log;
            getstatic org.xnio.nio.QueuedNioTcpServer.FQCN:Ljava/lang/String;
            getstatic org.jboss.logging.Logger$Level.DEBUG:Lorg/jboss/logging/Logger$Level;
            aload 2 /* e */
            ldc "Exception accepting request, closing server channel %s"
            aload 0 /* this */
            invokeinterface org.xnio.nio.Log.logf:(Ljava/lang/String;Lorg/jboss/logging/Logger$Level;Ljava/lang/Throwable;Ljava/lang/String;Ljava/lang/Object;)V
         7: .line 485
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.channel:Ljava/nio/channels/ServerSocketChannel;
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
         8: .line 486
            return
        end local 2 // java.io.IOException e
        start local 1 // java.nio.channels.SocketChannel accepted
         9: .line 489
      StackMap locals: java.nio.channels.SocketChannel
      StackMap stack:
            iconst_0
            istore 2 /* ok */
        start local 2 // boolean ok
        10: .line 490
            aload 1 /* accepted */
            ifnull 63
        11: .line 491
            aload 1 /* accepted */
            invokevirtual java.nio.channels.SocketChannel.getLocalAddress:()Ljava/net/SocketAddress;
            astore 3 /* localAddress */
        start local 3 // java.net.SocketAddress localAddress
        12: .line 493
            aload 3 /* localAddress */
            instanceof java.net.InetSocketAddress
            ifeq 16
        13: .line 494
            aload 3 /* localAddress */
            checkcast java.net.InetSocketAddress
            astore 5 /* address */
        start local 5 // java.net.InetSocketAddress address
        14: .line 495
            aload 5 /* address */
            invokevirtual java.net.InetSocketAddress.getAddress:()Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.hashCode:()I
            bipush 23
            imul
            aload 5 /* address */
            invokevirtual java.net.InetSocketAddress.getPort:()I
            iadd
            istore 4 /* hash */
        end local 5 // java.net.InetSocketAddress address
        start local 4 // int hash
        15: .line 496
            goto 20
        end local 4 // int hash
      StackMap locals: int java.net.SocketAddress
      StackMap stack:
        16: aload 3 /* localAddress */
            instanceof org.xnio.LocalSocketAddress
            ifeq 19
        17: .line 497
            aload 3 /* localAddress */
            checkcast org.xnio.LocalSocketAddress
            invokevirtual org.xnio.LocalSocketAddress.getName:()Ljava/lang/String;
            invokevirtual java.lang.String.hashCode:()I
            istore 4 /* hash */
        start local 4 // int hash
        18: .line 498
            goto 20
        end local 4 // int hash
        19: .line 499
      StackMap locals:
      StackMap stack:
            aload 3 /* localAddress */
            invokevirtual java.lang.Object.hashCode:()I
            istore 4 /* hash */
        start local 4 // int hash
        20: .line 501
      StackMap locals: int
      StackMap stack:
            aload 1 /* accepted */
            invokevirtual java.nio.channels.SocketChannel.getRemoteAddress:()Ljava/net/SocketAddress;
            astore 5 /* remoteAddress */
        start local 5 // java.net.SocketAddress remoteAddress
        21: .line 502
            aload 5 /* remoteAddress */
            instanceof java.net.InetSocketAddress
            ifeq 25
        22: .line 503
            aload 5 /* remoteAddress */
            checkcast java.net.InetSocketAddress
            astore 6 /* address */
        start local 6 // java.net.InetSocketAddress address
        23: .line 504
            aload 6 /* address */
            invokevirtual java.net.InetSocketAddress.getAddress:()Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.hashCode:()I
            bipush 23
            imul
            aload 6 /* address */
            invokevirtual java.net.InetSocketAddress.getPort:()I
            iadd
            bipush 23
            imul
            iload 4 /* hash */
            iadd
            istore 4 /* hash */
        end local 6 // java.net.InetSocketAddress address
        24: .line 505
            goto 29
      StackMap locals: java.net.SocketAddress
      StackMap stack:
        25: aload 5 /* remoteAddress */
            instanceof org.xnio.LocalSocketAddress
            ifeq 28
        26: .line 506
            aload 5 /* remoteAddress */
            checkcast org.xnio.LocalSocketAddress
            invokevirtual org.xnio.LocalSocketAddress.getName:()Ljava/lang/String;
            invokevirtual java.lang.String.hashCode:()I
            bipush 23
            imul
            iload 4 /* hash */
            iadd
            istore 4 /* hash */
        27: .line 507
            goto 29
        28: .line 508
      StackMap locals:
      StackMap stack:
            aload 3 /* localAddress */
            invokevirtual java.lang.Object.hashCode:()I
            bipush 23
            imul
            iload 4 /* hash */
            iadd
            istore 4 /* hash */
        29: .line 510
      StackMap locals:
      StackMap stack:
            aload 1 /* accepted */
            iconst_0
            invokevirtual java.nio.channels.SocketChannel.configureBlocking:(Z)Ljava/nio/channels/SelectableChannel;
            pop
        30: .line 511
            aload 1 /* accepted */
            invokevirtual java.nio.channels.SocketChannel.socket:()Ljava/net/Socket;
            astore 6 /* socket */
        start local 6 // java.net.Socket socket
        31: .line 512
            aload 6 /* socket */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.keepAlive:I
            ifeq 32
            iconst_1
            goto 33
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int java.net.SocketAddress int java.net.SocketAddress java.net.Socket
      StackMap stack: java.net.Socket
        32: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int java.net.SocketAddress int java.net.SocketAddress java.net.Socket
      StackMap stack: java.net.Socket int
        33: invokevirtual java.net.Socket.setKeepAlive:(Z)V
        34: .line 513
            aload 6 /* socket */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.oobInline:I
            ifeq 35
            iconst_1
            goto 36
      StackMap locals:
      StackMap stack: java.net.Socket
        35: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int java.net.SocketAddress int java.net.SocketAddress java.net.Socket
      StackMap stack: java.net.Socket int
        36: invokevirtual java.net.Socket.setOOBInline:(Z)V
        37: .line 514
            aload 6 /* socket */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.tcpNoDelay:I
            ifeq 38
            iconst_1
            goto 39
      StackMap locals:
      StackMap stack: java.net.Socket
        38: iconst_0
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int java.net.SocketAddress int java.net.SocketAddress java.net.Socket
      StackMap stack: java.net.Socket int
        39: invokevirtual java.net.Socket.setTcpNoDelay:(Z)V
        40: .line 515
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.sendBuffer:I
            istore 7 /* sendBuffer */
        start local 7 // int sendBuffer
        41: .line 516
            iload 7 /* sendBuffer */
            ifle 42
            aload 6 /* socket */
            iload 7 /* sendBuffer */
            invokevirtual java.net.Socket.setSendBufferSize:(I)V
        42: .line 517
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.worker:Lorg/xnio/nio/NioXnioWorker;
            iload 4 /* hash */
            invokevirtual org.xnio.nio.NioXnioWorker.getIoThread:(I)Lorg/xnio/nio/WorkerThread;
            astore 8 /* ioThread */
        start local 8 // org.xnio.nio.WorkerThread ioThread
        43: .line 518
            iconst_1
            istore 2 /* ok */
        44: .line 519
            aload 8 /* ioThread */
            invokevirtual org.xnio.nio.WorkerThread.getNumber:()I
            istore 9 /* number */
        start local 9 // int number
        45: .line 520
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.acceptQueues:Ljava/util/List;
            iload 9 /* number */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.util.concurrent.BlockingQueue
            astore 10 /* queue */
        start local 10 // java.util.concurrent.BlockingQueue queue
        46: .line 521
            aload 10 /* queue */
            aload 1 /* accepted */
            invokeinterface java.util.concurrent.BlockingQueue.add:(Ljava/lang/Object;)Z
            pop
        47: .line 523
            aload 8 /* ioThread */
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.acceptTask:Ljava/lang/Runnable;
            invokevirtual org.xnio.nio.WorkerThread.execute:(Ljava/lang/Runnable;)V
        48: .line 524
            aload 0 /* this */
            dup
            getfield org.xnio.nio.QueuedNioTcpServer.openConnections:I
            iconst_1
            iadd
            putfield org.xnio.nio.QueuedNioTcpServer.openConnections:I
        49: .line 525
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.openConnections:I
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.connectionStatus:J
            invokestatic org.xnio.nio.QueuedNioTcpServer.getHighWater:(J)I
            if_icmplt 60
        50: .line 526
            aload 0 /* this */
            dup
            astore 11
            monitorenter
        51: .line 527
            aload 0 /* this */
            iconst_1
            putfield org.xnio.nio.QueuedNioTcpServer.suspendedDueToWatermark:Z
        52: .line 528
            getstatic org.xnio.nio.Log.tcpServerLog:Lorg/xnio/nio/Log;
            getstatic org.xnio.nio.QueuedNioTcpServer.FQCN:Ljava/lang/String;
            getstatic org.jboss.logging.Logger$Level.DEBUG:Lorg/jboss/logging/Logger$Level;
            aconst_null
            ldc "Total open connections reach high water limit (%s) by this new accepting request %s"
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.connectionStatus:J
            invokestatic org.xnio.nio.QueuedNioTcpServer.getHighWater:(J)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 1 /* accepted */
            invokeinterface org.xnio.nio.Log.logf:(Ljava/lang/String;Lorg/jboss/logging/Logger$Level;Ljava/lang/Throwable;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        53: .line 526
            aload 11
            monitorexit
        54: goto 60
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int java.net.SocketAddress int java.net.SocketAddress java.net.Socket int org.xnio.nio.WorkerThread int java.util.concurrent.BlockingQueue org.xnio.nio.QueuedNioTcpServer
      StackMap stack: java.lang.Throwable
        55: aload 11
            monitorexit
        56: athrow
        end local 10 // java.util.concurrent.BlockingQueue queue
        end local 9 // int number
        end local 8 // org.xnio.nio.WorkerThread ioThread
        end local 7 // int sendBuffer
        end local 6 // java.net.Socket socket
        end local 5 // java.net.SocketAddress remoteAddress
        end local 4 // int hash
        end local 3 // java.net.SocketAddress localAddress
        57: .line 531
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int
      StackMap stack: java.lang.Throwable
            astore 12
        58: .line 532
            iload 2 /* ok */
            ifne 59
            aload 1 /* accepted */
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
        59: .line 533
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int top top top top top top top top top java.lang.Throwable
      StackMap stack:
            aload 12
            athrow
        60: .line 532
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel int
      StackMap stack:
            iload 2 /* ok */
            ifne 63
            aload 1 /* accepted */
            invokestatic org.xnio.IoUtils.safeClose:(Ljava/io/Closeable;)V
        end local 2 // boolean ok
        61: .line 534
            goto 63
      StackMap locals: org.xnio.nio.QueuedNioTcpServer java.nio.channels.SocketChannel
      StackMap stack: java.io.IOException
        62: pop
        63: .line 536
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.nio.channels.SocketChannel accepted
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   64     0           this  Lorg/xnio/nio/QueuedNioTcpServer;
            1    5     1       accepted  Ljava/nio/channels/SocketChannel;
            9   64     1       accepted  Ljava/nio/channels/SocketChannel;
            6    9     2              e  Ljava/io/IOException;
           10   61     2             ok  Z
           12   57     3   localAddress  Ljava/net/SocketAddress;
           15   16     4           hash  I
           18   19     4           hash  I
           20   57     4           hash  I
           14   15     5        address  Ljava/net/InetSocketAddress;
           21   57     5  remoteAddress  Ljava/net/SocketAddress;
           23   24     6        address  Ljava/net/InetSocketAddress;
           31   57     6         socket  Ljava/net/Socket;
           41   57     7     sendBuffer  I
           43   57     8       ioThread  Lorg/xnio/nio/WorkerThread;
           45   57     9         number  I
           46   57    10          queue  Ljava/util/concurrent/BlockingQueue<Ljava/nio/channels/SocketChannel;>;
      Exception table:
        from    to  target  type
           0     4       5  Class java.io.IOException
          51    54      55  any
          55    56      55  any
          11    57      57  any
           9    61      62  Class java.io.IOException

  public void connectionClosed();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.xnio.nio.QueuedNioTcpServer this
         0: .line 539
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.thread:Lorg/xnio/nio/WorkerThread;
            aload 0 /* this */
            getfield org.xnio.nio.QueuedNioTcpServer.connectionClosedTask:Ljava/lang/Runnable;
            invokevirtual org.xnio.nio.WorkerThread.execute:(Ljava/lang/Runnable;)V
         1: .line 540
            return
        end local 0 // org.xnio.nio.QueuedNioTcpServer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/xnio/nio/QueuedNioTcpServer;

  public org.xnio.channels.CloseableChannel accept();
    descriptor: ()Lorg/xnio/channels/CloseableChannel;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.QueuedNioTcpServer.accept:()Lorg/xnio/nio/NioSocketStreamConnection;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.io.IOException

  public org.xnio.channels.ConnectedChannel accept();
    descriptor: ()Lorg/xnio/channels/ConnectedChannel;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.xnio.nio.QueuedNioTcpServer.accept:()Lorg/xnio/nio/NioSocketStreamConnection;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.io.IOException

  static int access$2(org.xnio.nio.QueuedNioTcpServer);
    descriptor: (Lorg/xnio/nio/QueuedNioTcpServer;)I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 114
            aload 0
            getfield org.xnio.nio.QueuedNioTcpServer.openConnections:I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
Signature: Lorg/xnio/nio/AbstractNioChannel<Lorg/xnio/nio/QueuedNioTcpServer;>;Lorg/xnio/channels/AcceptingChannel<Lorg/xnio/StreamConnection;>;Lorg/xnio/channels/AcceptListenerSettable<Lorg/xnio/nio/QueuedNioTcpServer;>;
SourceFile: "QueuedNioTcpServer.java"
NestMembers:
  org.xnio.nio.QueuedNioTcpServer$1  org.xnio.nio.QueuedNioTcpServer$2  org.xnio.nio.QueuedNioTcpServer$3  org.xnio.nio.QueuedNioTcpServer$4
InnerClasses:
  public final Level = org.jboss.logging.Logger$Level of org.jboss.logging.Logger
  public abstract Setter = org.xnio.ChannelListener$Setter of org.xnio.ChannelListener
  public SetBuilder = org.xnio.Option$SetBuilder of org.xnio.Option
  public Setter = org.xnio.channels.AcceptListenerSettable$Setter of org.xnio.channels.AcceptListenerSettable
  org.xnio.nio.QueuedNioTcpServer$1
  org.xnio.nio.QueuedNioTcpServer$2
  org.xnio.nio.QueuedNioTcpServer$3
  org.xnio.nio.QueuedNioTcpServer$4