final class sun.security.ssl.X509KeyManagerImpl extends javax.net.ssl.X509ExtendedKeyManager implements javax.net.ssl.X509KeyManager
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.X509KeyManagerImpl
  super_class: javax.net.ssl.X509ExtendedKeyManager
{
  private static final sun.security.ssl.Debug debug;
    descriptor: Lsun/security/ssl/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final boolean useDebug;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static java.util.Date verificationDate;
    descriptor: Ljava/util/Date;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private final java.util.List<java.security.KeyStore$Builder> builders;
    descriptor: Ljava/util/List;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/List<Ljava/security/KeyStore$Builder;>;

  private final java.util.concurrent.atomic.AtomicLong uidCounter;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.Map<java.lang.String, java.lang.ref.Reference<java.security.KeyStore$PrivateKeyEntry>> entryCacheMap;
    descriptor: Ljava/util/Map;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/ref/Reference<Ljava/security/KeyStore$PrivateKeyEntry;>;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 64
            ldc "ssl"
            invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
            putstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
         1: .line 67
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 3
            ldc "keymanager"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 3
         2: .line 66
            iconst_1
            goto 4
      StackMap locals:
      StackMap stack:
         3: iconst_0
      StackMap locals:
      StackMap stack: int
         4: putstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
         5: .line 70
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.security.KeyStore$Builder);
    descriptor: (Ljava/security/KeyStore$Builder;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.security.KeyStore$Builder builder
         0: .line 82
            aload 0 /* this */
            aload 1 /* builder */
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
            invokespecial sun.security.ssl.X509KeyManagerImpl.<init>:(Ljava/util/List;)V
         1: .line 83
            return
        end local 1 // java.security.KeyStore$Builder builder
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lsun/security/ssl/X509KeyManagerImpl;
            0    2     1  builder  Ljava/security/KeyStore$Builder;
    MethodParameters:
         Name  Flags
      builder  

  void <init>(java.util.List<java.security.KeyStore$Builder>);
    descriptor: (Ljava/util/List;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.util.List builders
         0: .line 85
            aload 0 /* this */
            invokespecial javax.net.ssl.X509ExtendedKeyManager.<init>:()V
         1: .line 86
            aload 0 /* this */
            aload 1 /* builders */
            putfield sun.security.ssl.X509KeyManagerImpl.builders:Ljava/util/List;
         2: .line 87
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield sun.security.ssl.X509KeyManagerImpl.uidCounter:Ljava/util/concurrent/atomic/AtomicLong;
         3: .line 88
            aload 0 /* this */
         4: .line 89
            new sun.security.ssl.X509KeyManagerImpl$SizedMap
            dup
            invokespecial sun.security.ssl.X509KeyManagerImpl$SizedMap.<init>:()V
         5: .line 88
            invokestatic java.util.Collections.synchronizedMap:(Ljava/util/Map;)Ljava/util/Map;
            putfield sun.security.ssl.X509KeyManagerImpl.entryCacheMap:Ljava/util/Map;
         6: .line 90
            return
        end local 1 // java.util.List builders
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lsun/security/ssl/X509KeyManagerImpl;
            0    7     1  builders  Ljava/util/List<Ljava/security/KeyStore$Builder;>;
    Signature: (Ljava/util/List<Ljava/security/KeyStore$Builder;>;)V
    MethodParameters:
          Name  Flags
      builders  

  public java.security.cert.X509Certificate[] getCertificateChain(java.lang.String);
    descriptor: (Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String alias
         0: .line 108
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getEntry:(Ljava/lang/String;)Ljava/security/KeyStore$PrivateKeyEntry;
            astore 2 /* entry */
        start local 2 // java.security.KeyStore$PrivateKeyEntry entry
         1: .line 109
            aload 2 /* entry */
            ifnonnull 2
            aconst_null
            goto 3
         2: .line 110
      StackMap locals: java.security.KeyStore$PrivateKeyEntry
      StackMap stack:
            aload 2 /* entry */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate[]
         3: .line 109
      StackMap locals:
      StackMap stack: java.security.cert.X509Certificate[]
            areturn
        end local 2 // java.security.KeyStore$PrivateKeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lsun/security/ssl/X509KeyManagerImpl;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Ljava/security/KeyStore$PrivateKeyEntry;
    MethodParameters:
       Name  Flags
      alias  

  public java.security.PrivateKey getPrivateKey(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/PrivateKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String alias
         0: .line 115
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getEntry:(Ljava/lang/String;)Ljava/security/KeyStore$PrivateKeyEntry;
            astore 2 /* entry */
        start local 2 // java.security.KeyStore$PrivateKeyEntry entry
         1: .line 116
            aload 2 /* entry */
            ifnonnull 2
            aconst_null
            goto 3
      StackMap locals: java.security.KeyStore$PrivateKeyEntry
      StackMap stack:
         2: aload 2 /* entry */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getPrivateKey:()Ljava/security/PrivateKey;
      StackMap locals:
      StackMap stack: java.security.PrivateKey
         3: areturn
        end local 2 // java.security.KeyStore$PrivateKeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lsun/security/ssl/X509KeyManagerImpl;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Ljava/security/KeyStore$PrivateKeyEntry;
    MethodParameters:
       Name  Flags
      alias  

  public java.lang.String chooseClientAlias(java.lang.String[], java.security.Principal[], java.net.Socket);
    descriptor: ([Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String[] keyTypes
        start local 2 // java.security.Principal[] issuers
        start local 3 // java.net.Socket socket
         0: .line 122
            aload 0 /* this */
            aload 1 /* keyTypes */
            invokestatic sun.security.ssl.X509KeyManagerImpl.getKeyTypes:([Ljava/lang/String;)Ljava/util/List;
            aload 2 /* issuers */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.CLIENT:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
         1: .line 123
            aload 0 /* this */
            aload 3 /* socket */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljava/net/Socket;)Ljava/security/AlgorithmConstraints;
         2: .line 122
            invokevirtual sun.security.ssl.X509KeyManagerImpl.chooseAlias:(Ljava/util/List;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)Ljava/lang/String;
            areturn
        end local 3 // java.net.Socket socket
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.lang.String[] keyTypes
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lsun/security/ssl/X509KeyManagerImpl;
            0    3     1  keyTypes  [Ljava/lang/String;
            0    3     2   issuers  [Ljava/security/Principal;
            0    3     3    socket  Ljava/net/Socket;
    MethodParameters:
          Name  Flags
      keyTypes  
      issuers   
      socket    

  public java.lang.String chooseEngineClientAlias(java.lang.String[], java.security.Principal[], javax.net.ssl.SSLEngine);
    descriptor: ([Ljava/lang/String;[Ljava/security/Principal;Ljavax/net/ssl/SSLEngine;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String[] keyTypes
        start local 2 // java.security.Principal[] issuers
        start local 3 // javax.net.ssl.SSLEngine engine
         0: .line 129
            aload 0 /* this */
            aload 1 /* keyTypes */
            invokestatic sun.security.ssl.X509KeyManagerImpl.getKeyTypes:([Ljava/lang/String;)Ljava/util/List;
            aload 2 /* issuers */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.CLIENT:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
         1: .line 130
            aload 0 /* this */
            aload 3 /* engine */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljavax/net/ssl/SSLEngine;)Ljava/security/AlgorithmConstraints;
         2: .line 129
            invokevirtual sun.security.ssl.X509KeyManagerImpl.chooseAlias:(Ljava/util/List;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)Ljava/lang/String;
            areturn
        end local 3 // javax.net.ssl.SSLEngine engine
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.lang.String[] keyTypes
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lsun/security/ssl/X509KeyManagerImpl;
            0    3     1  keyTypes  [Ljava/lang/String;
            0    3     2   issuers  [Ljava/security/Principal;
            0    3     3    engine  Ljavax/net/ssl/SSLEngine;
    MethodParameters:
          Name  Flags
      keyTypes  
      issuers   
      engine    

  public java.lang.String chooseServerAlias(java.lang.String, java.security.Principal[], java.net.Socket);
    descriptor: (Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String keyType
        start local 2 // java.security.Principal[] issuers
        start local 3 // java.net.Socket socket
         0: .line 136
            aload 0 /* this */
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 1 /* keyType */
            aastore
            invokestatic sun.security.ssl.X509KeyManagerImpl.getKeyTypes:([Ljava/lang/String;)Ljava/util/List;
            aload 2 /* issuers */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.SERVER:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
         1: .line 137
            aload 0 /* this */
            aload 3 /* socket */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljava/net/Socket;)Ljava/security/AlgorithmConstraints;
         2: .line 138
            aload 3 /* socket */
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljava/net/Socket;)Ljava/util/List;
         3: .line 139
            ldc "HTTPS"
         4: .line 136
            invokevirtual sun.security.ssl.X509KeyManagerImpl.chooseAlias:(Ljava/util/List;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List;Ljava/lang/String;)Ljava/lang/String;
            areturn
        end local 3 // java.net.Socket socket
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.lang.String keyType
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lsun/security/ssl/X509KeyManagerImpl;
            0    5     1  keyType  Ljava/lang/String;
            0    5     2  issuers  [Ljava/security/Principal;
            0    5     3   socket  Ljava/net/Socket;
    MethodParameters:
         Name  Flags
      keyType  
      issuers  
      socket   

  public java.lang.String chooseEngineServerAlias(java.lang.String, java.security.Principal[], javax.net.ssl.SSLEngine);
    descriptor: (Ljava/lang/String;[Ljava/security/Principal;Ljavax/net/ssl/SSLEngine;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String keyType
        start local 2 // java.security.Principal[] issuers
        start local 3 // javax.net.ssl.SSLEngine engine
         0: .line 154
            aload 0 /* this */
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 1 /* keyType */
            aastore
            invokestatic sun.security.ssl.X509KeyManagerImpl.getKeyTypes:([Ljava/lang/String;)Ljava/util/List;
            aload 2 /* issuers */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.SERVER:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
         1: .line 155
            aload 0 /* this */
            aload 3 /* engine */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljavax/net/ssl/SSLEngine;)Ljava/security/AlgorithmConstraints;
         2: .line 156
            aload 3 /* engine */
            invokestatic sun.security.ssl.X509TrustManagerImpl.getRequestedServerNames:(Ljavax/net/ssl/SSLEngine;)Ljava/util/List;
         3: .line 157
            ldc "HTTPS"
         4: .line 154
            invokevirtual sun.security.ssl.X509KeyManagerImpl.chooseAlias:(Ljava/util/List;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List;Ljava/lang/String;)Ljava/lang/String;
            areturn
        end local 3 // javax.net.ssl.SSLEngine engine
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.lang.String keyType
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lsun/security/ssl/X509KeyManagerImpl;
            0    5     1  keyType  Ljava/lang/String;
            0    5     2  issuers  [Ljava/security/Principal;
            0    5     3   engine  Ljavax/net/ssl/SSLEngine;
    MethodParameters:
         Name  Flags
      keyType  
      issuers  
      engine   

  public java.lang.String[] getClientAliases(java.lang.String, java.security.Principal[]);
    descriptor: (Ljava/lang/String;[Ljava/security/Principal;)[Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String keyType
        start local 2 // java.security.Principal[] issuers
         0: .line 171
            aload 0 /* this */
            aload 1 /* keyType */
            aload 2 /* issuers */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.CLIENT:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            aconst_null
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAliases:(Ljava/lang/String;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)[Ljava/lang/String;
            areturn
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.lang.String keyType
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lsun/security/ssl/X509KeyManagerImpl;
            0    1     1  keyType  Ljava/lang/String;
            0    1     2  issuers  [Ljava/security/Principal;
    MethodParameters:
         Name  Flags
      keyType  
      issuers  

  public java.lang.String[] getServerAliases(java.lang.String, java.security.Principal[]);
    descriptor: (Ljava/lang/String;[Ljava/security/Principal;)[Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String keyType
        start local 2 // java.security.Principal[] issuers
         0: .line 176
            aload 0 /* this */
            aload 1 /* keyType */
            aload 2 /* issuers */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.SERVER:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            aconst_null
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAliases:(Ljava/lang/String;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)[Ljava/lang/String;
            areturn
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.lang.String keyType
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lsun/security/ssl/X509KeyManagerImpl;
            0    1     1  keyType  Ljava/lang/String;
            0    1     2  issuers  [Ljava/security/Principal;
    MethodParameters:
         Name  Flags
      keyType  
      issuers  

  private java.security.AlgorithmConstraints getAlgorithmConstraints(java.net.Socket);
    descriptor: (Ljava/net/Socket;)Ljava/security/AlgorithmConstraints;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=7, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.net.Socket socket
         0: .line 185
            aload 1 /* socket */
            ifnull 18
            aload 1 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 18
         1: .line 186
            aload 1 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 18
         2: .line 188
            aload 1 /* socket */
            checkcast javax.net.ssl.SSLSocket
            astore 2 /* sslSocket */
        start local 2 // javax.net.ssl.SSLSocket sslSocket
         3: .line 189
            aload 2 /* sslSocket */
            invokevirtual javax.net.ssl.SSLSocket.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
            astore 3 /* session */
        start local 3 // javax.net.ssl.SSLSession session
         4: .line 191
            aload 3 /* session */
            ifnull 17
         5: .line 193
            aload 3 /* session */
            invokeinterface javax.net.ssl.SSLSession.getProtocol:()Ljava/lang/String;
            invokestatic sun.security.ssl.ProtocolVersion.valueOf:(Ljava/lang/String;)Lsun/security/ssl/ProtocolVersion;
         6: .line 192
            astore 4 /* protocolVersion */
        start local 4 // sun.security.ssl.ProtocolVersion protocolVersion
         7: .line 194
            aload 4 /* protocolVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS12PlusSpec:()Z
            ifeq 17
         8: .line 195
            aconst_null
            astore 5 /* peerSupportedSignAlgs */
        start local 5 // java.lang.String[] peerSupportedSignAlgs
         9: .line 197
            aload 3 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 14
        10: .line 199
            aload 3 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
        11: .line 198
            astore 6 /* extSession */
        start local 6 // javax.net.ssl.ExtendedSSLSession extSession
        12: .line 201
            aload 6 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getPeerSupportedSignatureAlgorithms:()[Ljava/lang/String;
        13: .line 200
            astore 5 /* peerSupportedSignAlgs */
        end local 6 // javax.net.ssl.ExtendedSSLSession extSession
        14: .line 204
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.net.Socket javax.net.ssl.SSLSocket javax.net.ssl.SSLSession sun.security.ssl.ProtocolVersion java.lang.String[]
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        15: .line 205
            aload 2 /* sslSocket */
            aload 5 /* peerSupportedSignAlgs */
            iconst_1
        16: .line 204
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;[Ljava/lang/String;Z)V
            areturn
        end local 5 // java.lang.String[] peerSupportedSignAlgs
        end local 4 // sun.security.ssl.ProtocolVersion protocolVersion
        17: .line 209
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 2 /* sslSocket */
            iconst_1
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;Z)V
            areturn
        end local 3 // javax.net.ssl.SSLSession session
        end local 2 // javax.net.ssl.SSLSocket sslSocket
        18: .line 212
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aconst_null
            iconst_1
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;Z)V
            areturn
        end local 1 // java.net.Socket socket
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   19     0                   this  Lsun/security/ssl/X509KeyManagerImpl;
            0   19     1                 socket  Ljava/net/Socket;
            3   18     2              sslSocket  Ljavax/net/ssl/SSLSocket;
            4   18     3                session  Ljavax/net/ssl/SSLSession;
            7   17     4        protocolVersion  Lsun/security/ssl/ProtocolVersion;
            9   17     5  peerSupportedSignAlgs  [Ljava/lang/String;
           12   14     6             extSession  Ljavax/net/ssl/ExtendedSSLSession;
    MethodParameters:
        Name  Flags
      socket  

  private java.security.AlgorithmConstraints getAlgorithmConstraints(javax.net.ssl.SSLEngine);
    descriptor: (Ljavax/net/ssl/SSLEngine;)Ljava/security/AlgorithmConstraints;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // javax.net.ssl.SSLEngine engine
         0: .line 217
            aload 1 /* engine */
            ifnull 15
         1: .line 218
            aload 1 /* engine */
            invokevirtual javax.net.ssl.SSLEngine.getHandshakeSession:()Ljavax/net/ssl/SSLSession;
            astore 2 /* session */
        start local 2 // javax.net.ssl.SSLSession session
         2: .line 219
            aload 2 /* session */
            ifnull 15
         3: .line 221
            aload 2 /* session */
            invokeinterface javax.net.ssl.SSLSession.getProtocol:()Ljava/lang/String;
            invokestatic sun.security.ssl.ProtocolVersion.valueOf:(Ljava/lang/String;)Lsun/security/ssl/ProtocolVersion;
         4: .line 220
            astore 3 /* protocolVersion */
        start local 3 // sun.security.ssl.ProtocolVersion protocolVersion
         5: .line 222
            aload 3 /* protocolVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS12PlusSpec:()Z
            ifeq 15
         6: .line 223
            aconst_null
            astore 4 /* peerSupportedSignAlgs */
        start local 4 // java.lang.String[] peerSupportedSignAlgs
         7: .line 225
            aload 2 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 12
         8: .line 227
            aload 2 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
         9: .line 226
            astore 5 /* extSession */
        start local 5 // javax.net.ssl.ExtendedSSLSession extSession
        10: .line 229
            aload 5 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getPeerSupportedSignatureAlgorithms:()[Ljava/lang/String;
        11: .line 228
            astore 4 /* peerSupportedSignAlgs */
        end local 5 // javax.net.ssl.ExtendedSSLSession extSession
        12: .line 232
      StackMap locals: javax.net.ssl.SSLSession sun.security.ssl.ProtocolVersion java.lang.String[]
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        13: .line 233
            aload 1 /* engine */
            aload 4 /* peerSupportedSignAlgs */
            iconst_1
        14: .line 232
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;[Ljava/lang/String;Z)V
            areturn
        end local 4 // java.lang.String[] peerSupportedSignAlgs
        end local 3 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 2 // javax.net.ssl.SSLSession session
        15: .line 238
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 1 /* engine */
            iconst_1
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;Z)V
            areturn
        end local 1 // javax.net.ssl.SSLEngine engine
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   16     0                   this  Lsun/security/ssl/X509KeyManagerImpl;
            0   16     1                 engine  Ljavax/net/ssl/SSLEngine;
            2   15     2                session  Ljavax/net/ssl/SSLSession;
            5   15     3        protocolVersion  Lsun/security/ssl/ProtocolVersion;
            7   15     4  peerSupportedSignAlgs  [Ljava/lang/String;
           10   12     5             extSession  Ljavax/net/ssl/ExtendedSSLSession;
    MethodParameters:
        Name  Flags
      engine  

  private java.lang.String makeAlias(sun.security.ssl.X509KeyManagerImpl$EntryStatus);
    descriptor: (Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // sun.security.ssl.X509KeyManagerImpl$EntryStatus entry
         0: .line 246
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.uidCounter:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.incrementAndGet:()J
            invokestatic java.lang.String.valueOf:(J)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* entry */
            getfield sun.security.ssl.X509KeyManagerImpl$EntryStatus.builderIndex:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         1: .line 247
            aload 1 /* entry */
            getfield sun.security.ssl.X509KeyManagerImpl$EntryStatus.alias:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         2: .line 246
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 1 // sun.security.ssl.X509KeyManagerImpl$EntryStatus entry
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lsun/security/ssl/X509KeyManagerImpl;
            0    3     1  entry  Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;
    MethodParameters:
       Name  Flags
      entry  

  private java.security.KeyStore$PrivateKeyEntry getEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/KeyStore$PrivateKeyEntry;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=11, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String alias
         0: .line 252
            aload 1 /* alias */
            ifnonnull 2
         1: .line 253
            aconst_null
            areturn
         2: .line 257
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.entryCacheMap:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.ref.Reference
            astore 2 /* ref */
        start local 2 // java.lang.ref.Reference ref
         3: .line 258
            aload 2 /* ref */
            ifnull 4
            aload 2 /* ref */
            invokevirtual java.lang.ref.Reference.get:()Ljava/lang/Object;
            checkcast java.security.KeyStore$PrivateKeyEntry
            goto 5
      StackMap locals: java.lang.ref.Reference
      StackMap stack:
         4: aconst_null
      StackMap locals:
      StackMap stack: java.security.KeyStore$PrivateKeyEntry
         5: astore 3 /* entry */
        start local 3 // java.security.KeyStore$PrivateKeyEntry entry
         6: .line 259
            aload 3 /* entry */
            ifnull 8
         7: .line 260
            aload 3 /* entry */
            areturn
         8: .line 264
      StackMap locals: java.security.KeyStore$PrivateKeyEntry
      StackMap stack:
            aload 1 /* alias */
            bipush 46
            invokevirtual java.lang.String.indexOf:(I)I
            istore 4 /* firstDot */
        start local 4 // int firstDot
         9: .line 265
            aload 1 /* alias */
            bipush 46
            iload 4 /* firstDot */
            iconst_1
            iadd
            invokevirtual java.lang.String.indexOf:(II)I
            istore 5 /* secondDot */
        start local 5 // int secondDot
        10: .line 266
            iload 4 /* firstDot */
            iconst_m1
            if_icmpeq 11
            iload 5 /* secondDot */
            iload 4 /* firstDot */
            if_icmpne 12
        11: .line 268
      StackMap locals: int int
      StackMap stack:
            aconst_null
            areturn
        12: .line 272
      StackMap locals:
      StackMap stack:
            aload 1 /* alias */
            iload 4 /* firstDot */
            iconst_1
            iadd
            iload 5 /* secondDot */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
        13: .line 271
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            istore 6 /* builderIndex */
        start local 6 // int builderIndex
        14: .line 273
            aload 1 /* alias */
            iload 5 /* secondDot */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 7 /* keyStoreAlias */
        start local 7 // java.lang.String keyStoreAlias
        15: .line 274
            aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.builders:Ljava/util/List;
            iload 6 /* builderIndex */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.KeyStore$Builder
            astore 8 /* builder */
        start local 8 // java.security.KeyStore$Builder builder
        16: .line 275
            aload 8 /* builder */
            invokevirtual java.security.KeyStore$Builder.getKeyStore:()Ljava/security/KeyStore;
            astore 9 /* ks */
        start local 9 // java.security.KeyStore ks
        17: .line 276
            aload 9 /* ks */
        18: .line 277
            aload 7 /* keyStoreAlias */
            aload 8 /* builder */
            aload 1 /* alias */
            invokevirtual java.security.KeyStore$Builder.getProtectionParameter:(Ljava/lang/String;)Ljava/security/KeyStore$ProtectionParameter;
        19: .line 276
            invokevirtual java.security.KeyStore.getEntry:(Ljava/lang/String;Ljava/security/KeyStore$ProtectionParameter;)Ljava/security/KeyStore$Entry;
            astore 10 /* newEntry */
        start local 10 // java.security.KeyStore$Entry newEntry
        20: .line 278
            aload 10 /* newEntry */
            instanceof java.security.KeyStore$PrivateKeyEntry
            ifne 22
        21: .line 280
            aconst_null
            areturn
        22: .line 282
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.lang.String java.lang.ref.Reference java.security.KeyStore$PrivateKeyEntry int int int java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.security.KeyStore$Entry
      StackMap stack:
            aload 10 /* newEntry */
            checkcast java.security.KeyStore$PrivateKeyEntry
            astore 3 /* entry */
        23: .line 283
            aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.entryCacheMap:Ljava/util/Map;
            aload 1 /* alias */
            new java.lang.ref.SoftReference
            dup
            aload 3 /* entry */
            invokespecial java.lang.ref.SoftReference.<init>:(Ljava/lang/Object;)V
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        24: .line 284
            aload 3 /* entry */
        25: areturn
        end local 10 // java.security.KeyStore$Entry newEntry
        end local 9 // java.security.KeyStore ks
        end local 8 // java.security.KeyStore$Builder builder
        end local 7 // java.lang.String keyStoreAlias
        end local 6 // int builderIndex
        26: .line 285
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.lang.String java.lang.ref.Reference java.security.KeyStore$PrivateKeyEntry int int
      StackMap stack: java.lang.Exception
            pop
        27: .line 287
            aconst_null
            areturn
        end local 5 // int secondDot
        end local 4 // int firstDot
        end local 3 // java.security.KeyStore$PrivateKeyEntry entry
        end local 2 // java.lang.ref.Reference ref
        end local 1 // java.lang.String alias
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   28     0           this  Lsun/security/ssl/X509KeyManagerImpl;
            0   28     1          alias  Ljava/lang/String;
            3   28     2            ref  Ljava/lang/ref/Reference<Ljava/security/KeyStore$PrivateKeyEntry;>;
            6   28     3          entry  Ljava/security/KeyStore$PrivateKeyEntry;
            9   28     4       firstDot  I
           10   28     5      secondDot  I
           14   26     6   builderIndex  I
           15   26     7  keyStoreAlias  Ljava/lang/String;
           16   26     8        builder  Ljava/security/KeyStore$Builder;
           17   26     9             ks  Ljava/security/KeyStore;
           20   26    10       newEntry  Ljava/security/KeyStore$Entry;
      Exception table:
        from    to  target  type
          12    21      26  Class java.lang.Exception
          22    25      26  Class java.lang.Exception
    MethodParameters:
       Name  Flags
      alias  

  private static java.util.List<sun.security.ssl.X509KeyManagerImpl$KeyType> getKeyTypes(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)Ljava/util/List;
    flags: (0x008a) ACC_PRIVATE, ACC_STATIC, ACC_VARARGS
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // java.lang.String[] keyTypes
         0: .line 339
            aload 0 /* keyTypes */
            ifnull 2
         1: .line 340
            aload 0 /* keyTypes */
            arraylength
            ifeq 2
            aload 0 /* keyTypes */
            iconst_0
            aaload
            ifnonnull 3
         2: .line 341
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
         3: .line 343
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            aload 0 /* keyTypes */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 1 /* list */
        start local 1 // java.util.List list
         4: .line 344
            aload 0 /* keyTypes */
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 8
      StackMap locals: java.lang.String[] java.util.List top int int java.lang.String[]
      StackMap stack:
         5: aload 5
            iload 3
            aaload
            astore 2 /* keyType */
        start local 2 // java.lang.String keyType
         6: .line 345
            aload 1 /* list */
            new sun.security.ssl.X509KeyManagerImpl$KeyType
            dup
            aload 2 /* keyType */
            invokespecial sun.security.ssl.X509KeyManagerImpl$KeyType.<init>:(Ljava/lang/String;)V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // java.lang.String keyType
         7: .line 344
            iinc 3 1
      StackMap locals:
      StackMap stack:
         8: iload 3
            iload 4
            if_icmplt 5
         9: .line 347
            aload 1 /* list */
            areturn
        end local 1 // java.util.List list
        end local 0 // java.lang.String[] keyTypes
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   10     0  keyTypes  [Ljava/lang/String;
            4   10     1      list  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            6    7     2   keyType  Ljava/lang/String;
    Signature: ([Ljava/lang/String;)Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
    MethodParameters:
          Name  Flags
      keyTypes  

  private java.lang.String chooseAlias(java.util.List<sun.security.ssl.X509KeyManagerImpl$KeyType>, java.security.Principal[], sun.security.ssl.X509KeyManagerImpl$CheckType, java.security.AlgorithmConstraints);
    descriptor: (Ljava/util/List;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=5, args_size=5
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.util.List keyTypeList
        start local 2 // java.security.Principal[] issuers
        start local 3 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        start local 4 // java.security.AlgorithmConstraints constraints
         0: .line 366
            aload 0 /* this */
            aload 1 /* keyTypeList */
            aload 2 /* issuers */
         1: .line 367
            aload 3 /* checkType */
            aload 4 /* constraints */
            aconst_null
            aconst_null
         2: .line 366
            invokevirtual sun.security.ssl.X509KeyManagerImpl.chooseAlias:(Ljava/util/List;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List;Ljava/lang/String;)Ljava/lang/String;
            areturn
        end local 4 // java.security.AlgorithmConstraints constraints
        end local 3 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.util.List keyTypeList
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    3     0         this  Lsun/security/ssl/X509KeyManagerImpl;
            0    3     1  keyTypeList  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            0    3     2      issuers  [Ljava/security/Principal;
            0    3     3    checkType  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0    3     4  constraints  Ljava/security/AlgorithmConstraints;
    Signature: (Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)Ljava/lang/String;
    MethodParameters:
             Name  Flags
      keyTypeList  
      issuers      
      checkType    
      constraints  

  private java.lang.String chooseAlias(java.util.List<sun.security.ssl.X509KeyManagerImpl$KeyType>, java.security.Principal[], sun.security.ssl.X509KeyManagerImpl$CheckType, java.security.AlgorithmConstraints, java.util.List<javax.net.ssl.SNIServerName>, java.lang.String);
    descriptor: (Ljava/util/List;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List;Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=13, args_size=7
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.util.List keyTypeList
        start local 2 // java.security.Principal[] issuers
        start local 3 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        start local 4 // java.security.AlgorithmConstraints constraints
        start local 5 // java.util.List requestedServerNames
        start local 6 // java.lang.String idAlgorithm
         0: .line 374
            aload 1 /* keyTypeList */
            ifnull 1
            aload 1 /* keyTypeList */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 2
         1: .line 375
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
         2: .line 378
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* issuers */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getIssuerSet:([Ljava/security/Principal;)Ljava/util/Set;
            astore 7 /* issuerSet */
        start local 7 // java.util.Set issuerSet
         3: .line 379
            aconst_null
            astore 8 /* allResults */
        start local 8 // java.util.List allResults
         4: .line 380
            iconst_0
            istore 9 /* i */
        start local 9 // int i
         5: aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.builders:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            istore 10 /* n */
        start local 10 // int n
         6: goto 24
         7: .line 382
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.util.List java.security.Principal[] sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.util.Set java.util.List int int
      StackMap stack:
            aload 0 /* this */
            iload 9 /* i */
            aload 1 /* keyTypeList */
         8: .line 383
            aload 7 /* issuerSet */
            iconst_0
            aload 3 /* checkType */
            aload 4 /* constraints */
         9: .line 384
            aload 5 /* requestedServerNames */
            aload 6 /* idAlgorithm */
        10: .line 382
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAliases:(ILjava/util/List;Ljava/util/Set;ZLsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List;Ljava/lang/String;)Ljava/util/List;
            astore 11 /* results */
        start local 11 // java.util.List results
        11: .line 385
            aload 11 /* results */
            ifnull 23
        12: .line 389
            aload 11 /* results */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast sun.security.ssl.X509KeyManagerImpl$EntryStatus
            astore 12 /* status */
        start local 12 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        13: .line 390
            aload 12 /* status */
            getfield sun.security.ssl.X509KeyManagerImpl$EntryStatus.checkResult:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.OK:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
            if_acmpne 18
        14: .line 391
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 16
        15: .line 392
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            new java.lang.StringBuilder
            dup
            ldc "KeyMgr: choosing key: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 12 /* status */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        16: .line 394
      StackMap locals: java.util.List sun.security.ssl.X509KeyManagerImpl$EntryStatus
      StackMap stack:
            aload 0 /* this */
            aload 12 /* status */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.makeAlias:(Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;)Ljava/lang/String;
        17: areturn
        18: .line 396
      StackMap locals:
      StackMap stack:
            aload 8 /* allResults */
            ifnonnull 20
        19: .line 397
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 8 /* allResults */
        20: .line 399
      StackMap locals:
      StackMap stack:
            aload 8 /* allResults */
            aload 11 /* results */
            invokeinterface java.util.List.addAll:(Ljava/util/Collection;)Z
            pop
        end local 12 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        end local 11 // java.util.List results
        21: .line 401
            goto 23
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.util.List java.security.Principal[] sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.util.Set java.util.List int int
      StackMap stack: java.lang.Exception
        22: pop
        23: .line 380
      StackMap locals:
      StackMap stack:
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        24: iload 9 /* i */
            iload 10 /* n */
            if_icmplt 7
        end local 10 // int n
        end local 9 // int i
        25: .line 405
            aload 8 /* allResults */
            ifnonnull 29
        26: .line 406
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 28
        27: .line 407
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            ldc "KeyMgr: no matching key found"
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        28: .line 409
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        29: .line 411
      StackMap locals:
      StackMap stack:
            aload 8 /* allResults */
            invokestatic java.util.Collections.sort:(Ljava/util/List;)V
        30: .line 412
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 33
        31: .line 413
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            ldc "KeyMgr: no good matching key found, returning best match out of:"
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        32: .line 415
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            aload 8 /* allResults */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        33: .line 417
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 8 /* allResults */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast sun.security.ssl.X509KeyManagerImpl$EntryStatus
            invokevirtual sun.security.ssl.X509KeyManagerImpl.makeAlias:(Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;)Ljava/lang/String;
            areturn
        end local 8 // java.util.List allResults
        end local 7 // java.util.Set issuerSet
        end local 6 // java.lang.String idAlgorithm
        end local 5 // java.util.List requestedServerNames
        end local 4 // java.security.AlgorithmConstraints constraints
        end local 3 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.util.List keyTypeList
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   34     0                  this  Lsun/security/ssl/X509KeyManagerImpl;
            0   34     1           keyTypeList  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            0   34     2               issuers  [Ljava/security/Principal;
            0   34     3             checkType  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0   34     4           constraints  Ljava/security/AlgorithmConstraints;
            0   34     5  requestedServerNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
            0   34     6           idAlgorithm  Ljava/lang/String;
            3   34     7             issuerSet  Ljava/util/Set<Ljava/security/Principal;>;
            4   34     8            allResults  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
            5   25     9                     i  I
            6   25    10                     n  I
           11   21    11               results  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
           13   21    12                status  Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;
      Exception table:
        from    to  target  type
           7    17      22  Class java.lang.Exception
          18    21      22  Class java.lang.Exception
    Signature: (Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;Ljava/lang/String;)Ljava/lang/String;
    MethodParameters:
                      Name  Flags
      keyTypeList           
      issuers               
      checkType             
      constraints           
      requestedServerNames  
      idAlgorithm           

  public java.lang.String[] getAliases(java.lang.String, java.security.Principal[], sun.security.ssl.X509KeyManagerImpl$CheckType, java.security.AlgorithmConstraints);
    descriptor: (Ljava/lang/String;[Ljava/security/Principal;Lsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)[Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=11, args_size=5
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.lang.String keyType
        start local 2 // java.security.Principal[] issuers
        start local 3 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        start local 4 // java.security.AlgorithmConstraints constraints
         0: .line 428
            aload 1 /* keyType */
            ifnonnull 2
         1: .line 429
            aconst_null
            areturn
         2: .line 432
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* issuers */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getIssuerSet:([Ljava/security/Principal;)Ljava/util/Set;
            astore 5 /* issuerSet */
        start local 5 // java.util.Set issuerSet
         3: .line 433
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 1 /* keyType */
            aastore
            invokestatic sun.security.ssl.X509KeyManagerImpl.getKeyTypes:([Ljava/lang/String;)Ljava/util/List;
            astore 6 /* keyTypeList */
        start local 6 // java.util.List keyTypeList
         4: .line 434
            aconst_null
            astore 7 /* allResults */
        start local 7 // java.util.List allResults
         5: .line 435
            iconst_0
            istore 8 /* i */
        start local 8 // int i
         6: aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.builders:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            istore 9 /* n */
        start local 9 // int n
         7: goto 19
         8: .line 437
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.lang.String java.security.Principal[] sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.Set java.util.List java.util.List int int
      StackMap stack:
            aload 0 /* this */
            iload 8 /* i */
            aload 6 /* keyTypeList */
         9: .line 438
            aload 5 /* issuerSet */
            iconst_1
            aload 3 /* checkType */
            aload 4 /* constraints */
        10: .line 439
            aconst_null
            aconst_null
        11: .line 437
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAliases:(ILjava/util/List;Ljava/util/Set;ZLsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List;Ljava/lang/String;)Ljava/util/List;
            astore 10 /* results */
        start local 10 // java.util.List results
        12: .line 440
            aload 10 /* results */
            ifnull 18
        13: .line 441
            aload 7 /* allResults */
            ifnonnull 15
        14: .line 442
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 7 /* allResults */
        15: .line 444
      StackMap locals: java.util.List
      StackMap stack:
            aload 7 /* allResults */
            aload 10 /* results */
            invokeinterface java.util.List.addAll:(Ljava/util/Collection;)Z
            pop
        end local 10 // java.util.List results
        16: .line 446
            goto 18
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.lang.String java.security.Principal[] sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.Set java.util.List java.util.List int int
      StackMap stack: java.lang.Exception
        17: pop
        18: .line 435
      StackMap locals:
      StackMap stack:
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        19: iload 8 /* i */
            iload 9 /* n */
            if_icmplt 8
        end local 9 // int n
        end local 8 // int i
        20: .line 450
            aload 7 /* allResults */
            ifnull 21
            aload 7 /* allResults */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 24
        21: .line 451
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 23
        22: .line 452
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            ldc "KeyMgr: no matching alias found"
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        23: .line 454
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        24: .line 456
      StackMap locals:
      StackMap stack:
            aload 7 /* allResults */
            invokestatic java.util.Collections.sort:(Ljava/util/List;)V
        25: .line 457
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 27
        26: .line 458
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            new java.lang.StringBuilder
            dup
            ldc "KeyMgr: getting aliases: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* allResults */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        27: .line 460
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 7 /* allResults */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.toAliases:(Ljava/util/List;)[Ljava/lang/String;
            areturn
        end local 7 // java.util.List allResults
        end local 6 // java.util.List keyTypeList
        end local 5 // java.util.Set issuerSet
        end local 4 // java.security.AlgorithmConstraints constraints
        end local 3 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        end local 2 // java.security.Principal[] issuers
        end local 1 // java.lang.String keyType
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   28     0         this  Lsun/security/ssl/X509KeyManagerImpl;
            0   28     1      keyType  Ljava/lang/String;
            0   28     2      issuers  [Ljava/security/Principal;
            0   28     3    checkType  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0   28     4  constraints  Ljava/security/AlgorithmConstraints;
            3   28     5    issuerSet  Ljava/util/Set<Ljava/security/Principal;>;
            4   28     6  keyTypeList  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            5   28     7   allResults  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
            6   20     8            i  I
            7   20     9            n  I
           12   16    10      results  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
      Exception table:
        from    to  target  type
           8    16      17  Class java.lang.Exception
    MethodParameters:
             Name  Flags
      keyType      
      issuers      
      checkType    
      constraints  

  private java.lang.String[] toAliases(java.util.List<sun.security.ssl.X509KeyManagerImpl$EntryStatus>);
    descriptor: (Ljava/util/List;)[Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.util.List results
         0: .line 465
            aload 1 /* results */
            invokeinterface java.util.List.size:()I
            anewarray java.lang.String
            astore 2 /* s */
        start local 2 // java.lang.String[] s
         1: .line 466
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         2: .line 467
            aload 1 /* results */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 5
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.util.List java.lang.String[] int top java.util.Iterator
      StackMap stack:
         3: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.X509KeyManagerImpl$EntryStatus
            astore 4 /* result */
        start local 4 // sun.security.ssl.X509KeyManagerImpl$EntryStatus result
         4: .line 468
            aload 2 /* s */
            iload 3 /* i */
            iinc 3 /* i */ 1
            aload 0 /* this */
            aload 4 /* result */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.makeAlias:(Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;)Ljava/lang/String;
            aastore
        end local 4 // sun.security.ssl.X509KeyManagerImpl$EntryStatus result
         5: .line 467
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 470
            aload 2 /* s */
            areturn
        end local 3 // int i
        end local 2 // java.lang.String[] s
        end local 1 // java.util.List results
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lsun/security/ssl/X509KeyManagerImpl;
            0    7     1  results  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
            1    7     2        s  [Ljava/lang/String;
            2    7     3        i  I
            4    5     4   result  Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;
    Signature: (Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;)[Ljava/lang/String;
    MethodParameters:
         Name  Flags
      results  

  private java.util.Set<java.security.Principal> getIssuerSet(java.security.Principal[]);
    descriptor: ([Ljava/security/Principal;)Ljava/util/Set;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // java.security.Principal[] issuers
         0: .line 475
            aload 1 /* issuers */
            ifnull 2
            aload 1 /* issuers */
            arraylength
            ifeq 2
         1: .line 476
            new java.util.HashSet
            dup
            aload 1 /* issuers */
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            areturn
         2: .line 478
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 1 // java.security.Principal[] issuers
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lsun/security/ssl/X509KeyManagerImpl;
            0    3     1  issuers  [Ljava/security/Principal;
    Signature: ([Ljava/security/Principal;)Ljava/util/Set<Ljava/security/Principal;>;
    MethodParameters:
         Name  Flags
      issuers  

  private java.util.List<sun.security.ssl.X509KeyManagerImpl$EntryStatus> getAliases(int, java.util.List<sun.security.ssl.X509KeyManagerImpl$KeyType>, java.util.Set<java.security.Principal>, boolean, sun.security.ssl.X509KeyManagerImpl$CheckType, java.security.AlgorithmConstraints, java.util.List<javax.net.ssl.SNIServerName>, java.lang.String);
    descriptor: (ILjava/util/List;Ljava/util/Set;ZLsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List;Ljava/lang/String;)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=26, args_size=9
        start local 0 // sun.security.ssl.X509KeyManagerImpl this
        start local 1 // int builderIndex
        start local 2 // java.util.List keyTypes
        start local 3 // java.util.Set issuerSet
        start local 4 // boolean findAll
        start local 5 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        start local 6 // java.security.AlgorithmConstraints constraints
        start local 7 // java.util.List requestedServerNames
        start local 8 // java.lang.String idAlgorithm
         0: .line 719
            aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.builders:Ljava/util/List;
            iload 1 /* builderIndex */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast java.security.KeyStore$Builder
            astore 9 /* builder */
        start local 9 // java.security.KeyStore$Builder builder
         1: .line 720
            aload 9 /* builder */
            invokevirtual java.security.KeyStore$Builder.getKeyStore:()Ljava/security/KeyStore;
            astore 10 /* ks */
        start local 10 // java.security.KeyStore ks
         2: .line 721
            aconst_null
            astore 11 /* results */
        start local 11 // java.util.List results
         3: .line 722
            getstatic sun.security.ssl.X509KeyManagerImpl.verificationDate:Ljava/util/Date;
            astore 12 /* date */
        start local 12 // java.util.Date date
         4: .line 723
            iconst_0
            istore 13 /* preferred */
        start local 13 // boolean preferred
         5: .line 724
            aload 10 /* ks */
            invokevirtual java.security.KeyStore.aliases:()Ljava/util/Enumeration;
            astore 14 /* e */
        start local 14 // java.util.Enumeration e
         6: goto 82
         7: .line 725
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration
      StackMap stack:
            aload 14 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 15 /* alias */
        start local 15 // java.lang.String alias
         8: .line 727
            aload 10 /* ks */
            aload 15 /* alias */
            invokevirtual java.security.KeyStore.isKeyEntry:(Ljava/lang/String;)Z
            ifne 10
         9: .line 728
            goto 82
        10: .line 731
      StackMap locals: java.lang.String
      StackMap stack:
            aload 10 /* ks */
            aload 15 /* alias */
            invokevirtual java.security.KeyStore.getCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/Certificate;
            astore 16 /* chain */
        start local 16 // java.security.cert.Certificate[] chain
        11: .line 732
            aload 16 /* chain */
            ifnull 82
            aload 16 /* chain */
            arraylength
            ifne 13
        12: .line 734
            goto 82
        13: .line 737
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            iconst_0
            istore 17 /* incompatible */
        start local 17 // boolean incompatible
        14: .line 738
            aload 16 /* chain */
            dup
            astore 21
            arraylength
            istore 20
            iconst_0
            istore 19
            goto 20
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int top int int java.security.cert.Certificate[]
      StackMap stack:
        15: aload 21
            iload 19
            aaload
            astore 18 /* cert */
        start local 18 // java.security.cert.Certificate cert
        16: .line 739
            aload 18 /* cert */
            instanceof java.security.cert.X509Certificate
            ifne 19
        17: .line 741
            iconst_1
            istore 17 /* incompatible */
        18: .line 742
            goto 21
        end local 18 // java.security.cert.Certificate cert
        19: .line 738
      StackMap locals:
      StackMap stack:
            iinc 19 1
      StackMap locals:
      StackMap stack:
        20: iload 19
            iload 20
            if_icmplt 15
        21: .line 745
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int
      StackMap stack:
            iload 17 /* incompatible */
            ifeq 23
        22: .line 746
            goto 82
        23: .line 750
      StackMap locals:
      StackMap stack:
            iconst_m1
            istore 18 /* keyIndex */
        start local 18 // int keyIndex
        24: .line 751
            iconst_0
            istore 19 /* j */
        start local 19 // int j
        25: .line 752
            aload 2 /* keyTypes */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 21
            goto 31
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int int int top java.util.Iterator
      StackMap stack:
        26: aload 21
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.X509KeyManagerImpl$KeyType
            astore 20 /* keyType */
        start local 20 // sun.security.ssl.X509KeyManagerImpl$KeyType keyType
        27: .line 753
            aload 20 /* keyType */
            aload 16 /* chain */
            invokevirtual sun.security.ssl.X509KeyManagerImpl$KeyType.matches:([Ljava/security/cert/Certificate;)Z
            ifeq 30
        28: .line 754
            iload 19 /* j */
            istore 18 /* keyIndex */
        29: .line 755
            goto 32
        30: .line 757
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int int int sun.security.ssl.X509KeyManagerImpl$KeyType java.util.Iterator
      StackMap stack:
            iinc 19 /* j */ 1
        end local 20 // sun.security.ssl.X509KeyManagerImpl$KeyType keyType
        31: .line 752
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int int int top java.util.Iterator
      StackMap stack:
            aload 21
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 26
        32: .line 759
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int int int
      StackMap stack:
            iload 18 /* keyIndex */
            iconst_m1
            if_icmpne 38
        33: .line 760
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 82
        34: .line 761
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Ignoring alias "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        35: .line 762
            ldc ": key algorithm does not match"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        36: .line 761
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        37: .line 764
            goto 82
        38: .line 767
      StackMap locals:
      StackMap stack:
            aload 3 /* issuerSet */
            ifnull 54
        39: .line 768
            iconst_0
            istore 20 /* found */
        start local 20 // boolean found
        40: .line 769
            aload 16 /* chain */
            dup
            astore 24
            arraylength
            istore 23
            iconst_0
            istore 22
            goto 47
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int int int int top int int java.security.cert.Certificate[]
      StackMap stack:
        41: aload 24
            iload 22
            aaload
            astore 21 /* cert */
        start local 21 // java.security.cert.Certificate cert
        42: .line 770
            aload 21 /* cert */
            checkcast java.security.cert.X509Certificate
            astore 25 /* xcert */
        start local 25 // java.security.cert.X509Certificate xcert
        43: .line 771
            aload 3 /* issuerSet */
            aload 25 /* xcert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 46
        44: .line 772
            iconst_1
            istore 20 /* found */
        45: .line 773
            goto 48
        end local 25 // java.security.cert.X509Certificate xcert
        end local 21 // java.security.cert.Certificate cert
        46: .line 769
      StackMap locals:
      StackMap stack:
            iinc 22 1
      StackMap locals:
      StackMap stack:
        47: iload 22
            iload 23
            if_icmplt 41
        48: .line 776
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration java.lang.String java.security.cert.Certificate[] int int int int
      StackMap stack:
            iload 20 /* found */
            ifne 54
        49: .line 777
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 82
        50: .line 778
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Ignoring alias "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        51: .line 779
            ldc ": issuers do not match"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        52: .line 778
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        53: .line 781
            goto 82
        end local 20 // boolean found
        54: .line 786
      StackMap locals:
      StackMap stack:
            aload 6 /* constraints */
            ifnull 65
        55: .line 787
            aload 6 /* constraints */
            aload 16 /* chain */
        56: .line 788
            aload 5 /* checkType */
            invokevirtual sun.security.ssl.X509KeyManagerImpl$CheckType.getValidator:()Ljava/lang/String;
        57: .line 787
            invokestatic sun.security.ssl.X509KeyManagerImpl.conformsToAlgorithmConstraints:(Ljava/security/AlgorithmConstraints;[Ljava/security/cert/Certificate;Ljava/lang/String;)Z
        58: .line 788
            ifne 65
        59: .line 790
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 82
        60: .line 791
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Ignoring alias "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        61: .line 792
            ldc ": certificate list does not conform to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        62: .line 793
            ldc "algorithm constraints"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        63: .line 791
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        64: .line 795
            goto 82
        65: .line 798
      StackMap locals:
      StackMap stack:
            aload 12 /* date */
            ifnonnull 67
        66: .line 799
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 12 /* date */
        67: .line 802
      StackMap locals:
      StackMap stack:
            aload 5 /* checkType */
            aload 16 /* chain */
            iconst_0
            aaload
            checkcast java.security.cert.X509Certificate
            aload 12 /* date */
        68: .line 803
            aload 7 /* requestedServerNames */
            aload 8 /* idAlgorithm */
        69: .line 802
            invokevirtual sun.security.ssl.X509KeyManagerImpl$CheckType.check:(Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List;Ljava/lang/String;)Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        70: .line 801
            astore 20 /* checkResult */
        start local 20 // sun.security.ssl.X509KeyManagerImpl$CheckResult checkResult
        71: .line 805
            new sun.security.ssl.X509KeyManagerImpl$EntryStatus
            dup
            iload 1 /* builderIndex */
            iload 18 /* keyIndex */
        72: .line 806
            aload 15 /* alias */
            aload 16 /* chain */
            aload 20 /* checkResult */
        73: .line 805
            invokespecial sun.security.ssl.X509KeyManagerImpl$EntryStatus.<init>:(IILjava/lang/String;[Ljava/security/cert/Certificate;Lsun/security/ssl/X509KeyManagerImpl$CheckResult;)V
        74: .line 804
            astore 21 /* status */
        start local 21 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        75: .line 807
            iload 13 /* preferred */
            ifne 77
            aload 20 /* checkResult */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.OK:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
            if_acmpne 77
            iload 18 /* keyIndex */
            ifne 77
        76: .line 808
            iconst_1
            istore 13 /* preferred */
        77: .line 810
      StackMap locals: sun.security.ssl.X509KeyManagerImpl$CheckResult sun.security.ssl.X509KeyManagerImpl$EntryStatus
      StackMap stack:
            iload 13 /* preferred */
            ifeq 79
            iload 4 /* findAll */
            ifne 79
        78: .line 813
            aload 21 /* status */
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
            areturn
        79: .line 815
      StackMap locals:
      StackMap stack:
            aload 11 /* results */
            ifnonnull 81
        80: .line 816
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 11 /* results */
        81: .line 818
      StackMap locals:
      StackMap stack:
            aload 11 /* results */
            aload 21 /* status */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 21 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        end local 20 // sun.security.ssl.X509KeyManagerImpl$CheckResult checkResult
        end local 19 // int j
        end local 18 // int keyIndex
        end local 17 // boolean incompatible
        end local 16 // java.security.cert.Certificate[] chain
        end local 15 // java.lang.String alias
        82: .line 724
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.List java.lang.String java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration
      StackMap stack:
            aload 14 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 7
        end local 14 // java.util.Enumeration e
        83: .line 821
            aload 11 /* results */
            areturn
        end local 13 // boolean preferred
        end local 12 // java.util.Date date
        end local 11 // java.util.List results
        end local 10 // java.security.KeyStore ks
        end local 9 // java.security.KeyStore$Builder builder
        end local 8 // java.lang.String idAlgorithm
        end local 7 // java.util.List requestedServerNames
        end local 6 // java.security.AlgorithmConstraints constraints
        end local 5 // sun.security.ssl.X509KeyManagerImpl$CheckType checkType
        end local 4 // boolean findAll
        end local 3 // java.util.Set issuerSet
        end local 2 // java.util.List keyTypes
        end local 1 // int builderIndex
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   84     0                  this  Lsun/security/ssl/X509KeyManagerImpl;
            0   84     1          builderIndex  I
            0   84     2              keyTypes  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            0   84     3             issuerSet  Ljava/util/Set<Ljava/security/Principal;>;
            0   84     4               findAll  Z
            0   84     5             checkType  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0   84     6           constraints  Ljava/security/AlgorithmConstraints;
            0   84     7  requestedServerNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
            0   84     8           idAlgorithm  Ljava/lang/String;
            1   84     9               builder  Ljava/security/KeyStore$Builder;
            2   84    10                    ks  Ljava/security/KeyStore;
            3   84    11               results  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
            4   84    12                  date  Ljava/util/Date;
            5   84    13             preferred  Z
            6   83    14                     e  Ljava/util/Enumeration<Ljava/lang/String;>;
            8   82    15                 alias  Ljava/lang/String;
           11   82    16                 chain  [Ljava/security/cert/Certificate;
           14   82    17          incompatible  Z
           16   19    18                  cert  Ljava/security/cert/Certificate;
           24   82    18              keyIndex  I
           25   82    19                     j  I
           27   31    20               keyType  Lsun/security/ssl/X509KeyManagerImpl$KeyType;
           40   54    20                 found  Z
           42   46    21                  cert  Ljava/security/cert/Certificate;
           43   46    25                 xcert  Ljava/security/cert/X509Certificate;
           71   82    20           checkResult  Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
           75   82    21                status  Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;
    Exceptions:
      throws java.lang.Exception
    Signature: (ILjava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;Ljava/util/Set<Ljava/security/Principal;>;ZLsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;Ljava/lang/String;)Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
    MethodParameters:
                      Name  Flags
      builderIndex          
      keyTypes              
      issuerSet             
      findAll               
      checkType             
      constraints           
      requestedServerNames  
      idAlgorithm           

  private static boolean conformsToAlgorithmConstraints(java.security.AlgorithmConstraints, java.security.cert.Certificate[], java.lang.String);
    descriptor: (Ljava/security/AlgorithmConstraints;[Ljava/security/cert/Certificate;Ljava/lang/String;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=7, args_size=3
        start local 0 // java.security.AlgorithmConstraints constraints
        start local 1 // java.security.cert.Certificate[] chain
        start local 2 // java.lang.String variant
         0: .line 828
            new sun.security.provider.certpath.AlgorithmChecker
            dup
            aload 0 /* constraints */
            aconst_null
            aload 2 /* variant */
            invokespecial sun.security.provider.certpath.AlgorithmChecker.<init>:(Ljava/security/AlgorithmConstraints;Ljava/security/Timestamp;Ljava/lang/String;)V
            astore 3 /* checker */
        start local 3 // sun.security.provider.certpath.AlgorithmChecker checker
         1: .line 830
            aload 3 /* checker */
            iconst_0
            invokevirtual sun.security.provider.certpath.AlgorithmChecker.init:(Z)V
         2: .line 831
            goto 9
      StackMap locals: java.security.AlgorithmConstraints java.security.cert.Certificate[] java.lang.String sun.security.provider.certpath.AlgorithmChecker
      StackMap stack: java.security.cert.CertPathValidatorException
         3: astore 4 /* cpve */
        start local 4 // java.security.cert.CertPathValidatorException cpve
         4: .line 833
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 8
         5: .line 834
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
         6: .line 835
            new java.lang.StringBuilder
            dup
            ldc "Cannot initialize algorithm constraints checker: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* cpve */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         7: .line 834
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
         8: .line 838
      StackMap locals: java.security.cert.CertPathValidatorException
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // java.security.cert.CertPathValidatorException cpve
         9: .line 842
      StackMap locals:
      StackMap stack:
            aload 1 /* chain */
            arraylength
            iconst_1
            isub
            istore 4 /* i */
        start local 4 // int i
        10: goto 21
        11: .line 843
      StackMap locals: int
      StackMap stack:
            aload 1 /* chain */
            iload 4 /* i */
            aaload
            astore 5 /* cert */
        start local 5 // java.security.cert.Certificate cert
        12: .line 846
            aload 3 /* checker */
            aload 5 /* cert */
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            invokevirtual sun.security.provider.certpath.AlgorithmChecker.check:(Ljava/security/cert/Certificate;Ljava/util/Collection;)V
        13: .line 847
            goto 20
      StackMap locals: java.security.AlgorithmConstraints java.security.cert.Certificate[] java.lang.String sun.security.provider.certpath.AlgorithmChecker int java.security.cert.Certificate
      StackMap stack: java.security.cert.CertPathValidatorException
        14: astore 6 /* cpve */
        start local 6 // java.security.cert.CertPathValidatorException cpve
        15: .line 848
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 19
        16: .line 849
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Certificate ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* cert */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        17: .line 850
            ldc ") does not conform to algorithm constraints: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* cpve */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 849
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        19: .line 853
      StackMap locals: java.security.cert.CertPathValidatorException
      StackMap stack:
            iconst_0
            ireturn
        end local 6 // java.security.cert.CertPathValidatorException cpve
        end local 5 // java.security.cert.Certificate cert
        20: .line 842
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ -1
      StackMap locals:
      StackMap stack:
        21: iload 4 /* i */
            ifge 11
        end local 4 // int i
        22: .line 857
            iconst_1
            ireturn
        end local 3 // sun.security.provider.certpath.AlgorithmChecker checker
        end local 2 // java.lang.String variant
        end local 1 // java.security.cert.Certificate[] chain
        end local 0 // java.security.AlgorithmConstraints constraints
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   23     0  constraints  Ljava/security/AlgorithmConstraints;
            0   23     1        chain  [Ljava/security/cert/Certificate;
            0   23     2      variant  Ljava/lang/String;
            1   23     3      checker  Lsun/security/provider/certpath/AlgorithmChecker;
            4    9     4         cpve  Ljava/security/cert/CertPathValidatorException;
           10   22     4            i  I
           12   20     5         cert  Ljava/security/cert/Certificate;
           15   20     6         cpve  Ljava/security/cert/CertPathValidatorException;
      Exception table:
        from    to  target  type
           1     2       3  Class java.security.cert.CertPathValidatorException
          12    13      14  Class java.security.cert.CertPathValidatorException
    MethodParameters:
             Name  Flags
      constraints  
      chain        
      variant      
}
SourceFile: "X509KeyManagerImpl.java"
NestMembers:
  sun.security.ssl.X509KeyManagerImpl$CheckResult  sun.security.ssl.X509KeyManagerImpl$CheckType  sun.security.ssl.X509KeyManagerImpl$EntryStatus  sun.security.ssl.X509KeyManagerImpl$KeyType  sun.security.ssl.X509KeyManagerImpl$SizedMap
InnerClasses:
  public abstract Builder = java.security.KeyStore$Builder of java.security.KeyStore
  public abstract Entry = java.security.KeyStore$Entry of java.security.KeyStore
  public final PrivateKeyEntry = java.security.KeyStore$PrivateKeyEntry of java.security.KeyStore
  public abstract ProtectionParameter = java.security.KeyStore$ProtectionParameter of java.security.KeyStore
  private final CheckResult = sun.security.ssl.X509KeyManagerImpl$CheckResult of sun.security.ssl.X509KeyManagerImpl
  private final CheckType = sun.security.ssl.X509KeyManagerImpl$CheckType of sun.security.ssl.X509KeyManagerImpl
  private EntryStatus = sun.security.ssl.X509KeyManagerImpl$EntryStatus of sun.security.ssl.X509KeyManagerImpl
  private KeyType = sun.security.ssl.X509KeyManagerImpl$KeyType of sun.security.ssl.X509KeyManagerImpl
  private SizedMap = sun.security.ssl.X509KeyManagerImpl$SizedMap of sun.security.ssl.X509KeyManagerImpl