final class com.microsoft.sqlserver.jdbc.SocketConnector implements java.lang.Runnable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.microsoft.sqlserver.jdbc.SocketConnector
  super_class: java.lang.Object
{
  private final java.net.Socket socket;
    descriptor: Ljava/net/Socket;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final com.microsoft.sqlserver.jdbc.SocketFinder socketFinder;
    descriptor: Lcom/microsoft/sqlserver/jdbc/SocketFinder;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

  private static final java.util.logging.Logger logger;
    descriptor: Ljava/util/logging/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

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

  private static long lastThreadID;
    descriptor: J
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 2993
            ldc "com.microsoft.sqlserver.jdbc.internals.SocketConnector"
            invokestatic java.util.logging.Logger.getLogger:(Ljava/lang/String;)Ljava/util/logging/Logger;
            putstatic com.microsoft.sqlserver.jdbc.SocketConnector.logger:Ljava/util/logging/Logger;
         1: .line 3001
            lconst_0
            putstatic com.microsoft.sqlserver.jdbc.SocketConnector.lastThreadID:J
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.net.Socket, java.net.InetSocketAddress, int, com.microsoft.sqlserver.jdbc.SocketFinder);
    descriptor: (Ljava/net/Socket;Ljava/net/InetSocketAddress;ILcom/microsoft/sqlserver/jdbc/SocketFinder;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // com.microsoft.sqlserver.jdbc.SocketConnector this
        start local 1 // java.net.Socket socket
        start local 2 // java.net.InetSocketAddress inetSocketAddress
        start local 3 // int timeOutInMilliSeconds
        start local 4 // com.microsoft.sqlserver.jdbc.SocketFinder socketFinder
         0: .line 3006
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 3008
            aload 0 /* this */
            aload 1 /* socket */
            putfield com.microsoft.sqlserver.jdbc.SocketConnector.socket:Ljava/net/Socket;
         2: .line 3009
            aload 0 /* this */
            aload 2 /* inetSocketAddress */
            putfield com.microsoft.sqlserver.jdbc.SocketConnector.inetSocketAddress:Ljava/net/InetSocketAddress;
         3: .line 3010
            aload 0 /* this */
            iload 3 /* timeOutInMilliSeconds */
            putfield com.microsoft.sqlserver.jdbc.SocketConnector.timeoutInMilliseconds:I
         4: .line 3011
            aload 0 /* this */
            aload 4 /* socketFinder */
            putfield com.microsoft.sqlserver.jdbc.SocketConnector.socketFinder:Lcom/microsoft/sqlserver/jdbc/SocketFinder;
         5: .line 3012
            aload 0 /* this */
            invokestatic com.microsoft.sqlserver.jdbc.SocketConnector.nextThreadID:()J
            invokestatic java.lang.Long.toString:(J)Ljava/lang/String;
            putfield com.microsoft.sqlserver.jdbc.SocketConnector.threadID:Ljava/lang/String;
         6: .line 3013
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "SocketConnector:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.threadID:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* socketFinder */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            putfield com.microsoft.sqlserver.jdbc.SocketConnector.traceID:Ljava/lang/String;
         7: .line 3014
            return
        end local 4 // com.microsoft.sqlserver.jdbc.SocketFinder socketFinder
        end local 3 // int timeOutInMilliSeconds
        end local 2 // java.net.InetSocketAddress inetSocketAddress
        end local 1 // java.net.Socket socket
        end local 0 // com.microsoft.sqlserver.jdbc.SocketConnector this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0    8     0                   this  Lcom/microsoft/sqlserver/jdbc/SocketConnector;
            0    8     1                 socket  Ljava/net/Socket;
            0    8     2      inetSocketAddress  Ljava/net/InetSocketAddress;
            0    8     3  timeOutInMilliSeconds  I
            0    8     4           socketFinder  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
    MethodParameters:
                       Name  Flags
      socket                 
      inetSocketAddress      
      timeOutInMilliSeconds  
      socketFinder           

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // com.microsoft.sqlserver.jdbc.SocketConnector this
         0: .line 3021
            aconst_null
            astore 1 /* exception */
        start local 1 // java.io.IOException exception
         1: .line 3025
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.socketFinder:Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getResult:()Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            astore 2 /* result */
        start local 2 // com.microsoft.sqlserver.jdbc.SocketFinder$Result result
         2: .line 3026
            aload 2 /* result */
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.UNKNOWN:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder$Result.equals:(Ljava/lang/Object;)Z
            ifeq 16
         3: .line 3028
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 7
         4: .line 3029
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketConnector.toString:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " connecting to InetSocketAddress:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.inetSocketAddress:Ljava/net/InetSocketAddress;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         5: .line 3030
            ldc " with timeout:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.timeoutInMilliseconds:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         6: .line 3029
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         7: .line 3033
      StackMap locals: java.io.IOException com.microsoft.sqlserver.jdbc.SocketFinder$Result
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.socket:Ljava/net/Socket;
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.inetSocketAddress:Ljava/net/InetSocketAddress;
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.timeoutInMilliseconds:I
            invokevirtual java.net.Socket.connect:(Ljava/net/SocketAddress;I)V
         8: .line 3034
            goto 15
      StackMap locals:
      StackMap stack: java.io.IOException
         9: astore 3 /* ex */
        start local 3 // java.io.IOException ex
        10: .line 3035
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 14
        11: .line 3036
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketConnector.toString:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " exception:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* ex */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " with message:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* ex */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        12: .line 3037
            ldc " occurred while connecting to InetSocketAddress:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.inetSocketAddress:Ljava/net/InetSocketAddress;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 3036
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        14: .line 3039
      StackMap locals: java.io.IOException
      StackMap stack:
            aload 3 /* ex */
            astore 1 /* exception */
        end local 3 // java.io.IOException ex
        15: .line 3042
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.socketFinder:Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.socket:Ljava/net/Socket;
            aload 1 /* exception */
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketConnector.toString:()Ljava/lang/String;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.updateResult:(Ljava/net/Socket;Ljava/io/IOException;Ljava/lang/String;)V
        16: .line 3045
      StackMap locals:
      StackMap stack:
            return
        end local 2 // com.microsoft.sqlserver.jdbc.SocketFinder$Result result
        end local 1 // java.io.IOException exception
        end local 0 // com.microsoft.sqlserver.jdbc.SocketConnector this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   17     0       this  Lcom/microsoft/sqlserver/jdbc/SocketConnector;
            1   17     1  exception  Ljava/io/IOException;
            2   17     2     result  Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
           10   15     3         ex  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           3     8       9  Class java.io.IOException

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.microsoft.sqlserver.jdbc.SocketConnector this
         0: .line 3053
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketConnector.traceID:Ljava/lang/String;
            areturn
        end local 0 // com.microsoft.sqlserver.jdbc.SocketConnector this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/microsoft/sqlserver/jdbc/SocketConnector;

  private static synchronized long nextThreadID();
    descriptor: ()J
    flags: (0x002a) ACC_PRIVATE, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=0, args_size=0
         0: .line 3060
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.lastThreadID:J
            ldc 9223372036854775807
            lcmp
            ifne 5
         1: .line 3061
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 3
         2: .line 3062
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.logger:Ljava/util/logging/Logger;
            ldc "Resetting the Id count"
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         3: .line 3063
      StackMap locals:
      StackMap stack:
            lconst_1
            putstatic com.microsoft.sqlserver.jdbc.SocketConnector.lastThreadID:J
         4: .line 3064
            goto 6
         5: .line 3065
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.lastThreadID:J
            lconst_1
            ladd
            putstatic com.microsoft.sqlserver.jdbc.SocketConnector.lastThreadID:J
         6: .line 3067
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketConnector.lastThreadID:J
            lreturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "IOBuffer.java"
InnerClasses:
  final Result = com.microsoft.sqlserver.jdbc.SocketFinder$Result of com.microsoft.sqlserver.jdbc.SocketFinder