public class org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler extends org.glassfish.grizzly.AbstractSocketConnectorHandler
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler
  super_class: org.glassfish.grizzly.AbstractSocketConnectorHandler
{
  private static final java.util.logging.Logger LOGGER;
    descriptor: Ljava/util/logging/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  protected static final int DEFAULT_CONNECTION_TIMEOUT;
    descriptor: I
    flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL
    ConstantValue: 30000

  private final org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$InstantConnectHandler instantConnectHandler;
    descriptor: Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler$InstantConnectHandler;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  protected boolean isReuseAddress;
    descriptor: Z
    flags: (0x0004) ACC_PROTECTED

  protected volatile long connectionTimeoutMillis;
    descriptor: J
    flags: (0x0044) ACC_PROTECTED, ACC_VOLATILE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 43
            ldc Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            invokestatic org.glassfish.grizzly.Grizzly.logger:(Ljava/lang/Class;)Ljava/util/logging/Logger;
            putstatic org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.LOGGER:Ljava/util/logging/Logger;
         1: .line 44
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  protected void <init>(org.glassfish.grizzly.nio.transport.TCPNIOTransport);
    descriptor: (Lorg/glassfish/grizzly/nio/transport/TCPNIOTransport;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // org.glassfish.grizzly.nio.transport.TCPNIOTransport transport
         0: .line 51
            aload 0 /* this */
            aload 1 /* transport */
            invokespecial org.glassfish.grizzly.AbstractSocketConnectorHandler.<init>:(Lorg/glassfish/grizzly/Transport;)V
         1: .line 48
            aload 0 /* this */
            ldc 30000
            putfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectionTimeoutMillis:J
         2: .line 52
            aload 0 /* this */
            aload 1 /* transport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.getConnectionTimeout:()I
            i2l
            putfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectionTimeoutMillis:J
         3: .line 53
            aload 0 /* this */
            aload 1 /* transport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.isReuseAddress:()Z
            putfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.isReuseAddress:Z
         4: .line 54
            aload 0 /* this */
            new org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$InstantConnectHandler
            dup
            aload 0 /* this */
            invokespecial org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$InstantConnectHandler.<init>:(Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;)V
            putfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.instantConnectHandler:Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler$InstantConnectHandler;
         5: .line 55
            return
        end local 1 // org.glassfish.grizzly.nio.transport.TCPNIOTransport transport
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0    6     1  transport  Lorg/glassfish/grizzly/nio/transport/TCPNIOTransport;
    MethodParameters:
           Name  Flags
      transport  final

  public void connect(java.net.SocketAddress, java.net.SocketAddress, org.glassfish.grizzly.CompletionHandler<org.glassfish.grizzly.Connection>);
    descriptor: (Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // java.net.SocketAddress remoteAddress
        start local 2 // java.net.SocketAddress localAddress
        start local 3 // org.glassfish.grizzly.CompletionHandler completionHandler
         0: .line 62
            aload 0 /* this */
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.transport:Lorg/glassfish/grizzly/Transport;
            invokeinterface org.glassfish.grizzly.Transport.isBlocking:()Z
            ifne 3
         1: .line 63
            aload 0 /* this */
            aload 1 /* remoteAddress */
            aload 2 /* localAddress */
            aload 3 /* completionHandler */
            iconst_0
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectAsync:(Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler;Z)Lorg/glassfish/grizzly/impl/FutureImpl;
            pop
         2: .line 64
            goto 4
         3: .line 65
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* remoteAddress */
            aload 2 /* localAddress */
            aload 3 /* completionHandler */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectSync:(Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler;)V
         4: .line 67
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.glassfish.grizzly.CompletionHandler completionHandler
        end local 2 // java.net.SocketAddress localAddress
        end local 1 // java.net.SocketAddress remoteAddress
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    5     0               this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0    5     1      remoteAddress  Ljava/net/SocketAddress;
            0    5     2       localAddress  Ljava/net/SocketAddress;
            0    5     3  completionHandler  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
    Signature: (Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;)V
    MethodParameters:
                   Name  Flags
      remoteAddress      final
      localAddress       final
      completionHandler  final

  protected void connectSync(java.net.SocketAddress, java.net.SocketAddress, org.glassfish.grizzly.CompletionHandler<org.glassfish.grizzly.Connection>);
    descriptor: (Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // java.net.SocketAddress remoteAddress
        start local 2 // java.net.SocketAddress localAddress
        start local 3 // org.glassfish.grizzly.CompletionHandler completionHandler
         0: .line 72
            aload 0 /* this */
            aload 1 /* remoteAddress */
         1: .line 73
            aload 2 /* localAddress */
            aload 3 /* completionHandler */
            iconst_1
         2: .line 72
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectAsync:(Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler;Z)Lorg/glassfish/grizzly/impl/FutureImpl;
            astore 4 /* future */
        start local 4 // org.glassfish.grizzly.impl.FutureImpl future
         3: .line 75
            aload 0 /* this */
            aload 4 /* future */
            aload 3 /* completionHandler */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.waitNIOFuture:(Lorg/glassfish/grizzly/impl/FutureImpl;Lorg/glassfish/grizzly/CompletionHandler;)V
         4: .line 76
            return
        end local 4 // org.glassfish.grizzly.impl.FutureImpl future
        end local 3 // org.glassfish.grizzly.CompletionHandler completionHandler
        end local 2 // java.net.SocketAddress localAddress
        end local 1 // java.net.SocketAddress remoteAddress
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    5     0               this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0    5     1      remoteAddress  Ljava/net/SocketAddress;
            0    5     2       localAddress  Ljava/net/SocketAddress;
            0    5     3  completionHandler  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
            3    5     4             future  Lorg/glassfish/grizzly/impl/FutureImpl<Lorg/glassfish/grizzly/Connection;>;
    Signature: (Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;)V
    MethodParameters:
                   Name  Flags
      remoteAddress      
      localAddress       
      completionHandler  

  protected org.glassfish.grizzly.impl.FutureImpl<org.glassfish.grizzly.Connection> connectAsync(java.net.SocketAddress, java.net.SocketAddress, org.glassfish.grizzly.CompletionHandler<org.glassfish.grizzly.Connection>, boolean);
    descriptor: (Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler;Z)Lorg/glassfish/grizzly/impl/FutureImpl;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=7, locals=15, args_size=5
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // java.net.SocketAddress remoteAddress
        start local 2 // java.net.SocketAddress localAddress
        start local 3 // org.glassfish.grizzly.CompletionHandler completionHandler
        start local 4 // boolean needFuture
         0: .line 85
            aload 0 /* this */
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.transport:Lorg/glassfish/grizzly/Transport;
            checkcast org.glassfish.grizzly.nio.transport.TCPNIOTransport
            astore 5 /* nioTransport */
        start local 5 // org.glassfish.grizzly.nio.transport.TCPNIOTransport nioTransport
         1: .line 86
            aconst_null
            astore 6 /* newConnection */
        start local 6 // org.glassfish.grizzly.nio.transport.TCPNIOConnection newConnection
         2: .line 89
            aload 5 /* nioTransport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.getSelectorProvider:()Ljava/nio/channels/spi/SelectorProvider;
            invokevirtual java.nio.channels.spi.SelectorProvider.openSocketChannel:()Ljava/nio/channels/SocketChannel;
         3: .line 88
            astore 7 /* socketChannel */
        start local 7 // java.nio.channels.SocketChannel socketChannel
         4: .line 91
            aload 5 /* nioTransport */
            aload 7 /* socketChannel */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.obtainNIOConnection:(Ljava/nio/channels/SocketChannel;)Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;
            astore 6 /* newConnection */
         5: .line 93
            aload 6 /* newConnection */
            astore 8 /* finalConnection */
        start local 8 // org.glassfish.grizzly.nio.transport.TCPNIOConnection finalConnection
         6: .line 95
            aload 7 /* socketChannel */
            invokevirtual java.nio.channels.SocketChannel.socket:()Ljava/net/Socket;
            astore 9 /* socket */
        start local 9 // java.net.Socket socket
         7: .line 97
            aload 5 /* nioTransport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.getChannelConfigurator:()Lorg/glassfish/grizzly/nio/ChannelConfigurator;
         8: .line 98
            aload 5 /* nioTransport */
            aload 7 /* socketChannel */
         9: .line 97
            invokeinterface org.glassfish.grizzly.nio.ChannelConfigurator.preConfigure:(Lorg/glassfish/grizzly/nio/NIOTransport;Ljava/nio/channels/SelectableChannel;)V
        10: .line 100
            aload 0 /* this */
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.isReuseAddress:Z
            istore 10 /* reuseAddr */
        start local 10 // boolean reuseAddr
        11: .line 101
            iload 10 /* reuseAddr */
            aload 5 /* nioTransport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.isReuseAddress:()Z
            if_icmpeq 13
        12: .line 102
            aload 9 /* socket */
            iload 10 /* reuseAddr */
            invokevirtual java.net.Socket.setReuseAddress:(Z)V
        13: .line 105
      StackMap locals: org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler java.net.SocketAddress java.net.SocketAddress org.glassfish.grizzly.CompletionHandler int org.glassfish.grizzly.nio.transport.TCPNIOTransport org.glassfish.grizzly.nio.transport.TCPNIOConnection java.nio.channels.SocketChannel org.glassfish.grizzly.nio.transport.TCPNIOConnection java.net.Socket int
      StackMap stack:
            aload 2 /* localAddress */
            ifnull 15
        14: .line 106
            aload 9 /* socket */
            aload 2 /* localAddress */
            invokevirtual java.net.Socket.bind:(Ljava/net/SocketAddress;)V
        15: .line 109
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 8 /* finalConnection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.preConfigure:(Lorg/glassfish/grizzly/Connection;)V
        16: .line 111
            aload 8 /* finalConnection */
            aload 0 /* this */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.getProcessor:()Lorg/glassfish/grizzly/Processor;
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.setProcessor:(Lorg/glassfish/grizzly/Processor;)V
        17: .line 112
            aload 8 /* finalConnection */
            aload 0 /* this */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.getProcessorSelector:()Lorg/glassfish/grizzly/ProcessorSelector;
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.setProcessorSelector:(Lorg/glassfish/grizzly/ProcessorSelector;)V
        18: .line 114
            aload 7 /* socketChannel */
            aload 1 /* remoteAddress */
            invokevirtual java.nio.channels.SocketChannel.connect:(Ljava/net/SocketAddress;)Z
            istore 11 /* isConnected */
        start local 11 // boolean isConnected
        19: .line 120
            iload 4 /* needFuture */
            ifeq 24
        20: .line 121
            aload 0 /* this */
            aload 8 /* finalConnection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.makeCancellableFuture:(Lorg/glassfish/grizzly/Connection;)Lorg/glassfish/grizzly/impl/FutureImpl;
            astore 13 /* futureToReturn */
        start local 13 // org.glassfish.grizzly.impl.FutureImpl futureToReturn
        21: .line 124
            aload 13 /* futureToReturn */
            aload 3 /* completionHandler */
        22: .line 123
            invokestatic org.glassfish.grizzly.utils.Futures.toCompletionHandler:(Lorg/glassfish/grizzly/impl/FutureImpl;Lorg/glassfish/grizzly/CompletionHandler;)Lorg/glassfish/grizzly/CompletionHandler;
            astore 12 /* completionHandlerToPass */
        start local 12 // org.glassfish.grizzly.CompletionHandler completionHandlerToPass
        23: .line 126
            goto 26
        end local 13 // org.glassfish.grizzly.impl.FutureImpl futureToReturn
        end local 12 // org.glassfish.grizzly.CompletionHandler completionHandlerToPass
        24: .line 127
      StackMap locals: int
      StackMap stack:
            aload 3 /* completionHandler */
            astore 12 /* completionHandlerToPass */
        start local 12 // org.glassfish.grizzly.CompletionHandler completionHandlerToPass
        25: .line 128
            aconst_null
            astore 13 /* futureToReturn */
        start local 13 // org.glassfish.grizzly.impl.FutureImpl futureToReturn
        26: .line 131
      StackMap locals: org.glassfish.grizzly.CompletionHandler org.glassfish.grizzly.impl.FutureImpl
      StackMap stack:
            aload 6 /* newConnection */
        27: .line 132
            new org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$1
            dup
            aload 0 /* this */
            aload 8 /* finalConnection */
            aload 12 /* completionHandlerToPass */
            invokespecial org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$1.<init>:(Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;Lorg/glassfish/grizzly/CompletionHandler;)V
        28: .line 131
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.setConnectResultHandler:(Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection$ConnectResultHandler;)V
        29: .line 146
            aload 5 /* nioTransport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.getNIOChannelDistributor:()Lorg/glassfish/grizzly/nio/NIOChannelDistributor;
        30: .line 145
            astore 14 /* nioChannelDistributor */
        start local 14 // org.glassfish.grizzly.nio.NIOChannelDistributor nioChannelDistributor
        31: .line 148
            aload 14 /* nioChannelDistributor */
            ifnonnull 35
        32: .line 149
            new java.lang.IllegalStateException
            dup
        33: .line 150
            ldc "NIOChannelDistributor is null. Is Transport running?"
        34: .line 149
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        35: .line 153
      StackMap locals: org.glassfish.grizzly.nio.NIOChannelDistributor
      StackMap stack:
            iload 11 /* isConnected */
            ifeq 41
        36: .line 154
            aload 14 /* nioChannelDistributor */
        37: .line 155
            aload 7 /* socketChannel */
            iconst_0
            aload 6 /* newConnection */
        38: .line 156
            aload 0 /* this */
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.instantConnectHandler:Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler$InstantConnectHandler;
        39: .line 154
            invokeinterface org.glassfish.grizzly.nio.NIOChannelDistributor.registerChannelAsync:(Ljava/nio/channels/SelectableChannel;ILjava/lang/Object;Lorg/glassfish/grizzly/CompletionHandler;)V
        40: .line 157
            goto 45
        41: .line 158
      StackMap locals:
      StackMap stack:
            aload 14 /* nioChannelDistributor */
        42: .line 159
            aload 7 /* socketChannel */
            bipush 8
            aload 6 /* newConnection */
        43: .line 160
            new org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$RegisterChannelCompletionHandler
            dup
            aload 6 /* newConnection */
            invokespecial org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$RegisterChannelCompletionHandler.<init>:(Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;)V
        44: .line 158
            invokeinterface org.glassfish.grizzly.nio.NIOChannelDistributor.registerChannelAsync:(Ljava/nio/channels/SelectableChannel;ILjava/lang/Object;Lorg/glassfish/grizzly/CompletionHandler;)V
        45: .line 163
      StackMap locals:
      StackMap stack:
            aload 13 /* futureToReturn */
        46: areturn
        end local 14 // org.glassfish.grizzly.nio.NIOChannelDistributor nioChannelDistributor
        end local 13 // org.glassfish.grizzly.impl.FutureImpl futureToReturn
        end local 12 // org.glassfish.grizzly.CompletionHandler completionHandlerToPass
        end local 11 // boolean isConnected
        end local 10 // boolean reuseAddr
        end local 9 // java.net.Socket socket
        end local 8 // org.glassfish.grizzly.nio.transport.TCPNIOConnection finalConnection
        end local 7 // java.nio.channels.SocketChannel socketChannel
        47: .line 164
      StackMap locals: org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler java.net.SocketAddress java.net.SocketAddress org.glassfish.grizzly.CompletionHandler int org.glassfish.grizzly.nio.transport.TCPNIOTransport org.glassfish.grizzly.nio.transport.TCPNIOConnection
      StackMap stack: java.lang.Exception
            astore 7 /* e */
        start local 7 // java.lang.Exception e
        48: .line 165
            aload 6 /* newConnection */
            ifnull 50
        49: .line 166
            aload 6 /* newConnection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.closeSilently:()V
        50: .line 169
      StackMap locals: java.lang.Exception
      StackMap stack:
            aload 3 /* completionHandler */
            ifnull 52
        51: .line 170
            aload 3 /* completionHandler */
            aload 7 /* e */
            invokeinterface org.glassfish.grizzly.CompletionHandler.failed:(Ljava/lang/Throwable;)V
        52: .line 173
      StackMap locals:
      StackMap stack:
            iload 4 /* needFuture */
            ifeq 53
            aload 7 /* e */
            invokestatic org.glassfish.grizzly.impl.ReadyFutureImpl.create:(Ljava/lang/Throwable;)Lorg/glassfish/grizzly/impl/ReadyFutureImpl;
            goto 54
      StackMap locals:
      StackMap stack:
        53: aconst_null
      StackMap locals:
      StackMap stack: org.glassfish.grizzly.impl.ReadyFutureImpl
        54: areturn
        end local 7 // java.lang.Exception e
        end local 6 // org.glassfish.grizzly.nio.transport.TCPNIOConnection newConnection
        end local 5 // org.glassfish.grizzly.nio.transport.TCPNIOTransport nioTransport
        end local 4 // boolean needFuture
        end local 3 // org.glassfish.grizzly.CompletionHandler completionHandler
        end local 2 // java.net.SocketAddress localAddress
        end local 1 // java.net.SocketAddress remoteAddress
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            0   55     0                     this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0   55     1            remoteAddress  Ljava/net/SocketAddress;
            0   55     2             localAddress  Ljava/net/SocketAddress;
            0   55     3        completionHandler  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
            0   55     4               needFuture  Z
            1   55     5             nioTransport  Lorg/glassfish/grizzly/nio/transport/TCPNIOTransport;
            2   55     6            newConnection  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;
            4   47     7            socketChannel  Ljava/nio/channels/SocketChannel;
            6   47     8          finalConnection  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;
            7   47     9                   socket  Ljava/net/Socket;
           11   47    10                reuseAddr  Z
           19   47    11              isConnected  Z
           23   24    12  completionHandlerToPass  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
           25   47    12  completionHandlerToPass  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
           21   24    13           futureToReturn  Lorg/glassfish/grizzly/impl/FutureImpl<Lorg/glassfish/grizzly/Connection;>;
           26   47    13           futureToReturn  Lorg/glassfish/grizzly/impl/FutureImpl<Lorg/glassfish/grizzly/Connection;>;
           31   47    14    nioChannelDistributor  Lorg/glassfish/grizzly/nio/NIOChannelDistributor;
           48   55     7                        e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2    46      47  Class java.lang.Exception
    Signature: (Ljava/net/SocketAddress;Ljava/net/SocketAddress;Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;Z)Lorg/glassfish/grizzly/impl/FutureImpl<Lorg/glassfish/grizzly/Connection;>;
    MethodParameters:
                   Name  Flags
      remoteAddress      final
      localAddress       final
      completionHandler  final
      needFuture         final

  protected static void onConnectedAsync(org.glassfish.grizzly.nio.transport.TCPNIOConnection, org.glassfish.grizzly.CompletionHandler<org.glassfish.grizzly.Connection>);
    descriptor: (Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;Lorg/glassfish/grizzly/CompletionHandler;)V
    flags: (0x000c) ACC_PROTECTED, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=2
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnection connection
        start local 1 // org.glassfish.grizzly.CompletionHandler completionHandler
         0: .line 182
            aload 0 /* connection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.getTransport:()Lorg/glassfish/grizzly/Transport;
            checkcast org.glassfish.grizzly.nio.transport.TCPNIOTransport
         1: .line 181
            astore 2 /* tcpTransport */
        start local 2 // org.glassfish.grizzly.nio.transport.TCPNIOTransport tcpTransport
         2: .line 183
            aload 0 /* connection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.getChannel:()Ljava/nio/channels/SelectableChannel;
            checkcast java.nio.channels.SocketChannel
            astore 3 /* channel */
        start local 3 // java.nio.channels.SocketChannel channel
         3: .line 186
            aload 3 /* channel */
            invokevirtual java.nio.channels.SocketChannel.isConnected:()Z
            ifne 5
         4: .line 187
            aload 3 /* channel */
            invokevirtual java.nio.channels.SocketChannel.finishConnect:()Z
            pop
         5: .line 190
      StackMap locals: org.glassfish.grizzly.nio.transport.TCPNIOTransport java.nio.channels.SocketChannel
      StackMap stack:
            aload 0 /* connection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.resetProperties:()V
         6: .line 193
            aload 0 /* connection */
            getstatic org.glassfish.grizzly.IOEvent.CLIENT_CONNECTED:Lorg/glassfish/grizzly/IOEvent;
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.disableIOEvent:(Lorg/glassfish/grizzly/IOEvent;)V
         7: .line 196
            aload 2 /* tcpTransport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.getChannelConfigurator:()Lorg/glassfish/grizzly/nio/ChannelConfigurator;
            aload 2 /* tcpTransport */
            aload 3 /* channel */
            invokeinterface org.glassfish.grizzly.nio.ChannelConfigurator.postConfigure:(Lorg/glassfish/grizzly/nio/NIOTransport;Ljava/nio/channels/SelectableChannel;)V
         8: .line 197
            goto 12
      StackMap locals:
      StackMap stack: java.lang.Exception
         9: astore 4 /* e */
        start local 4 // java.lang.Exception e
        10: .line 198
            aload 0 /* connection */
            aload 1 /* completionHandler */
            aload 4 /* e */
            invokestatic org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.abortConnection:(Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;Lorg/glassfish/grizzly/CompletionHandler;Ljava/lang/Throwable;)V
        11: .line 199
            aload 4 /* e */
            invokestatic org.glassfish.grizzly.utils.Exceptions.makeIOException:(Ljava/lang/Throwable;)Ljava/io/IOException;
            athrow
        end local 4 // java.lang.Exception e
        12: .line 202
      StackMap locals:
      StackMap stack:
            aload 0 /* connection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.notifyReady:()Z
            ifeq 16
        13: .line 203
            aload 2 /* tcpTransport */
            getstatic org.glassfish.grizzly.IOEvent.CONNECTED:Lorg/glassfish/grizzly/IOEvent;
            aload 0 /* connection */
        14: .line 204
            new org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$EnableReadHandler
            dup
            aload 1 /* completionHandler */
            invokespecial org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$EnableReadHandler.<init>:(Lorg/glassfish/grizzly/CompletionHandler;)V
        15: .line 203
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent:(Lorg/glassfish/grizzly/IOEvent;Lorg/glassfish/grizzly/Connection;Lorg/glassfish/grizzly/IOEventLifeCycleListener;)V
        16: .line 206
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.nio.channels.SocketChannel channel
        end local 2 // org.glassfish.grizzly.nio.transport.TCPNIOTransport tcpTransport
        end local 1 // org.glassfish.grizzly.CompletionHandler completionHandler
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnection connection
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   17     0         connection  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;
            0   17     1  completionHandler  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
            2   17     2       tcpTransport  Lorg/glassfish/grizzly/nio/transport/TCPNIOTransport;
            3   17     3            channel  Ljava/nio/channels/SocketChannel;
           10   12     4                  e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           3     8       9  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    Signature: (Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;)V
    MethodParameters:
                   Name  Flags
      connection         final
      completionHandler  final

  public boolean isReuseAddress();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
         0: .line 209
            aload 0 /* this */
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.isReuseAddress:Z
            ireturn
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;

  public void setReuseAddress(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // boolean isReuseAddress
         0: .line 213
            aload 0 /* this */
            iload 1 /* isReuseAddress */
            putfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.isReuseAddress:Z
         1: .line 214
            return
        end local 1 // boolean isReuseAddress
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0    2     1  isReuseAddress  Z
    MethodParameters:
                Name  Flags
      isReuseAddress  

  public long getSyncConnectTimeout(java.util.concurrent.TimeUnit);
    descriptor: (Ljava/util/concurrent/TimeUnit;)J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // java.util.concurrent.TimeUnit timeUnit
         0: .line 217
            aload 1 /* timeUnit */
            aload 0 /* this */
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectionTimeoutMillis:J
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
            lreturn
        end local 1 // java.util.concurrent.TimeUnit timeUnit
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0    1     1  timeUnit  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
          Name  Flags
      timeUnit  final

  public void setSyncConnectTimeout(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // long timeout
        start local 3 // java.util.concurrent.TimeUnit timeUnit
         0: .line 221
            aload 0 /* this */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            lload 1 /* timeout */
            aload 3 /* timeUnit */
            invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
            putfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectionTimeoutMillis:J
         1: .line 222
            return
        end local 3 // java.util.concurrent.TimeUnit timeUnit
        end local 1 // long timeout
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0    2     1   timeout  J
            0    2     3  timeUnit  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
          Name  Flags
      timeout   final
      timeUnit  final

  protected void waitNIOFuture(org.glassfish.grizzly.impl.FutureImpl<org.glassfish.grizzly.Connection>, org.glassfish.grizzly.CompletionHandler<org.glassfish.grizzly.Connection>);
    descriptor: (Lorg/glassfish/grizzly/impl/FutureImpl;Lorg/glassfish/grizzly/CompletionHandler;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
        start local 1 // org.glassfish.grizzly.impl.FutureImpl future
        start local 2 // org.glassfish.grizzly.CompletionHandler completionHandler
         0: .line 228
            aload 1 /* future */
            aload 0 /* this */
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.connectionTimeoutMillis:J
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokeinterface org.glassfish.grizzly.impl.FutureImpl.get:(JLjava/util/concurrent/TimeUnit;)Ljava/lang/Object;
            pop
         1: .line 229
            goto 10
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         2: astore 3 /* e */
        start local 3 // java.lang.InterruptedException e
         3: .line 230
            aload 1 /* future */
            aload 2 /* completionHandler */
            aload 3 /* e */
            invokestatic org.glassfish.grizzly.utils.Futures.notifyFailure:(Lorg/glassfish/grizzly/impl/FutureImpl;Lorg/glassfish/grizzly/CompletionHandler;Ljava/lang/Throwable;)V
        end local 3 // java.lang.InterruptedException e
         4: goto 10
         5: .line 231
      StackMap locals:
      StackMap stack: java.util.concurrent.TimeoutException
            pop
         6: .line 232
            aload 1 /* future */
            aload 2 /* completionHandler */
         7: .line 233
            new java.io.IOException
            dup
            ldc "Channel registration on Selector timeout!"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
         8: .line 232
            invokestatic org.glassfish.grizzly.utils.Futures.notifyFailure:(Lorg/glassfish/grizzly/impl/FutureImpl;Lorg/glassfish/grizzly/CompletionHandler;Ljava/lang/Throwable;)V
            goto 10
         9: .line 234
      StackMap locals:
      StackMap stack: java.lang.Exception
            pop
        10: .line 236
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.glassfish.grizzly.CompletionHandler completionHandler
        end local 1 // org.glassfish.grizzly.impl.FutureImpl future
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   11     0               this  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;
            0   11     1             future  Lorg/glassfish/grizzly/impl/FutureImpl<Lorg/glassfish/grizzly/Connection;>;
            0   11     2  completionHandler  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
            3    4     3                  e  Ljava/lang/InterruptedException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.InterruptedException
           0     1       5  Class java.util.concurrent.TimeoutException
           0     1       9  Class java.lang.Exception
    Signature: (Lorg/glassfish/grizzly/impl/FutureImpl<Lorg/glassfish/grizzly/Connection;>;Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;)V
    MethodParameters:
                   Name  Flags
      future             final
      completionHandler  final

  private static void abortConnection(org.glassfish.grizzly.nio.transport.TCPNIOConnection, org.glassfish.grizzly.CompletionHandler<org.glassfish.grizzly.Connection>, java.lang.Throwable);
    descriptor: (Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;Lorg/glassfish/grizzly/CompletionHandler;Ljava/lang/Throwable;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnection connection
        start local 1 // org.glassfish.grizzly.CompletionHandler completionHandler
        start local 2 // java.lang.Throwable failure
         0: .line 242
            aload 0 /* connection */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnection.closeSilently:()V
         1: .line 244
            aload 1 /* completionHandler */
            ifnull 3
         2: .line 245
            aload 1 /* completionHandler */
            aload 2 /* failure */
            invokeinterface org.glassfish.grizzly.CompletionHandler.failed:(Ljava/lang/Throwable;)V
         3: .line 247
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Throwable failure
        end local 1 // org.glassfish.grizzly.CompletionHandler completionHandler
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOConnection connection
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    4     0         connection  Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;
            0    4     1  completionHandler  Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;
            0    4     2            failure  Ljava/lang/Throwable;
    Signature: (Lorg/glassfish/grizzly/nio/transport/TCPNIOConnection;Lorg/glassfish/grizzly/CompletionHandler<Lorg/glassfish/grizzly/Connection;>;Ljava/lang/Throwable;)V
    MethodParameters:
                   Name  Flags
      connection         final
      completionHandler  final
      failure            final

  public static org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$Builder builder(org.glassfish.grizzly.nio.transport.TCPNIOTransport);
    descriptor: (Lorg/glassfish/grizzly/nio/transport/TCPNIOTransport;)Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler$Builder;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.glassfish.grizzly.nio.transport.TCPNIOTransport transport
         0: .line 347
            new org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$Builder
            dup
            invokespecial org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$Builder.<init>:()V
            aload 0 /* transport */
            invokevirtual org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$Builder.setTransport:(Lorg/glassfish/grizzly/nio/transport/TCPNIOTransport;)Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler$Builder;
            areturn
        end local 0 // org.glassfish.grizzly.nio.transport.TCPNIOTransport transport
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0  transport  Lorg/glassfish/grizzly/nio/transport/TCPNIOTransport;
    MethodParameters:
           Name  Flags
      transport  final

  static org.glassfish.grizzly.Transport access$0(org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler);
    descriptor: (Lorg/glassfish/grizzly/nio/transport/TCPNIOConnectorHandler;)Lorg/glassfish/grizzly/Transport;
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 41
            aload 0
            getfield org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler.transport:Lorg/glassfish/grizzly/Transport;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "TCPNIOConnectorHandler.java"
NestMembers:
  org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$1  org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$Builder  org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$EnableReadHandler  org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$InstantConnectHandler  org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$RegisterChannelCompletionHandler
InnerClasses:
  protected abstract ConnectResultHandler = org.glassfish.grizzly.nio.transport.TCPNIOConnection$ConnectResultHandler of org.glassfish.grizzly.nio.transport.TCPNIOConnection
  org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$1
  public Builder = org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$Builder of org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler
  private final EnableReadHandler = org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$EnableReadHandler of org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler
  private InstantConnectHandler = org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$InstantConnectHandler of org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler
  private RegisterChannelCompletionHandler = org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler$RegisterChannelCompletionHandler of org.glassfish.grizzly.nio.transport.TCPNIOConnectorHandler