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 107
            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 108
            aload 2 /* entry */
            ifnonnull 2
            aconst_null
            goto 3
         2: .line 109
      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 108
      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 113
            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 114
            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 119
            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 120
            aload 0 /* this */
            aload 3 /* socket */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljava/net/Socket;)Ljava/security/AlgorithmConstraints;
         2: .line 119
            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 125
            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 126
            aload 0 /* this */
            aload 3 /* engine */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljavax/net/ssl/SSLEngine;)Ljava/security/AlgorithmConstraints;
         2: .line 125
            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=6, 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 131
            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 132
            aload 0 /* this */
            aload 3 /* socket */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljava/net/Socket;)Ljava/security/AlgorithmConstraints;
         2: .line 131
            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 keyType
        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  keyType  Ljava/lang/String;
            0    3     2  issuers  [Ljava/security/Principal;
            0    3     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=6, 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 137
            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 138
            aload 0 /* this */
            aload 3 /* engine */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAlgorithmConstraints:(Ljavax/net/ssl/SSLEngine;)Ljava/security/AlgorithmConstraints;
         2: .line 137
            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 keyType
        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  keyType  Ljava/lang/String;
            0    3     2  issuers  [Ljava/security/Principal;
            0    3     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 142
            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 146
            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 155
            aload 1 /* socket */
            ifnull 18
            aload 1 /* socket */
            invokevirtual java.net.Socket.isConnected:()Z
            ifeq 18
         1: .line 156
            aload 1 /* socket */
            instanceof javax.net.ssl.SSLSocket
            ifeq 18
         2: .line 158
            aload 1 /* socket */
            checkcast javax.net.ssl.SSLSocket
            astore 2 /* sslSocket */
        start local 2 // javax.net.ssl.SSLSocket sslSocket
         3: .line 159
            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 161
            aload 3 /* session */
            ifnull 17
         5: .line 163
            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 162
            astore 4 /* protocolVersion */
        start local 4 // sun.security.ssl.ProtocolVersion protocolVersion
         7: .line 164
            aload 4 /* protocolVersion */
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmplt 17
         8: .line 165
            aconst_null
            astore 5 /* peerSupportedSignAlgs */
        start local 5 // java.lang.String[] peerSupportedSignAlgs
         9: .line 167
            aload 3 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 14
        10: .line 169
            aload 3 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
        11: .line 168
            astore 6 /* extSession */
        start local 6 // javax.net.ssl.ExtendedSSLSession extSession
        12: .line 171
            aload 6 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getPeerSupportedSignatureAlgorithms:()[Ljava/lang/String;
        13: .line 170
            astore 5 /* peerSupportedSignAlgs */
        end local 6 // javax.net.ssl.ExtendedSSLSession extSession
        14: .line 174
      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 175
            aload 2 /* sslSocket */
            aload 5 /* peerSupportedSignAlgs */
            iconst_1
        16: .line 174
            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 179
      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 182
      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 187
            aload 1 /* engine */
            ifnull 15
         1: .line 188
            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 189
            aload 2 /* session */
            ifnull 15
         3: .line 191
            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 190
            astore 3 /* protocolVersion */
        start local 3 // sun.security.ssl.ProtocolVersion protocolVersion
         5: .line 192
            aload 3 /* protocolVersion */
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmplt 15
         6: .line 193
            aconst_null
            astore 4 /* peerSupportedSignAlgs */
        start local 4 // java.lang.String[] peerSupportedSignAlgs
         7: .line 195
            aload 2 /* session */
            instanceof javax.net.ssl.ExtendedSSLSession
            ifeq 12
         8: .line 197
            aload 2 /* session */
            checkcast javax.net.ssl.ExtendedSSLSession
         9: .line 196
            astore 5 /* extSession */
        start local 5 // javax.net.ssl.ExtendedSSLSession extSession
        10: .line 199
            aload 5 /* extSession */
            invokevirtual javax.net.ssl.ExtendedSSLSession.getPeerSupportedSignatureAlgorithms:()[Ljava/lang/String;
        11: .line 198
            astore 4 /* peerSupportedSignAlgs */
        end local 5 // javax.net.ssl.ExtendedSSLSession extSession
        12: .line 202
      StackMap locals: javax.net.ssl.SSLSession sun.security.ssl.ProtocolVersion java.lang.String[]
      StackMap stack:
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
        13: .line 203
            aload 1 /* engine */
            aload 4 /* peerSupportedSignAlgs */
            iconst_1
        14: .line 202
            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 208
      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 216
            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 217
            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 216
            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 222
            aload 1 /* alias */
            ifnonnull 2
         1: .line 223
            aconst_null
            areturn
         2: .line 227
      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 228
            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 229
            aload 3 /* entry */
            ifnull 8
         7: .line 230
            aload 3 /* entry */
            areturn
         8: .line 234
      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 235
            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 236
            iload 4 /* firstDot */
            iconst_m1
            if_icmpeq 11
            iload 5 /* secondDot */
            iload 4 /* firstDot */
            if_icmpne 12
        11: .line 238
      StackMap locals: int int
      StackMap stack:
            aconst_null
            areturn
        12: .line 242
      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 241
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            istore 6 /* builderIndex */
        start local 6 // int builderIndex
        14: .line 243
            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 244
            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 245
            aload 8 /* builder */
            invokevirtual java.security.KeyStore$Builder.getKeyStore:()Ljava/security/KeyStore;
            astore 9 /* ks */
        start local 9 // java.security.KeyStore ks
        17: .line 246
            aload 9 /* ks */
        18: .line 247
            aload 7 /* keyStoreAlias */
            aload 8 /* builder */
            aload 1 /* alias */
            invokevirtual java.security.KeyStore$Builder.getProtectionParameter:(Ljava/lang/String;)Ljava/security/KeyStore$ProtectionParameter;
        19: .line 246
            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 248
            aload 10 /* newEntry */
            instanceof java.security.KeyStore$PrivateKeyEntry
            ifne 22
        21: .line 250
            aconst_null
            areturn
        22: .line 252
      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 253
            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 254
            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 255
      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 257
            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 309
            aload 0 /* keyTypes */
            ifnull 2
         1: .line 310
            aload 0 /* keyTypes */
            arraylength
            ifeq 2
            aload 0 /* keyTypes */
            iconst_0
            aaload
            ifnonnull 3
         2: .line 311
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
         3: .line 313
      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 314
            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 315
            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 314
            iinc 3 1
      StackMap locals:
      StackMap stack:
         8: iload 3
            iload 4
            if_icmplt 5
         9: .line 317
            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=11, 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 335
            aload 1 /* keyTypeList */
            ifnull 1
            aload 1 /* keyTypeList */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 2
         1: .line 336
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
         2: .line 339
      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 340
            aconst_null
            astore 6 /* allResults */
        start local 6 // java.util.List allResults
         4: .line 341
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         5: aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl.builders:Ljava/util/List;
            invokeinterface java.util.List.size:()I
            istore 8 /* n */
        start local 8 // int n
         6: goto 23
         7: .line 343
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.util.List java.security.Principal[] sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.Set java.util.List int int
      StackMap stack:
            aload 0 /* this */
            iload 7 /* i */
            aload 1 /* keyTypeList */
         8: .line 344
            aload 5 /* issuerSet */
            iconst_0
            aload 3 /* checkType */
            aload 4 /* constraints */
         9: .line 343
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAliases:(ILjava/util/List;Ljava/util/Set;ZLsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)Ljava/util/List;
            astore 9 /* results */
        start local 9 // java.util.List results
        10: .line 345
            aload 9 /* results */
            ifnull 22
        11: .line 349
            aload 9 /* results */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast sun.security.ssl.X509KeyManagerImpl$EntryStatus
            astore 10 /* status */
        start local 10 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        12: .line 350
            aload 10 /* 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 17
        13: .line 351
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 15
        14: .line 352
            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 10 /* 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
        15: .line 354
      StackMap locals: java.util.List sun.security.ssl.X509KeyManagerImpl$EntryStatus
      StackMap stack:
            aload 0 /* this */
            aload 10 /* status */
            invokevirtual sun.security.ssl.X509KeyManagerImpl.makeAlias:(Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;)Ljava/lang/String;
        16: areturn
        17: .line 356
      StackMap locals:
      StackMap stack:
            aload 6 /* allResults */
            ifnonnull 19
        18: .line 357
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 6 /* allResults */
        19: .line 359
      StackMap locals:
      StackMap stack:
            aload 6 /* allResults */
            aload 9 /* results */
            invokeinterface java.util.List.addAll:(Ljava/util/Collection;)Z
            pop
        end local 10 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        end local 9 // java.util.List results
        20: .line 361
            goto 22
      StackMap locals: sun.security.ssl.X509KeyManagerImpl java.util.List java.security.Principal[] sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.util.Set java.util.List int int
      StackMap stack: java.lang.Exception
        21: pop
        22: .line 341
      StackMap locals:
      StackMap stack:
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        23: iload 7 /* i */
            iload 8 /* n */
            if_icmplt 7
        end local 8 // int n
        end local 7 // int i
        24: .line 365
            aload 6 /* allResults */
            ifnonnull 28
        25: .line 366
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 27
        26: .line 367
            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
        27: .line 369
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        28: .line 371
      StackMap locals:
      StackMap stack:
            aload 6 /* allResults */
            invokestatic java.util.Collections.sort:(Ljava/util/List;)V
        29: .line 372
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 32
        30: .line 373
            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
        31: .line 375
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
            aload 6 /* allResults */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        32: .line 377
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 6 /* 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 6 // java.util.List allResults
        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.util.List keyTypeList
        end local 0 // sun.security.ssl.X509KeyManagerImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   33     0         this  Lsun/security/ssl/X509KeyManagerImpl;
            0   33     1  keyTypeList  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            0   33     2      issuers  [Ljava/security/Principal;
            0   33     3    checkType  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0   33     4  constraints  Ljava/security/AlgorithmConstraints;
            3   33     5    issuerSet  Ljava/util/Set<Ljava/security/Principal;>;
            4   33     6   allResults  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
            5   24     7            i  I
            6   24     8            n  I
           10   20     9      results  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
           12   20    10       status  Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;
      Exception table:
        from    to  target  type
           7    16      21  Class java.lang.Exception
          17    20      21  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/lang/String;
    MethodParameters:
             Name  Flags
      keyTypeList  
      issuers      
      checkType    
      constraints  

  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=7, 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 388
            aload 1 /* keyType */
            ifnonnull 2
         1: .line 389
            aconst_null
            areturn
         2: .line 392
      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 393
            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 394
            aconst_null
            astore 7 /* allResults */
        start local 7 // java.util.List allResults
         5: .line 395
            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 18
         8: .line 397
      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 398
            aload 5 /* issuerSet */
            iconst_1
            aload 3 /* checkType */
            aload 4 /* constraints */
        10: .line 397
            invokevirtual sun.security.ssl.X509KeyManagerImpl.getAliases:(ILjava/util/List;Ljava/util/Set;ZLsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)Ljava/util/List;
            astore 10 /* results */
        start local 10 // java.util.List results
        11: .line 399
            aload 10 /* results */
            ifnull 17
        12: .line 400
            aload 7 /* allResults */
            ifnonnull 14
        13: .line 401
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 7 /* allResults */
        14: .line 403
      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
        15: .line 405
            goto 17
      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
        16: pop
        17: .line 395
      StackMap locals:
      StackMap stack:
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 8 /* i */
            iload 9 /* n */
            if_icmplt 8
        end local 9 // int n
        end local 8 // int i
        19: .line 409
            aload 7 /* allResults */
            ifnull 20
            aload 7 /* allResults */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 23
        20: .line 410
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 22
        21: .line 411
            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
        22: .line 413
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        23: .line 415
      StackMap locals:
      StackMap stack:
            aload 7 /* allResults */
            invokestatic java.util.Collections.sort:(Ljava/util/List;)V
        24: .line 416
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 26
        25: .line 417
            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
        26: .line 419
      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   27     0         this  Lsun/security/ssl/X509KeyManagerImpl;
            0   27     1      keyType  Ljava/lang/String;
            0   27     2      issuers  [Ljava/security/Principal;
            0   27     3    checkType  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0   27     4  constraints  Ljava/security/AlgorithmConstraints;
            3   27     5    issuerSet  Ljava/util/Set<Ljava/security/Principal;>;
            4   27     6  keyTypeList  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            5   27     7   allResults  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
            6   19     8            i  I
            7   19     9            n  I
           11   15    10      results  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
      Exception table:
        from    to  target  type
           8    15      16  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 424
            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 425
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         2: .line 426
            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 427
            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 426
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 429
            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 434
            aload 1 /* issuers */
            ifnull 2
            aload 1 /* issuers */
            arraylength
            ifeq 2
         1: .line 435
            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 437
      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);
    descriptor: (ILjava/util/List;Ljava/util/Set;ZLsun/security/ssl/X509KeyManagerImpl$CheckType;Ljava/security/AlgorithmConstraints;)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=24, args_size=7
        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
         0: .line 630
            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 7 /* builder */
        start local 7 // java.security.KeyStore$Builder builder
         1: .line 631
            aload 7 /* builder */
            invokevirtual java.security.KeyStore$Builder.getKeyStore:()Ljava/security/KeyStore;
            astore 8 /* ks */
        start local 8 // java.security.KeyStore ks
         2: .line 632
            aconst_null
            astore 9 /* results */
        start local 9 // java.util.List results
         3: .line 633
            getstatic sun.security.ssl.X509KeyManagerImpl.verificationDate:Ljava/util/Date;
            astore 10 /* date */
        start local 10 // java.util.Date date
         4: .line 634
            iconst_0
            istore 11 /* preferred */
        start local 11 // boolean preferred
         5: .line 635
            aload 8 /* ks */
            invokevirtual java.security.KeyStore.aliases:()Ljava/util/Enumeration;
            astore 12 /* e */
        start local 12 // java.util.Enumeration e
         6: goto 80
         7: .line 636
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration
      StackMap stack:
            aload 12 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 13 /* alias */
        start local 13 // java.lang.String alias
         8: .line 638
            aload 8 /* ks */
            aload 13 /* alias */
            invokevirtual java.security.KeyStore.isKeyEntry:(Ljava/lang/String;)Z
            ifne 10
         9: .line 639
            goto 80
        10: .line 642
      StackMap locals: java.lang.String
      StackMap stack:
            aload 8 /* ks */
            aload 13 /* alias */
            invokevirtual java.security.KeyStore.getCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/Certificate;
            astore 14 /* chain */
        start local 14 // java.security.cert.Certificate[] chain
        11: .line 643
            aload 14 /* chain */
            ifnull 80
            aload 14 /* chain */
            arraylength
            ifne 13
        12: .line 645
            goto 80
        13: .line 648
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            iconst_0
            istore 15 /* incompatible */
        start local 15 // boolean incompatible
        14: .line 649
            aload 14 /* chain */
            dup
            astore 19
            arraylength
            istore 18
            iconst_0
            istore 17
            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.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 19
            iload 17
            aaload
            astore 16 /* cert */
        start local 16 // java.security.cert.Certificate cert
        16: .line 650
            aload 16 /* cert */
            instanceof java.security.cert.X509Certificate
            ifne 19
        17: .line 652
            iconst_1
            istore 15 /* incompatible */
        18: .line 653
            goto 21
        end local 16 // java.security.cert.Certificate cert
        19: .line 649
      StackMap locals:
      StackMap stack:
            iinc 17 1
      StackMap locals:
      StackMap stack:
        20: iload 17
            iload 18
            if_icmplt 15
        21: .line 656
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints 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 15 /* incompatible */
            ifeq 23
        22: .line 657
            goto 80
        23: .line 661
      StackMap locals:
      StackMap stack:
            iconst_m1
            istore 16 /* keyIndex */
        start local 16 // int keyIndex
        24: .line 662
            iconst_0
            istore 17 /* j */
        start local 17 // int j
        25: .line 663
            aload 2 /* keyTypes */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 19
            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.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 19
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.X509KeyManagerImpl$KeyType
            astore 18 /* keyType */
        start local 18 // sun.security.ssl.X509KeyManagerImpl$KeyType keyType
        27: .line 664
            aload 18 /* keyType */
            aload 14 /* chain */
            invokevirtual sun.security.ssl.X509KeyManagerImpl$KeyType.matches:([Ljava/security/cert/Certificate;)Z
            ifeq 30
        28: .line 665
            iload 17 /* j */
            istore 16 /* keyIndex */
        29: .line 666
            goto 32
        30: .line 668
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints 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 17 /* j */ 1
        end local 18 // sun.security.ssl.X509KeyManagerImpl$KeyType keyType
        31: .line 663
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints 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 19
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 26
        32: .line 670
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints 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 16 /* keyIndex */
            iconst_m1
            if_icmpne 38
        33: .line 671
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 80
        34: .line 672
            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 13 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        35: .line 673
            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 672
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        37: .line 675
            goto 80
        38: .line 678
      StackMap locals:
      StackMap stack:
            aload 3 /* issuerSet */
            ifnull 54
        39: .line 679
            iconst_0
            istore 18 /* found */
        start local 18 // boolean found
        40: .line 680
            aload 14 /* chain */
            dup
            astore 22
            arraylength
            istore 21
            iconst_0
            istore 20
            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.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 22
            iload 20
            aaload
            astore 19 /* cert */
        start local 19 // java.security.cert.Certificate cert
        42: .line 681
            aload 19 /* cert */
            checkcast java.security.cert.X509Certificate
            astore 23 /* xcert */
        start local 23 // java.security.cert.X509Certificate xcert
        43: .line 682
            aload 3 /* issuerSet */
            aload 23 /* 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 683
            iconst_1
            istore 18 /* found */
        45: .line 684
            goto 48
        end local 23 // java.security.cert.X509Certificate xcert
        end local 19 // java.security.cert.Certificate cert
        46: .line 680
      StackMap locals:
      StackMap stack:
            iinc 20 1
      StackMap locals:
      StackMap stack:
        47: iload 20
            iload 21
            if_icmplt 41
        48: .line 687
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints 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 18 /* found */
            ifne 54
        49: .line 688
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 80
        50: .line 689
            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 13 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        51: .line 690
            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 689
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        53: .line 692
            goto 80
        end local 18 // boolean found
        54: .line 697
      StackMap locals:
      StackMap stack:
            aload 6 /* constraints */
            ifnull 65
        55: .line 698
            aload 6 /* constraints */
            aload 14 /* chain */
        56: .line 699
            aload 5 /* checkType */
            invokevirtual sun.security.ssl.X509KeyManagerImpl$CheckType.getValidator:()Ljava/lang/String;
        57: .line 698
            invokestatic sun.security.ssl.X509KeyManagerImpl.conformsToAlgorithmConstraints:(Ljava/security/AlgorithmConstraints;[Ljava/security/cert/Certificate;Ljava/lang/String;)Z
        58: .line 699
            ifne 65
        59: .line 701
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 80
        60: .line 702
            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 13 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        61: .line 703
            ldc ": certificate list does not conform to "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        62: .line 704
            ldc "algorithm constraints"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        63: .line 702
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        64: .line 706
            goto 80
        65: .line 709
      StackMap locals:
      StackMap stack:
            aload 10 /* date */
            ifnonnull 67
        66: .line 710
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 10 /* date */
        67: .line 713
      StackMap locals:
      StackMap stack:
            aload 5 /* checkType */
            aload 14 /* chain */
            iconst_0
            aaload
            checkcast java.security.cert.X509Certificate
            aload 10 /* date */
            invokevirtual sun.security.ssl.X509KeyManagerImpl$CheckType.check:(Ljava/security/cert/X509Certificate;Ljava/util/Date;)Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        68: .line 712
            astore 18 /* checkResult */
        start local 18 // sun.security.ssl.X509KeyManagerImpl$CheckResult checkResult
        69: .line 715
            new sun.security.ssl.X509KeyManagerImpl$EntryStatus
            dup
            iload 1 /* builderIndex */
            iload 16 /* keyIndex */
        70: .line 716
            aload 13 /* alias */
            aload 14 /* chain */
            aload 18 /* checkResult */
        71: .line 715
            invokespecial sun.security.ssl.X509KeyManagerImpl$EntryStatus.<init>:(IILjava/lang/String;[Ljava/security/cert/Certificate;Lsun/security/ssl/X509KeyManagerImpl$CheckResult;)V
        72: .line 714
            astore 19 /* status */
        start local 19 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        73: .line 717
            iload 11 /* preferred */
            ifne 75
            aload 18 /* checkResult */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.OK:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
            if_acmpne 75
            iload 16 /* keyIndex */
            ifne 75
        74: .line 718
            iconst_1
            istore 11 /* preferred */
        75: .line 720
      StackMap locals: sun.security.ssl.X509KeyManagerImpl$CheckResult sun.security.ssl.X509KeyManagerImpl$EntryStatus
      StackMap stack:
            iload 11 /* preferred */
            ifeq 77
            iload 4 /* findAll */
            ifne 77
        76: .line 723
            aload 19 /* status */
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
            areturn
        77: .line 725
      StackMap locals:
      StackMap stack:
            aload 9 /* results */
            ifnonnull 79
        78: .line 726
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 9 /* results */
        79: .line 728
      StackMap locals:
      StackMap stack:
            aload 9 /* results */
            aload 19 /* status */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 19 // sun.security.ssl.X509KeyManagerImpl$EntryStatus status
        end local 18 // sun.security.ssl.X509KeyManagerImpl$CheckResult checkResult
        end local 17 // int j
        end local 16 // int keyIndex
        end local 15 // boolean incompatible
        end local 14 // java.security.cert.Certificate[] chain
        end local 13 // java.lang.String alias
        80: .line 635
      StackMap locals: sun.security.ssl.X509KeyManagerImpl int java.util.List java.util.Set int sun.security.ssl.X509KeyManagerImpl$CheckType java.security.AlgorithmConstraints java.security.KeyStore$Builder java.security.KeyStore java.util.List java.util.Date int java.util.Enumeration
      StackMap stack:
            aload 12 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 7
        end local 12 // java.util.Enumeration e
        81: .line 731
            aload 9 /* results */
            areturn
        end local 11 // boolean preferred
        end local 10 // java.util.Date date
        end local 9 // java.util.List results
        end local 8 // java.security.KeyStore ks
        end local 7 // java.security.KeyStore$Builder builder
        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   82     0          this  Lsun/security/ssl/X509KeyManagerImpl;
            0   82     1  builderIndex  I
            0   82     2      keyTypes  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$KeyType;>;
            0   82     3     issuerSet  Ljava/util/Set<Ljava/security/Principal;>;
            0   82     4       findAll  Z
            0   82     5     checkType  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0   82     6   constraints  Ljava/security/AlgorithmConstraints;
            1   82     7       builder  Ljava/security/KeyStore$Builder;
            2   82     8            ks  Ljava/security/KeyStore;
            3   82     9       results  Ljava/util/List<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
            4   82    10          date  Ljava/util/Date;
            5   82    11     preferred  Z
            6   81    12             e  Ljava/util/Enumeration<Ljava/lang/String;>;
            8   80    13         alias  Ljava/lang/String;
           11   80    14         chain  [Ljava/security/cert/Certificate;
           14   80    15  incompatible  Z
           16   19    16          cert  Ljava/security/cert/Certificate;
           24   80    16      keyIndex  I
           25   80    17             j  I
           27   31    18       keyType  Lsun/security/ssl/X509KeyManagerImpl$KeyType;
           40   54    18         found  Z
           42   46    19          cert  Ljava/security/cert/Certificate;
           43   46    23         xcert  Ljava/security/cert/X509Certificate;
           69   80    18   checkResult  Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
           73   80    19        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<Lsun/security/ssl/X509KeyManagerImpl$EntryStatus;>;
    MethodParameters:
              Name  Flags
      builderIndex  
      keyTypes      
      issuerSet     
      findAll       
      checkType     
      constraints   

  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 738
            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 740
            aload 3 /* checker */
            iconst_0
            invokevirtual sun.security.provider.certpath.AlgorithmChecker.init:(Z)V
         2: .line 741
            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 743
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 8
         5: .line 744
            getstatic sun.security.ssl.X509KeyManagerImpl.debug:Lsun/security/ssl/Debug;
         6: .line 745
            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 744
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
         8: .line 748
      StackMap locals: java.security.cert.CertPathValidatorException
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // java.security.cert.CertPathValidatorException cpve
         9: .line 752
      StackMap locals:
      StackMap stack:
            aload 1 /* chain */
            arraylength
            iconst_1
            isub
            istore 4 /* i */
        start local 4 // int i
        10: goto 21
        11: .line 753
      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 756
            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 757
            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 758
            getstatic sun.security.ssl.X509KeyManagerImpl.useDebug:Z
            ifeq 19
        16: .line 759
            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 760
            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 759
            invokevirtual sun.security.ssl.Debug.println:(Ljava/lang/String;)V
        19: .line 763
      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 752
      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 767
            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