final class com.microsoft.sqlserver.jdbc.SocketFinder
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.microsoft.sqlserver.jdbc.SocketFinder
  super_class: java.lang.Object
{
  private static final java.util.concurrent.ThreadPoolExecutor threadPoolExecutor;
    descriptor: Ljava/util/concurrent/ThreadPoolExecutor;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int minTimeoutForParallelConnections;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1500

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

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

  private volatile com.microsoft.sqlserver.jdbc.SocketFinder$Result result;
    descriptor: Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

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

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

  private volatile java.net.Socket selectedSocket;
    descriptor: Ljava/net/Socket;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile java.io.IOException selectedException;
    descriptor: Ljava/io/IOException;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  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 static final int ipAddressLimit;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 64

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

  private javax.net.SocketFactory socketFactory;
    descriptor: Ljavax/net/SocketFactory;
    flags: (0x0002) ACC_PRIVATE

  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=9, locals=0, args_size=0
         0: .line 2269
            ldc Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            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 com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
         3: .line 2281
            new java.util.concurrent.ThreadPoolExecutor
            dup
            iconst_0
            ldc 2147483647
            ldc 5
         4: .line 2282
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            new java.util.concurrent.SynchronousQueue
            dup
            invokespecial java.util.concurrent.SynchronousQueue.<init>:()V
         5: .line 2281
            invokespecial java.util.concurrent.ThreadPoolExecutor.<init>:(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;)V
            putstatic com.microsoft.sqlserver.jdbc.SocketFinder.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
         6: .line 2316
            ldc "com.microsoft.sqlserver.jdbc.internals.SocketFinder"
            invokestatic java.util.logging.Logger.getLogger:(Ljava/lang/String;)Ljava/util/logging/Logger;
            putstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
         7: .line 2320
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.lang.String, com.microsoft.sqlserver.jdbc.SQLServerConnection);
    descriptor: (Ljava/lang/String;Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.lang.String callerTraceID
        start local 2 // com.microsoft.sqlserver.jdbc.SQLServerConnection sqlServerConnection
         0: .line 2333
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 2289
            aload 0 /* this */
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFinderlock:Ljava/lang/Object;
         2: .line 2293
            aload 0 /* this */
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.parentThreadLock:Ljava/lang/Object;
         3: .line 2297
            aload 0 /* this */
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.UNKNOWN:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
         4: .line 2301
            aload 0 /* this */
            iconst_0
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.noOfSpawnedThreads:I
         5: .line 2305
            aload 0 /* this */
            iconst_0
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.noOfThreadsThatNotified:I
         6: .line 2309
            aload 0 /* this */
            aconst_null
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
         7: .line 2313
            aload 0 /* this */
            aconst_null
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedException:Ljava/io/IOException;
         8: .line 2630
            aload 0 /* this */
            aconst_null
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFactory:Ljavax/net/SocketFactory;
         9: .line 2334
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "SocketFinder("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* callerTraceID */
            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.SocketFinder.traceID:Ljava/lang/String;
        10: .line 2335
            aload 0 /* this */
            aload 2 /* sqlServerConnection */
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.conn:Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;
        11: .line 2336
            return
        end local 2 // com.microsoft.sqlserver.jdbc.SQLServerConnection sqlServerConnection
        end local 1 // java.lang.String callerTraceID
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   12     0                 this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   12     1        callerTraceID  Ljava/lang/String;
            0   12     2  sqlServerConnection  Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;
    MethodParameters:
                     Name  Flags
      callerTraceID        
      sqlServerConnection  

  java.net.Socket findSocket(java.lang.String, int, int, boolean, boolean, boolean, int);
    descriptor: (Ljava/lang/String;IIZZZI)Ljava/net/Socket;
    flags: (0x0000) 
    Code:
      stack=4, locals=14, args_size=8
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.lang.String hostName
        start local 2 // int portNumber
        start local 3 // int timeoutInMilliSeconds
        start local 4 // boolean useParallel
        start local 5 // boolean useTnir
        start local 6 // boolean isTnirFirstAttempt
        start local 7 // int timeoutInMilliSecondsForFullTimeout
         0: .line 2349
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 1
            iload 3 /* timeoutInMilliSeconds */
            ifne 1
            new java.lang.AssertionError
            dup
            ldc "The driver does not allow a time out of 0"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 2352
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* inetAddrs */
        start local 8 // java.net.InetAddress[] inetAddrs
         2: .line 2354
            iload 4 /* useParallel */
            ifne 9
         3: .line 2357
            iload 5 /* useTnir */
            ifeq 6
            iload 6 /* isTnirFirstAttempt */
            ifeq 6
         4: .line 2358
            aload 0 /* this */
            aload 1 /* hostName */
            iload 2 /* portNumber */
            sipush 500
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getDefaultSocket:(Ljava/lang/String;II)Ljava/net/Socket;
         5: areturn
         6: .line 2359
      StackMap locals: java.net.InetAddress[]
      StackMap stack:
            iload 5 /* useTnir */
            ifne 9
         7: .line 2360
            aload 0 /* this */
            aload 1 /* hostName */
            iload 2 /* portNumber */
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getDefaultSocket:(Ljava/lang/String;II)Ljava/net/Socket;
         8: areturn
         9: .line 2366
      StackMap locals:
      StackMap stack:
            iload 4 /* useParallel */
            ifne 10
            iload 5 /* useTnir */
            ifeq 14
        10: .line 2368
      StackMap locals:
      StackMap stack:
            aload 1 /* hostName */
            invokestatic java.net.InetAddress.getAllByName:(Ljava/lang/String;)[Ljava/net/InetAddress;
            astore 8 /* inetAddrs */
        11: .line 2370
            iload 5 /* useTnir */
            ifeq 14
            aload 8 /* inetAddrs */
            arraylength
            bipush 64
            if_icmple 14
        12: .line 2371
            iconst_0
            istore 5 /* useTnir */
        13: .line 2372
            iload 7 /* timeoutInMilliSecondsForFullTimeout */
            istore 3 /* timeoutInMilliSeconds */
        14: .line 2378
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 25
        15: .line 2379
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.toString:()Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            astore 9 /* loggingString */
        start local 9 // java.lang.StringBuilder loggingString
        16: .line 2380
            aload 9 /* loggingString */
            ldc " Total no of InetAddresses: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        17: .line 2381
            aload 9 /* loggingString */
            aload 8 /* inetAddrs */
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            pop
        18: .line 2382
            aload 9 /* loggingString */
            ldc ". They are: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        19: .line 2384
            aload 8 /* inetAddrs */
            dup
            astore 13
            arraylength
            istore 12
            iconst_0
            istore 11
            goto 23
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.lang.String int int int int int int java.net.InetAddress[] java.lang.StringBuilder top int int java.net.InetAddress[]
      StackMap stack:
        20: aload 13
            iload 11
            aaload
            astore 10 /* inetAddr */
        start local 10 // java.net.InetAddress inetAddr
        21: .line 2385
            aload 9 /* loggingString */
            aload 10 /* inetAddr */
            invokevirtual java.net.InetAddress.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;
            pop
        end local 10 // java.net.InetAddress inetAddr
        22: .line 2384
            iinc 11 1
      StackMap locals:
      StackMap stack:
        23: iload 11
            iload 12
            if_icmplt 20
        24: .line 2388
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            aload 9 /* loggingString */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        end local 9 // java.lang.StringBuilder loggingString
        25: .line 2391
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.lang.String int int int int int int java.net.InetAddress[]
      StackMap stack:
            aload 8 /* inetAddrs */
            arraylength
            bipush 64
            if_icmple 32
        26: .line 2392
            new java.text.MessageFormat
            dup
        27: .line 2393
            ldc "R_ipAddressLimitWithMultiSubnetFailover"
            invokestatic com.microsoft.sqlserver.jdbc.SQLServerException.getErrString:(Ljava/lang/String;)Ljava/lang/String;
        28: .line 2392
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;)V
            astore 9 /* form */
        start local 9 // java.text.MessageFormat form
        29: .line 2394
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            bipush 64
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            aastore
            astore 10 /* msgArgs */
        start local 10 // java.lang.Object[] msgArgs
        30: .line 2395
            aload 9 /* form */
            aload 10 /* msgArgs */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            astore 11 /* errorStr */
        start local 11 // java.lang.String errorStr
        31: .line 2398
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.conn:Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;
            bipush 6
            aload 11 /* errorStr */
            invokevirtual com.microsoft.sqlserver.jdbc.SQLServerConnection.terminate:(ILjava/lang/String;)V
        end local 11 // java.lang.String errorStr
        end local 10 // java.lang.Object[] msgArgs
        end local 9 // java.text.MessageFormat form
        32: .line 2401
      StackMap locals:
      StackMap stack:
            aload 8 /* inetAddrs */
            arraylength
            iconst_1
            if_icmpne 35
        33: .line 2403
            aload 0 /* this */
            aload 8 /* inetAddrs */
            iconst_0
            aaload
            iload 2 /* portNumber */
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getConnectedSocket:(Ljava/net/InetAddress;II)Ljava/net/Socket;
        34: areturn
        35: .line 2405
      StackMap locals:
      StackMap stack:
            iload 3 /* timeoutInMilliSeconds */
            sipush 1500
            invokestatic java.lang.Math.max:(II)I
            istore 3 /* timeoutInMilliSeconds */
        36: .line 2406
            invokestatic com.microsoft.sqlserver.jdbc.Util.isIBM:()Z
            ifeq 41
        37: .line 2407
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 39
        38: .line 2408
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 "Using Java NIO with timeout:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        39: .line 2410
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 8 /* inetAddrs */
            iload 2 /* portNumber */
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.findSocketUsingJavaNIO:([Ljava/net/InetAddress;II)V
        40: .line 2411
            goto 44
        41: .line 2412
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 43
        42: .line 2413
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 "Using Threading with timeout:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        43: .line 2415
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 8 /* inetAddrs */
            iload 2 /* portNumber */
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.findSocketUsingThreading:([Ljava/net/InetAddress;II)V
        44: .line 2422
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$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 54
        45: .line 2423
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFinderlock:Ljava/lang/Object;
            dup
            astore 9
            monitorenter
        46: .line 2424
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$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 50
        47: .line 2425
            aload 0 /* this */
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.FAILURE:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
        48: .line 2426
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 50
        49: .line 2427
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " The parent thread updated the result to failure"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        50: .line 2423
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 9
            monitorexit
        51: goto 54
      StackMap locals:
      StackMap stack: java.lang.Throwable
        52: aload 9
            monitorexit
        53: athrow
        54: .line 2437
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.FAILURE:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder$Result.equals:(Ljava/lang/Object;)Z
            ifeq 71
        55: .line 2438
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedException:Ljava/io/IOException;
            ifnonnull 62
        56: .line 2439
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 60
        57: .line 2440
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.toString:()Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        58: .line 2441
            ldc " There is no selectedException. The wait calls timed out before any connect call returned or timed out."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        59: .line 2440
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        60: .line 2443
      StackMap locals:
      StackMap stack:
            ldc "R_connectionTimedOut"
            invokestatic com.microsoft.sqlserver.jdbc.SQLServerException.getErrString:(Ljava/lang/String;)Ljava/lang/String;
            astore 9 /* message */
        start local 9 // java.lang.String message
        61: .line 2444
            aload 0 /* this */
            new java.io.IOException
            dup
            aload 9 /* message */
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedException:Ljava/io/IOException;
        end local 9 // java.lang.String message
        62: .line 2446
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedException:Ljava/io/IOException;
            athrow
        end local 8 // java.net.InetAddress[] inetAddrs
        63: .line 2449
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.lang.String int int int int int int
      StackMap stack: java.lang.InterruptedException
            astore 8 /* ex */
        start local 8 // java.lang.InterruptedException ex
        64: .line 2451
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        65: .line 2453
            aload 0 /* this */
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/net/Socket;)V
        66: .line 2454
            aload 1 /* hostName */
            iload 2 /* portNumber */
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.conn:Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;
            aload 8 /* ex */
            invokestatic com.microsoft.sqlserver.jdbc.SQLServerException.ConvertConnectExceptionToSQLServerException:(Ljava/lang/String;ILcom/microsoft/sqlserver/jdbc/SQLServerConnection;Ljava/lang/Exception;)V
        end local 8 // java.lang.InterruptedException ex
        67: goto 71
        68: .line 2455
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 8 /* ex */
        start local 8 // java.io.IOException ex
        69: .line 2456
            aload 0 /* this */
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/net/Socket;)V
        70: .line 2466
            aload 1 /* hostName */
            iload 2 /* portNumber */
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.conn:Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;
            aload 8 /* ex */
            invokestatic com.microsoft.sqlserver.jdbc.SQLServerException.ConvertConnectExceptionToSQLServerException:(Ljava/lang/String;ILcom/microsoft/sqlserver/jdbc/SQLServerConnection;Ljava/lang/Exception;)V
        end local 8 // java.io.IOException ex
        71: .line 2470
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 72
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.SUCCESS:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder$Result.equals:(Ljava/lang/Object;)Z
            ifne 72
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        72: .line 2471
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 73
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            ifnonnull 73
            new java.lang.AssertionError
            dup
            ldc "Bug in code. Selected Socket cannot be null here."
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        73: .line 2473
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            areturn
        end local 7 // int timeoutInMilliSecondsForFullTimeout
        end local 6 // boolean isTnirFirstAttempt
        end local 5 // boolean useTnir
        end local 4 // boolean useParallel
        end local 3 // int timeoutInMilliSeconds
        end local 2 // int portNumber
        end local 1 // java.lang.String hostName
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                                 Name  Signature
            0   74     0                                 this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   74     1                             hostName  Ljava/lang/String;
            0   74     2                           portNumber  I
            0   74     3                timeoutInMilliSeconds  I
            0   74     4                          useParallel  Z
            0   74     5                              useTnir  Z
            0   74     6                   isTnirFirstAttempt  Z
            0   74     7  timeoutInMilliSecondsForFullTimeout  I
            2   63     8                            inetAddrs  [Ljava/net/InetAddress;
           16   25     9                        loggingString  Ljava/lang/StringBuilder;
           21   22    10                             inetAddr  Ljava/net/InetAddress;
           29   32     9                                 form  Ljava/text/MessageFormat;
           30   32    10                              msgArgs  [Ljava/lang/Object;
           31   32    11                             errorStr  Ljava/lang/String;
           61   62     9                              message  Ljava/lang/String;
           64   67     8                                   ex  Ljava/lang/InterruptedException;
           69   71     8                                   ex  Ljava/io/IOException;
      Exception table:
        from    to  target  type
          46    51      52  any
          52    53      52  any
           1     5      63  Class java.lang.InterruptedException
           6     8      63  Class java.lang.InterruptedException
           9    34      63  Class java.lang.InterruptedException
          35    63      63  Class java.lang.InterruptedException
           1     5      68  Class java.io.IOException
           6     8      68  Class java.io.IOException
           9    34      68  Class java.io.IOException
          35    63      68  Class java.io.IOException
    Exceptions:
      throws com.microsoft.sqlserver.jdbc.SQLServerException
    MethodParameters:
                                     Name  Flags
      hostName                             
      portNumber                           
      timeoutInMilliSeconds                
      useParallel                          
      useTnir                              
      isTnirFirstAttempt                   
      timeoutInMilliSecondsForFullTimeout  

  private void findSocketUsingJavaNIO(java.net.InetAddress[], int, int);
    descriptor: ([Ljava/net/InetAddress;II)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=24, args_size=4
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.net.InetAddress[] inetAddrs
        start local 2 // int portNumber
        start local 3 // int timeoutInMilliSeconds
         0: .line 2493
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 1
            iload 3 /* timeoutInMilliSeconds */
            ifne 1
            new java.lang.AssertionError
            dup
            ldc "The timeout cannot be zero"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 2494
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 2
            aload 1 /* inetAddrs */
            arraylength
            ifne 2
            new java.lang.AssertionError
            dup
            ldc "Number of inetAddresses should not be zero in this function"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 2496
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* selector */
        start local 4 // java.nio.channels.Selector selector
         3: .line 2497
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 5 /* socketChannels */
        start local 5 // java.util.LinkedList socketChannels
         4: .line 2498
            aconst_null
            astore 6 /* selectedChannel */
        start local 6 // java.nio.channels.SocketChannel selectedChannel
         5: .line 2501
            invokestatic java.nio.channels.Selector.open:()Ljava/nio/channels/Selector;
            astore 4 /* selector */
         6: .line 2503
            aload 1 /* inetAddrs */
            dup
            astore 10
            arraylength
            istore 9
            iconst_0
            istore 8
            goto 19
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel top int int java.net.InetAddress[]
      StackMap stack:
         7: aload 10
            iload 8
            aaload
            astore 7 /* inetAddr */
        start local 7 // java.net.InetAddress inetAddr
         8: .line 2504
            invokestatic java.nio.channels.SocketChannel.open:()Ljava/nio/channels/SocketChannel;
            astore 11 /* sChannel */
        start local 11 // java.nio.channels.SocketChannel sChannel
         9: .line 2505
            aload 5 /* socketChannels */
            aload 11 /* sChannel */
            invokevirtual java.util.LinkedList.add:(Ljava/lang/Object;)Z
            pop
        10: .line 2508
            aload 11 /* sChannel */
            iconst_0
            invokevirtual java.nio.channels.SocketChannel.configureBlocking:(Z)Ljava/nio/channels/SelectableChannel;
            pop
        11: .line 2512
            bipush 8
            istore 12 /* ops */
        start local 12 // int ops
        12: .line 2513
            aload 11 /* sChannel */
            aload 4 /* selector */
            iload 12 /* ops */
            invokevirtual java.nio.channels.SocketChannel.register:(Ljava/nio/channels/Selector;I)Ljava/nio/channels/SelectionKey;
            pop
        13: .line 2515
            aload 11 /* sChannel */
            new java.net.InetSocketAddress
            dup
            aload 7 /* inetAddr */
            iload 2 /* portNumber */
            invokespecial java.net.InetSocketAddress.<init>:(Ljava/net/InetAddress;I)V
            invokevirtual java.nio.channels.SocketChannel.connect:(Ljava/net/SocketAddress;)Z
            pop
        14: .line 2517
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 18
        15: .line 2518
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " initiated connection to address: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* inetAddr */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc ", portNumber: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        16: .line 2519
            iload 2 /* portNumber */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        17: .line 2518
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        end local 12 // int ops
        end local 11 // java.nio.channels.SocketChannel sChannel
        end local 7 // java.net.InetAddress inetAddr
        18: .line 2503
      StackMap locals:
      StackMap stack:
            iinc 8 1
      StackMap locals:
      StackMap stack:
        19: iload 8
            iload 9
            if_icmplt 7
        20: .line 2522
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 7 /* timerNow */
        start local 7 // long timerNow
        21: .line 2523
            lload 7 /* timerNow */
            iload 3 /* timeoutInMilliSeconds */
            i2l
            ladd
            lstore 9 /* timerExpire */
        start local 9 // long timerExpire
        22: .line 2526
            aload 1 /* inetAddrs */
            arraylength
            istore 11 /* noOfOutstandingChannels */
        start local 11 // int noOfOutstandingChannels
        23: .line 2529
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel long long int
      StackMap stack:
            lload 9 /* timerExpire */
            lload 7 /* timerNow */
            lsub
            lstore 12 /* timeRemaining */
        start local 12 // long timeRemaining
        24: .line 2531
            lload 12 /* timeRemaining */
            lconst_0
            lcmp
            ifle 68
            aload 6 /* selectedChannel */
            ifnonnull 68
            iload 11 /* noOfOutstandingChannels */
            ifgt 26
        25: .line 2532
            goto 68
        26: .line 2536
      StackMap locals: long
      StackMap stack:
            aload 4 /* selector */
            lload 12 /* timeRemaining */
            invokevirtual java.nio.channels.Selector.select:(J)I
            istore 14 /* readyChannels */
        start local 14 // int readyChannels
        27: .line 2538
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 29
        28: .line 2539
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " no of channels ready: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 14 /* readyChannels */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        29: .line 2545
      StackMap locals: int
      StackMap stack:
            iload 14 /* readyChannels */
            ifeq 55
        30: .line 2546
            aload 4 /* selector */
            invokevirtual java.nio.channels.Selector.selectedKeys:()Ljava/util/Set;
            astore 15 /* selectedKeys */
        start local 15 // java.util.Set selectedKeys
        31: .line 2547
            aload 15 /* selectedKeys */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 16 /* keyIterator */
        start local 16 // java.util.Iterator keyIterator
        32: .line 2549
            goto 54
        33: .line 2551
      StackMap locals: java.util.Set java.util.Iterator
      StackMap stack:
            aload 16 /* keyIterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.nio.channels.SelectionKey
            astore 17 /* key */
        start local 17 // java.nio.channels.SelectionKey key
        34: .line 2552
            aload 17 /* key */
            invokevirtual java.nio.channels.SelectionKey.channel:()Ljava/nio/channels/SelectableChannel;
            checkcast java.nio.channels.SocketChannel
            astore 18 /* ch */
        start local 18 // java.nio.channels.SocketChannel ch
        35: .line 2554
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 37
        36: .line 2555
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " processing the channel :"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 18 /* ch */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        37: .line 2558
      StackMap locals: java.nio.channels.SelectionKey java.nio.channels.SocketChannel
      StackMap stack:
            iconst_0
            istore 19 /* connected */
        start local 19 // boolean connected
        38: .line 2560
            aload 18 /* ch */
            invokevirtual java.nio.channels.SocketChannel.finishConnect:()Z
            istore 19 /* connected */
        39: .line 2564
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 40
            iload 19 /* connected */
            ifne 40
            new java.lang.AssertionError
            dup
            new java.lang.StringBuilder
            dup
            ldc "finishConnect on channel:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 18 /* ch */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " cannot be false"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        40: .line 2566
      StackMap locals: int
      StackMap stack:
            aload 18 /* ch */
            astore 6 /* selectedChannel */
        41: .line 2568
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 55
        42: .line 2569
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " selected the channel :"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* selectedChannel */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        43: .line 2571
            goto 55
        44: .line 2572
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 20 /* ex */
        start local 20 // java.io.IOException ex
        45: .line 2573
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 49
        46: .line 2574
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " the exception: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 20 /* 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;
        47: .line 2575
            aload 20 /* ex */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " occurred while processing the channel: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 18 /* ch */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        48: .line 2574
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        49: .line 2576
      StackMap locals: java.io.IOException
      StackMap stack:
            aload 0 /* this */
            aload 20 /* ex */
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.toString:()Ljava/lang/String;
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.updateSelectedException:(Ljava/io/IOException;Ljava/lang/String;)V
        50: .line 2579
            aload 18 /* ch */
            invokevirtual java.nio.channels.SocketChannel.close:()V
        end local 20 // java.io.IOException ex
        51: .line 2583
            aload 17 /* key */
            invokevirtual java.nio.channels.SelectionKey.cancel:()V
        52: .line 2584
            aload 16 /* keyIterator */
            invokeinterface java.util.Iterator.remove:()V
        53: .line 2585
            iinc 11 /* noOfOutstandingChannels */ -1
        end local 19 // boolean connected
        end local 18 // java.nio.channels.SocketChannel ch
        end local 17 // java.nio.channels.SelectionKey key
        54: .line 2549
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel long long int long int java.util.Set java.util.Iterator
      StackMap stack:
            aload 16 /* keyIterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 33
        end local 16 // java.util.Iterator keyIterator
        end local 15 // java.util.Set selectedKeys
        55: .line 2589
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 7 /* timerNow */
        end local 14 // int readyChannels
        end local 12 // long timeRemaining
        56: .line 2528
            goto 23
        end local 11 // int noOfOutstandingChannels
        end local 9 // long timerExpire
        end local 7 // long timerNow
        57: .line 2591
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel
      StackMap stack: java.io.IOException
            astore 7 /* ex */
        start local 7 // java.io.IOException ex
        58: .line 2595
            aload 0 /* this */
            aload 6 /* selectedChannel */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/nio/channels/SocketChannel;)V
        59: .line 2596
            aload 7 /* ex */
            athrow
        end local 7 // java.io.IOException ex
        60: .line 2597
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 21
        61: .line 2604
            aload 0 /* this */
            aload 4 /* selector */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/nio/channels/Selector;)V
        62: .line 2612
            aload 5 /* socketChannels */
            invokevirtual java.util.LinkedList.iterator:()Ljava/util/Iterator;
            astore 23
            goto 66
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel top top top top top top top top top top top top top top java.lang.Throwable top java.util.Iterator
      StackMap stack:
        63: aload 23
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.nio.channels.SocketChannel
            astore 22 /* s */
        start local 22 // java.nio.channels.SocketChannel s
        64: .line 2613
            aload 22 /* s */
            aload 6 /* selectedChannel */
            if_acmpeq 66
        65: .line 2614
            aload 0 /* this */
            aload 22 /* s */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/nio/channels/SocketChannel;)V
        end local 22 // java.nio.channels.SocketChannel s
        66: .line 2612
      StackMap locals:
      StackMap stack:
            aload 23
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 63
        67: .line 2617
            aload 21
            athrow
        68: .line 2604
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel
      StackMap stack:
            aload 0 /* this */
            aload 4 /* selector */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/nio/channels/Selector;)V
        69: .line 2612
            aload 5 /* socketChannels */
            invokevirtual java.util.LinkedList.iterator:()Ljava/util/Iterator;
            astore 23
            goto 73
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel top top top top top top top top top top top top top top top top java.util.Iterator
      StackMap stack:
        70: aload 23
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.nio.channels.SocketChannel
            astore 22 /* s */
        start local 22 // java.nio.channels.SocketChannel s
        71: .line 2613
            aload 22 /* s */
            aload 6 /* selectedChannel */
            if_acmpeq 73
        72: .line 2614
            aload 0 /* this */
            aload 22 /* s */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/nio/channels/SocketChannel;)V
        end local 22 // java.nio.channels.SocketChannel s
        73: .line 2612
      StackMap locals:
      StackMap stack:
            aload 23
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 70
        74: .line 2620
            aload 6 /* selectedChannel */
            ifnull 78
        75: .line 2623
            aload 6 /* selectedChannel */
            iconst_1
            invokevirtual java.nio.channels.SocketChannel.configureBlocking:(Z)Ljava/nio/channels/SelectableChannel;
            pop
        76: .line 2624
            aload 0 /* this */
            aload 6 /* selectedChannel */
            invokevirtual java.nio.channels.SocketChannel.socket:()Ljava/net/Socket;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
        77: .line 2626
            aload 0 /* this */
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.SUCCESS:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
        78: .line 2628
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.nio.channels.Selector java.util.LinkedList java.nio.channels.SocketChannel
      StackMap stack:
            return
        end local 6 // java.nio.channels.SocketChannel selectedChannel
        end local 5 // java.util.LinkedList socketChannels
        end local 4 // java.nio.channels.Selector selector
        end local 3 // int timeoutInMilliSeconds
        end local 2 // int portNumber
        end local 1 // java.net.InetAddress[] inetAddrs
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            0   79     0                     this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   79     1                inetAddrs  [Ljava/net/InetAddress;
            0   79     2               portNumber  I
            0   79     3    timeoutInMilliSeconds  I
            3   79     4                 selector  Ljava/nio/channels/Selector;
            4   79     5           socketChannels  Ljava/util/LinkedList<Ljava/nio/channels/SocketChannel;>;
            5   79     6          selectedChannel  Ljava/nio/channels/SocketChannel;
            8   18     7                 inetAddr  Ljava/net/InetAddress;
            9   18    11                 sChannel  Ljava/nio/channels/SocketChannel;
           12   18    12                      ops  I
           21   57     7                 timerNow  J
           22   57     9              timerExpire  J
           23   57    11  noOfOutstandingChannels  I
           24   56    12            timeRemaining  J
           27   56    14            readyChannels  I
           31   55    15             selectedKeys  Ljava/util/Set<Ljava/nio/channels/SelectionKey;>;
           32   55    16              keyIterator  Ljava/util/Iterator<Ljava/nio/channels/SelectionKey;>;
           34   54    17                      key  Ljava/nio/channels/SelectionKey;
           35   54    18                       ch  Ljava/nio/channels/SocketChannel;
           38   54    19                connected  Z
           45   51    20                       ex  Ljava/io/IOException;
           58   60     7                       ex  Ljava/io/IOException;
           64   66    22                        s  Ljava/nio/channels/SocketChannel;
           71   73    22                        s  Ljava/nio/channels/SocketChannel;
      Exception table:
        from    to  target  type
          38    43      44  Class java.io.IOException
           5    57      57  Class java.io.IOException
           5    60      60  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                       Name  Flags
      inetAddrs              
      portNumber             
      timeoutInMilliSeconds  

  private javax.net.SocketFactory getSocketFactory();
    descriptor: ()Ljavax/net/SocketFactory;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
         0: .line 2633
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFactory:Ljavax/net/SocketFactory;
            ifnonnull 15
         1: .line 2634
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.conn:Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;
            invokevirtual com.microsoft.sqlserver.jdbc.SQLServerConnection.getSocketFactoryClass:()Ljava/lang/String;
            astore 1 /* socketFactoryClass */
        start local 1 // java.lang.String socketFactoryClass
         2: .line 2635
            aload 1 /* socketFactoryClass */
            ifnonnull 5
         3: .line 2636
            aload 0 /* this */
            invokestatic javax.net.SocketFactory.getDefault:()Ljavax/net/SocketFactory;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFactory:Ljavax/net/SocketFactory;
         4: .line 2637
            goto 15
         5: .line 2638
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.conn:Lcom/microsoft/sqlserver/jdbc/SQLServerConnection;
            invokevirtual com.microsoft.sqlserver.jdbc.SQLServerConnection.getSocketFactoryConstructorArg:()Ljava/lang/String;
            astore 2 /* socketFactoryConstructorArg */
        start local 2 // java.lang.String socketFactoryConstructorArg
         6: .line 2640
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            ldc "socketFactoryClass"
            aastore
            dup
            iconst_1
            ldc "javax.net.SocketFactory"
            aastore
            astore 3 /* msgArgs */
        start local 3 // java.lang.Object[] msgArgs
         7: .line 2641
            aload 0 /* this */
            ldc Ljavax/net/SocketFactory;
            aload 1 /* socketFactoryClass */
         8: .line 2642
            aload 2 /* socketFactoryConstructorArg */
            aload 3 /* msgArgs */
         9: .line 2641
            invokestatic com.microsoft.sqlserver.jdbc.Util.newInstance:(Ljava/lang/Class;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/Object;
            checkcast javax.net.SocketFactory
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFactory:Ljavax/net/SocketFactory;
        end local 3 // java.lang.Object[] msgArgs
        10: .line 2643
            goto 15
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.lang.String java.lang.String
      StackMap stack: java.lang.RuntimeException
        11: astore 3 /* e */
        start local 3 // java.lang.RuntimeException e
        12: .line 2644
            aload 3 /* e */
            athrow
        end local 3 // java.lang.RuntimeException e
        13: .line 2645
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 3 /* e */
        start local 3 // java.lang.Exception e
        14: .line 2646
            new java.io.IOException
            dup
            aload 3 /* e */
            invokespecial java.io.IOException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        end local 2 // java.lang.String socketFactoryConstructorArg
        end local 1 // java.lang.String socketFactoryClass
        15: .line 2650
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFactory:Ljavax/net/SocketFactory;
            areturn
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                         Name  Signature
            0   16     0                         this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            2   15     1           socketFactoryClass  Ljava/lang/String;
            6   15     2  socketFactoryConstructorArg  Ljava/lang/String;
            7   10     3                      msgArgs  [Ljava/lang/Object;
           12   13     3                            e  Ljava/lang/RuntimeException;
           14   15     3                            e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           6    10      11  Class java.lang.RuntimeException
           6    10      13  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException

  private java.net.Socket getDefaultSocket(java.lang.String, int, int);
    descriptor: (Ljava/lang/String;II)Ljava/net/Socket;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.lang.String hostName
        start local 2 // int portNumber
        start local 3 // int timeoutInMilliSeconds
         0: .line 2665
            new java.net.InetSocketAddress
            dup
            aload 1 /* hostName */
            iload 2 /* portNumber */
            invokespecial java.net.InetSocketAddress.<init>:(Ljava/lang/String;I)V
            astore 4 /* addr */
        start local 4 // java.net.InetSocketAddress addr
         1: .line 2666
            aload 4 /* addr */
            invokevirtual java.net.InetSocketAddress.isUnresolved:()Z
            ifeq 10
         2: .line 2667
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 6
         3: .line 2668
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 "Failed to resolve host name: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* hostName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 2669
            ldc ". Using IP address from DNS cache."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 2668
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         6: .line 2671
      StackMap locals: java.net.InetSocketAddress
      StackMap stack:
            aload 1 /* hostName */
            invokestatic com.microsoft.sqlserver.jdbc.SQLServerConnection.getDNSEntry:(Ljava/lang/String;)Ljava/net/InetSocketAddress;
            astore 5 /* cacheEntry */
        start local 5 // java.net.InetSocketAddress cacheEntry
         7: .line 2672
            aload 5 /* cacheEntry */
            ifnull 8
            aload 5 /* cacheEntry */
            goto 9
      StackMap locals: java.net.InetSocketAddress
      StackMap stack:
         8: aload 4 /* addr */
      StackMap locals:
      StackMap stack: java.net.InetSocketAddress
         9: astore 4 /* addr */
        end local 5 // java.net.InetSocketAddress cacheEntry
        10: .line 2674
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* addr */
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getConnectedSocket:(Ljava/net/InetSocketAddress;I)Ljava/net/Socket;
            areturn
        end local 4 // java.net.InetSocketAddress addr
        end local 3 // int timeoutInMilliSeconds
        end local 2 // int portNumber
        end local 1 // java.lang.String hostName
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   11     0                   this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   11     1               hostName  Ljava/lang/String;
            0   11     2             portNumber  I
            0   11     3  timeoutInMilliSeconds  I
            1   11     4                   addr  Ljava/net/InetSocketAddress;
            7   10     5             cacheEntry  Ljava/net/InetSocketAddress;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                       Name  Flags
      hostName               
      portNumber             
      timeoutInMilliSeconds  

  private java.net.Socket getConnectedSocket(java.net.InetAddress, int, int);
    descriptor: (Ljava/net/InetAddress;II)Ljava/net/Socket;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.net.InetAddress inetAddr
        start local 2 // int portNumber
        start local 3 // int timeoutInMilliSeconds
         0: .line 2679
            new java.net.InetSocketAddress
            dup
            aload 1 /* inetAddr */
            iload 2 /* portNumber */
            invokespecial java.net.InetSocketAddress.<init>:(Ljava/net/InetAddress;I)V
            astore 4 /* addr */
        start local 4 // java.net.InetSocketAddress addr
         1: .line 2680
            aload 0 /* this */
            aload 4 /* addr */
            iload 3 /* timeoutInMilliSeconds */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getConnectedSocket:(Ljava/net/InetSocketAddress;I)Ljava/net/Socket;
            areturn
        end local 4 // java.net.InetSocketAddress addr
        end local 3 // int timeoutInMilliSeconds
        end local 2 // int portNumber
        end local 1 // java.net.InetAddress inetAddr
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0    2     0                   this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0    2     1               inetAddr  Ljava/net/InetAddress;
            0    2     2             portNumber  I
            0    2     3  timeoutInMilliSeconds  I
            1    2     4                   addr  Ljava/net/InetSocketAddress;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                       Name  Flags
      inetAddr               
      portNumber             
      timeoutInMilliSeconds  

  private java.net.Socket getConnectedSocket(java.net.InetSocketAddress, int);
    descriptor: (Ljava/net/InetSocketAddress;I)Ljava/net/Socket;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.net.InetSocketAddress addr
        start local 2 // int timeoutInMilliSeconds
         0: .line 2684
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 1
            iload 2 /* timeoutInMilliSeconds */
            ifne 1
            new java.lang.AssertionError
            dup
            ldc "timeout cannot be zero"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 2685
      StackMap locals:
      StackMap stack:
            aload 1 /* addr */
            invokevirtual java.net.InetSocketAddress.isUnresolved:()Z
            ifeq 3
         2: .line 2686
            new java.net.UnknownHostException
            dup
            invokespecial java.net.UnknownHostException.<init>:()V
            athrow
         3: .line 2687
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getSocketFactory:()Ljavax/net/SocketFactory;
            invokevirtual javax.net.SocketFactory.createSocket:()Ljava/net/Socket;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
         4: .line 2688
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            invokevirtual java.net.Socket.isConnected:()Z
            ifne 6
         5: .line 2689
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            aload 1 /* addr */
            iload 2 /* timeoutInMilliSeconds */
            invokevirtual java.net.Socket.connect:(Ljava/net/SocketAddress;I)V
         6: .line 2691
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            areturn
        end local 2 // int timeoutInMilliSeconds
        end local 1 // java.net.InetSocketAddress addr
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0    7     0                   this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0    7     1                   addr  Ljava/net/InetSocketAddress;
            0    7     2  timeoutInMilliSeconds  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                       Name  Flags
      addr                   
      timeoutInMilliSeconds  

  private void findSocketUsingThreading(java.net.InetAddress[], int, int);
    descriptor: ([Ljava/net/InetAddress;II)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=16, args_size=4
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.net.InetAddress[] inetAddrs
        start local 2 // int portNumber
        start local 3 // int timeoutInMilliSeconds
         0: .line 2696
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 1
            iload 3 /* timeoutInMilliSeconds */
            ifne 1
            new java.lang.AssertionError
            dup
            ldc "The timeout cannot be zero"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         1: .line 2698
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.$assertionsDisabled:Z
            ifne 2
            aload 1 /* inetAddrs */
            arraylength
            ifne 2
            new java.lang.AssertionError
            dup
            ldc "Number of inetAddresses should not be zero in this function"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         2: .line 2700
      StackMap locals:
      StackMap stack:
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 4 /* sockets */
        start local 4 // java.util.LinkedList sockets
         3: .line 2701
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 5 /* socketConnectors */
        start local 5 // java.util.LinkedList socketConnectors
         4: .line 2706
            aload 0 /* this */
            aload 1 /* inetAddrs */
            arraylength
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.noOfSpawnedThreads:I
         5: .line 2707
            aload 1 /* inetAddrs */
            dup
            astore 9
            arraylength
            istore 8
            iconst_0
            istore 7
            goto 15
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList top int int java.net.InetAddress[]
      StackMap stack:
         6: aload 9
            iload 7
            aaload
            astore 6 /* inetAddress */
        start local 6 // java.net.InetAddress inetAddress
         7: .line 2708
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.getSocketFactory:()Ljavax/net/SocketFactory;
            invokevirtual javax.net.SocketFactory.createSocket:()Ljava/net/Socket;
            astore 10 /* s */
        start local 10 // java.net.Socket s
         8: .line 2709
            aload 4 /* sockets */
            aload 10 /* s */
            invokevirtual java.util.LinkedList.add:(Ljava/lang/Object;)Z
            pop
         9: .line 2711
            new java.net.InetSocketAddress
            dup
            aload 6 /* inetAddress */
            iload 2 /* portNumber */
            invokespecial java.net.InetSocketAddress.<init>:(Ljava/net/InetAddress;I)V
            astore 11 /* inetSocketAddress */
        start local 11 // java.net.InetSocketAddress inetSocketAddress
        10: .line 2713
            new com.microsoft.sqlserver.jdbc.SocketConnector
            dup
            aload 10 /* s */
            aload 11 /* inetSocketAddress */
            iload 3 /* timeoutInMilliSeconds */
        11: .line 2714
            aload 0 /* this */
        12: .line 2713
            invokespecial com.microsoft.sqlserver.jdbc.SocketConnector.<init>:(Ljava/net/Socket;Ljava/net/InetSocketAddress;ILcom/microsoft/sqlserver/jdbc/SocketFinder;)V
            astore 12 /* socketConnector */
        start local 12 // com.microsoft.sqlserver.jdbc.SocketConnector socketConnector
        13: .line 2715
            aload 5 /* socketConnectors */
            aload 12 /* socketConnector */
            invokevirtual java.util.LinkedList.add:(Ljava/lang/Object;)Z
            pop
        end local 12 // com.microsoft.sqlserver.jdbc.SocketConnector socketConnector
        end local 11 // java.net.InetSocketAddress inetSocketAddress
        end local 10 // java.net.Socket s
        end local 6 // java.net.InetAddress inetAddress
        14: .line 2707
            iinc 7 1
      StackMap locals:
      StackMap stack:
        15: iload 7
            iload 8
            if_icmplt 6
        16: .line 2719
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.parentThreadLock:Ljava/lang/Object;
            dup
            astore 6
            monitorenter
        17: .line 2720
            aload 5 /* socketConnectors */
            invokevirtual java.util.LinkedList.iterator:()Ljava/util/Iterator;
            astore 8
            goto 20
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList java.lang.Object top java.util.Iterator
      StackMap stack:
        18: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.microsoft.sqlserver.jdbc.SocketConnector
            astore 7 /* sc */
        start local 7 // com.microsoft.sqlserver.jdbc.SocketConnector sc
        19: .line 2721
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
            aload 7 /* sc */
            invokevirtual java.util.concurrent.ThreadPoolExecutor.execute:(Ljava/lang/Runnable;)V
        end local 7 // com.microsoft.sqlserver.jdbc.SocketConnector sc
        20: .line 2720
      StackMap locals:
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 18
        21: .line 2724
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 7 /* timerNow */
        start local 7 // long timerNow
        22: .line 2725
            lload 7 /* timerNow */
            iload 3 /* timeoutInMilliSeconds */
            i2l
            ladd
            lstore 9 /* timerExpire */
        start local 9 // long timerExpire
        23: .line 2729
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList java.lang.Object long long
      StackMap stack:
            lload 9 /* timerExpire */
            lload 7 /* timerNow */
            lsub
            lstore 11 /* timeRemaining */
        start local 11 // long timeRemaining
        24: .line 2731
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 29
        25: .line 2732
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " TimeRemaining:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            lload 11 /* timeRemaining */
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc "; Result:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        26: .line 2733
            ldc "; Max. open thread count: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getLargestPoolSize:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        27: .line 2734
            ldc "; Current open thread count:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.threadPoolExecutor:Ljava/util/concurrent/ThreadPoolExecutor;
            invokevirtual java.util.concurrent.ThreadPoolExecutor.getActiveCount:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        28: .line 2732
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        29: .line 2748
      StackMap locals: long
      StackMap stack:
            lload 11 /* timeRemaining */
            lconst_0
            lcmp
            ifle 36
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$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
            ifne 31
        30: .line 2749
            goto 36
        31: .line 2751
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.parentThreadLock:Ljava/lang/Object;
            lload 11 /* timeRemaining */
            invokevirtual java.lang.Object.wait:(J)V
        32: .line 2753
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 34
        33: .line 2754
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 " The parent thread wokeup."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        34: .line 2757
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 7 /* timerNow */
        end local 11 // long timeRemaining
        35: .line 2728
            goto 23
        end local 9 // long timerExpire
        end local 7 // long timerNow
        36: .line 2719
      StackMap locals:
      StackMap stack:
            aload 6
            monitorexit
        37: goto 47
      StackMap locals:
      StackMap stack: java.lang.Throwable
        38: aload 6
            monitorexit
        39: athrow
        40: .line 2762
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList
      StackMap stack: java.lang.Throwable
            astore 13
        41: .line 2772
            aload 4 /* sockets */
            invokevirtual java.util.LinkedList.iterator:()Ljava/util/Iterator;
            astore 15
            goto 45
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList top top top top top top top java.lang.Throwable top java.util.Iterator
      StackMap stack:
        42: aload 15
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.Socket
            astore 14 /* s */
        start local 14 // java.net.Socket s
        43: .line 2773
            aload 14 /* s */
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            if_acmpeq 45
        44: .line 2774
            aload 0 /* this */
            aload 14 /* s */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/net/Socket;)V
        end local 14 // java.net.Socket s
        45: .line 2772
      StackMap locals:
      StackMap stack:
            aload 15
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 42
        46: .line 2777
            aload 13
            athrow
        47: .line 2772
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList
      StackMap stack:
            aload 4 /* sockets */
            invokevirtual java.util.LinkedList.iterator:()Ljava/util/Iterator;
            astore 15
            goto 51
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList top top top top top top top top top java.util.Iterator
      StackMap stack:
        48: aload 15
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.net.Socket
            astore 14 /* s */
        start local 14 // java.net.Socket s
        49: .line 2773
            aload 14 /* s */
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            if_acmpeq 51
        50: .line 2774
            aload 0 /* this */
            aload 14 /* s */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.close:(Ljava/net/Socket;)V
        end local 14 // java.net.Socket s
        51: .line 2772
      StackMap locals:
      StackMap stack:
            aload 15
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 48
        52: .line 2779
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            ifnull 54
        53: .line 2780
            aload 0 /* this */
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.SUCCESS:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
        54: .line 2782
      StackMap locals: com.microsoft.sqlserver.jdbc.SocketFinder java.net.InetAddress[] int int java.util.LinkedList java.util.LinkedList
      StackMap stack:
            return
        end local 5 // java.util.LinkedList socketConnectors
        end local 4 // java.util.LinkedList sockets
        end local 3 // int timeoutInMilliSeconds
        end local 2 // int portNumber
        end local 1 // java.net.InetAddress[] inetAddrs
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   55     0                   this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   55     1              inetAddrs  [Ljava/net/InetAddress;
            0   55     2             portNumber  I
            0   55     3  timeoutInMilliSeconds  I
            3   55     4                sockets  Ljava/util/LinkedList<Ljava/net/Socket;>;
            4   55     5       socketConnectors  Ljava/util/LinkedList<Lcom/microsoft/sqlserver/jdbc/SocketConnector;>;
            7   14     6            inetAddress  Ljava/net/InetAddress;
            8   14    10                      s  Ljava/net/Socket;
           10   14    11      inetSocketAddress  Ljava/net/InetSocketAddress;
           13   14    12        socketConnector  Lcom/microsoft/sqlserver/jdbc/SocketConnector;
           19   20     7                     sc  Lcom/microsoft/sqlserver/jdbc/SocketConnector;
           22   36     7               timerNow  J
           23   36     9            timerExpire  J
           24   35    11          timeRemaining  J
           43   45    14                      s  Ljava/net/Socket;
           49   51    14                      s  Ljava/net/Socket;
      Exception table:
        from    to  target  type
          17    37      38  any
          38    39      38  any
           4    40      40  any
    Exceptions:
      throws java.io.IOException, java.lang.InterruptedException
    MethodParameters:
                       Name  Flags
      inetAddrs              
      portNumber             
      timeoutInMilliSeconds  

  com.microsoft.sqlserver.jdbc.SocketFinder$Result getResult();
    descriptor: ()Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
         0: .line 2788
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            areturn
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;

  void close(java.nio.channels.Selector);
    descriptor: (Ljava/nio/channels/Selector;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.nio.channels.Selector selector
         0: .line 2792
            aload 1 /* selector */
            ifnull 8
         1: .line 2793
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 2794
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 ": Closing Selector"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         3: .line 2797
      StackMap locals:
      StackMap stack:
            aload 1 /* selector */
            invokevirtual java.nio.channels.Selector.close:()V
         4: .line 2798
            goto 8
      StackMap locals:
      StackMap stack: java.io.IOException
         5: astore 2 /* e */
        start local 2 // java.io.IOException e
         6: .line 2799
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 8
         7: .line 2800
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 ": Ignored the following error while closing Selector"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* e */
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 2 // java.io.IOException e
         8: .line 2803
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.nio.channels.Selector selector
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    9     0      this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0    9     1  selector  Ljava/nio/channels/Selector;
            6    8     2         e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.IOException
    MethodParameters:
          Name  Flags
      selector  

  void close(java.net.Socket);
    descriptor: (Ljava/net/Socket;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.net.Socket socket
         0: .line 2806
            aload 1 /* socket */
            ifnull 8
         1: .line 2807
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 2808
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 ": Closing TCP socket:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* socket */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         3: .line 2811
      StackMap locals:
      StackMap stack:
            aload 1 /* socket */
            invokevirtual java.net.Socket.close:()V
         4: .line 2812
            goto 8
      StackMap locals:
      StackMap stack: java.io.IOException
         5: astore 2 /* e */
        start local 2 // java.io.IOException e
         6: .line 2813
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 8
         7: .line 2814
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 ": Ignored the following error while closing socket"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* e */
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 2 // java.io.IOException e
         8: .line 2817
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.net.Socket socket
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0    9     1  socket  Ljava/net/Socket;
            6    8     2       e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.IOException
    MethodParameters:
        Name  Flags
      socket  

  void close(java.nio.channels.SocketChannel);
    descriptor: (Ljava/nio/channels/SocketChannel;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.nio.channels.SocketChannel socketChannel
         0: .line 2820
            aload 1 /* socketChannel */
            ifnull 10
         1: .line 2821
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 2822
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 ": Closing TCP socket channel:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* socketChannel */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         3: .line 2825
      StackMap locals:
      StackMap stack:
            aload 1 /* socketChannel */
            invokevirtual java.nio.channels.SocketChannel.close:()V
         4: .line 2826
            goto 10
      StackMap locals:
      StackMap stack: java.io.IOException
         5: astore 2 /* e */
        start local 2 // java.io.IOException e
         6: .line 2827
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 10
         7: .line 2828
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.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 "Ignored the following error while closing socketChannel"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 2829
            aload 2 /* e */
         9: .line 2828
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 2 // java.io.IOException e
        10: .line 2832
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.nio.channels.SocketChannel socketChannel
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   11     0           this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   11     1  socketChannel  Ljava/nio/channels/SocketChannel;
            6   10     2              e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.IOException
    MethodParameters:
               Name  Flags
      socketChannel  

  void updateResult(java.net.Socket, java.io.IOException, java.lang.String);
    descriptor: (Ljava/net/Socket;Ljava/io/IOException;Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.net.Socket socket
        start local 2 // java.io.IOException exception
        start local 3 // java.lang.String threadId
         0: .line 2848
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$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 40
         1: .line 2849
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 2850
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            ldc "The following child thread is waiting for socketFinderLock:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* threadId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         3: .line 2853
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.socketFinderlock:Ljava/lang/Object;
            dup
            astore 4
            monitorenter
         4: .line 2854
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 6
         5: .line 2855
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            ldc "The following child thread acquired socketFinderLock:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* threadId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
         6: .line 2858
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$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 14
         7: .line 2861
            aload 2 /* exception */
            ifnonnull 12
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
            ifnonnull 12
         8: .line 2862
            aload 0 /* this */
            aload 1 /* socket */
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedSocket:Ljava/net/Socket;
         9: .line 2863
            aload 0 /* this */
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.SUCCESS:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
        10: .line 2864
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 12
        11: .line 2865
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            ldc "The socket of the following thread has been chosen:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* threadId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        12: .line 2870
      StackMap locals:
      StackMap stack:
            aload 2 /* exception */
            ifnull 14
        13: .line 2871
            aload 0 /* this */
            aload 2 /* exception */
            aload 3 /* threadId */
            invokevirtual com.microsoft.sqlserver.jdbc.SocketFinder.updateSelectedException:(Ljava/io/IOException;Ljava/lang/String;)V
        14: .line 2875
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.noOfThreadsThatNotified:I
            iconst_1
            iadd
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.noOfThreadsThatNotified:I
        15: .line 2879
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.noOfThreadsThatNotified:I
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.noOfSpawnedThreads:I
            if_icmplt 17
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$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 17
        16: .line 2880
            aload 0 /* this */
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder$Result.FAILURE:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$Result;
        17: .line 2883
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.result:Lcom/microsoft/sqlserver/jdbc/SocketFinder$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
            ifne 34
        18: .line 2906
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 20
        19: .line 2907
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            ldc "The following child thread is waiting for parentThreadLock:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* threadId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        20: .line 2910
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.parentThreadLock:Ljava/lang/Object;
            dup
            astore 5
            monitorenter
        21: .line 2911
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 23
        22: .line 2912
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            ldc "The following child thread acquired parentThreadLock:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* threadId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        23: .line 2915
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.parentThreadLock:Ljava/lang/Object;
            invokevirtual java.lang.Object.notifyAll:()V
        24: .line 2910
            aload 5
            monitorexit
        25: goto 28
      StackMap locals:
      StackMap stack: java.lang.Throwable
        26: aload 5
            monitorexit
        27: athrow
        28: .line 2918
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 34
        29: .line 2919
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
        30: .line 2920
            new java.lang.StringBuilder
            dup
            ldc "The following child thread released parentThreadLock and notified the parent thread:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        31: .line 2921
            aload 3 /* threadId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        32: .line 2920
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        33: .line 2919
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        34: .line 2853
      StackMap locals:
      StackMap stack:
            aload 4
            monitorexit
        35: goto 38
      StackMap locals:
      StackMap stack: java.lang.Throwable
        36: aload 4
            monitorexit
        37: athrow
        38: .line 2926
      StackMap locals:
      StackMap stack:
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 40
        39: .line 2927
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            ldc "The following child thread released socketFinderLock:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* threadId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        40: .line 2931
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.String threadId
        end local 2 // java.io.IOException exception
        end local 1 // java.net.Socket socket
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   41     0       this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   41     1     socket  Ljava/net/Socket;
            0   41     2  exception  Ljava/io/IOException;
            0   41     3   threadId  Ljava/lang/String;
      Exception table:
        from    to  target  type
          21    25      26  any
          26    27      26  any
           4    35      36  any
          36    37      36  any
    MethodParameters:
           Name  Flags
      socket     
      exception  
      threadId   

  public void updateSelectedException(java.io.IOException, java.lang.String);
    descriptor: (Ljava/io/IOException;Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
        start local 1 // java.io.IOException ex
        start local 2 // java.lang.String traceId
         0: .line 2950
            iconst_0
            istore 3 /* updatedException */
        start local 3 // boolean updatedException
         1: .line 2951
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedException:Ljava/io/IOException;
            ifnull 3
         2: .line 2952
            aload 1 /* ex */
            instanceof java.net.SocketTimeoutException
            ifne 5
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedException:Ljava/io/IOException;
            instanceof java.net.SocketTimeoutException
            ifeq 5
         3: .line 2953
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aload 1 /* ex */
            putfield com.microsoft.sqlserver.jdbc.SocketFinder.selectedException:Ljava/io/IOException;
         4: .line 2954
            iconst_1
            istore 3 /* updatedException */
         5: .line 2957
      StackMap locals:
      StackMap stack:
            iload 3 /* updatedException */
            ifeq 10
         6: .line 2958
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.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 10
         7: .line 2959
            getstatic com.microsoft.sqlserver.jdbc.SocketFinder.logger:Ljava/util/logging/Logger;
            new java.lang.StringBuilder
            dup
            ldc "The selected exception is updated to the following: ExceptionType:"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* ex */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         8: .line 2960
            ldc "; ExceptionMessage:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* ex */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "; by the following thread:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* traceId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 2959
            invokevirtual java.util.logging.Logger.finer:(Ljava/lang/String;)V
        10: .line 2963
      StackMap locals:
      StackMap stack:
            return
        end local 3 // boolean updatedException
        end local 2 // java.lang.String traceId
        end local 1 // java.io.IOException ex
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   11     0              this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
            0   11     1                ex  Ljava/io/IOException;
            0   11     2           traceId  Ljava/lang/String;
            1   11     3  updatedException  Z
    MethodParameters:
         Name  Flags
      ex       
      traceId  

  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.SocketFinder this
         0: .line 2971
            aload 0 /* this */
            getfield com.microsoft.sqlserver.jdbc.SocketFinder.traceID:Ljava/lang/String;
            areturn
        end local 0 // com.microsoft.sqlserver.jdbc.SocketFinder this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/microsoft/sqlserver/jdbc/SocketFinder;
}
SourceFile: "IOBuffer.java"
NestMembers:
  com.microsoft.sqlserver.jdbc.SocketFinder$Result
InnerClasses:
  final Result = com.microsoft.sqlserver.jdbc.SocketFinder$Result of com.microsoft.sqlserver.jdbc.SocketFinder