abstract class sun.security.mscapi.KeyStore extends java.security.KeyStoreSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: sun.security.mscapi.KeyStore
  super_class: java.security.KeyStoreSpi
{
  private java.security.cert.CertificateFactory certificateFactory;
    descriptor: Ljava/security/cert/CertificateFactory;
    flags: (0x0002) ACC_PRIVATE

  private static final java.lang.String KEYSTORE_COMPATIBILITY_MODE_PROP;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "sun.security.mscapi.keyStoreCompatibilityMode"

  private final boolean keyStoreCompatibilityMode;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private java.util.Map<java.lang.String, sun.security.mscapi.KeyStore$KeyEntry> entries;
    descriptor: Ljava/util/Map;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Map<Ljava/lang/String;Lsun/security/mscapi/KeyStore$KeyEntry;>;

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

  void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String storeName
         0: .line 203
            aload 0 /* this */
            invokespecial java.security.KeyStoreSpi.<init>:()V
         1: .line 178
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.KeyStore.certificateFactory:Ljava/security/cert/CertificateFactory;
         2: .line 195
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
         3: .line 207
            new sun.security.action.GetPropertyAction
            dup
            ldc "sun.security.mscapi.keyStoreCompatibilityMode"
            invokespecial sun.security.action.GetPropertyAction.<init>:(Ljava/lang/String;)V
         4: .line 206
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
         5: .line 205
            astore 2 /* prop */
        start local 2 // java.lang.String prop
         6: .line 209
            ldc "false"
            aload 2 /* prop */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 9
         7: .line 210
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
         8: .line 211
            goto 10
         9: .line 212
      StackMap locals: sun.security.mscapi.KeyStore java.lang.String java.lang.String
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
        10: .line 215
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* storeName */
            putfield sun.security.mscapi.KeyStore.storeName:Ljava/lang/String;
        11: .line 216
            return
        end local 2 // java.lang.String prop
        end local 1 // java.lang.String storeName
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   12     0       this  Lsun/security/mscapi/KeyStore;
            0   12     1  storeName  Ljava/lang/String;
            6   12     2       prop  Ljava/lang/String;
    MethodParameters:
           Name  Flags
      storeName  

  public java.security.Key engineGetKey(java.lang.String, char[]);
    descriptor: (Ljava/lang/String;[C)Ljava/security/Key;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // char[] password
         0: .line 244
            aload 1 /* alias */
            ifnonnull 2
         1: .line 245
            aconst_null
            areturn
         2: .line 248
      StackMap locals:
      StackMap stack:
            aload 2 /* password */
            ifnull 4
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
            ifne 4
         3: .line 249
            new java.security.UnrecoverableKeyException
            dup
            ldc "Password must be null"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 252
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.mscapi.KeyStore.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifne 6
         5: .line 253
            aconst_null
            areturn
         6: .line 255
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 3 /* entry */
        start local 3 // sun.security.mscapi.KeyStore$KeyEntry entry
         7: .line 256
            aload 3 /* entry */
            ifnonnull 9
         8: .line 257
            aconst_null
            goto 10
         9: .line 258
      StackMap locals: sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
            aload 3 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getPrivateKey:()Lsun/security/mscapi/Key;
        10: .line 256
      StackMap locals:
      StackMap stack: sun.security.mscapi.Key
            areturn
        end local 3 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 2 // char[] password
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lsun/security/mscapi/KeyStore;
            0   11     1     alias  Ljava/lang/String;
            0   11     2  password  [C
            7   11     3     entry  Lsun/security/mscapi/KeyStore$KeyEntry;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
          Name  Flags
      alias     
      password  

  public java.security.cert.Certificate[] engineGetCertificateChain(java.lang.String);
    descriptor: (Ljava/lang/String;)[Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
         0: .line 274
            aload 1 /* alias */
            ifnonnull 2
         1: .line 275
            aconst_null
            areturn
         2: .line 278
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 2 /* entry */
        start local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
         3: .line 279
            aload 2 /* entry */
            ifnonnull 5
         4: .line 280
            aconst_null
            goto 6
         5: .line 281
      StackMap locals: sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
            aload 2 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getCertificateChain:()[Ljava/security/cert/X509Certificate;
         6: .line 279
      StackMap locals:
      StackMap stack: java.security.cert.X509Certificate[]
            astore 3 /* certChain */
        start local 3 // java.security.cert.X509Certificate[] certChain
         7: .line 282
            aload 3 /* certChain */
            ifnonnull 9
         8: .line 283
            aconst_null
            goto 10
         9: .line 284
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            aload 3 /* certChain */
            invokevirtual java.security.cert.X509Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
        10: .line 282
      StackMap locals:
      StackMap stack: java.security.cert.Certificate[]
            areturn
        end local 3 // java.security.cert.X509Certificate[] certChain
        end local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lsun/security/mscapi/KeyStore;
            0   11     1      alias  Ljava/lang/String;
            3   11     2      entry  Lsun/security/mscapi/KeyStore$KeyEntry;
            7   11     3  certChain  [Ljava/security/cert/X509Certificate;
    MethodParameters:
       Name  Flags
      alias  

  public java.security.cert.Certificate engineGetCertificate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
         0: .line 304
            aload 1 /* alias */
            ifnonnull 2
         1: .line 305
            aconst_null
            areturn
         2: .line 308
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 2 /* entry */
        start local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
         3: .line 309
            aload 2 /* entry */
            ifnonnull 5
         4: .line 310
            aconst_null
            goto 6
         5: .line 311
      StackMap locals: sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
            aload 2 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getCertificateChain:()[Ljava/security/cert/X509Certificate;
         6: .line 309
      StackMap locals:
      StackMap stack: java.security.cert.X509Certificate[]
            astore 3 /* certChain */
        start local 3 // java.security.cert.X509Certificate[] certChain
         7: .line 312
            aload 3 /* certChain */
            ifnull 8
            aload 3 /* certChain */
            arraylength
            ifne 9
         8: .line 313
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            aconst_null
            goto 10
         9: .line 314
      StackMap locals:
      StackMap stack:
            aload 3 /* certChain */
            iconst_0
            aaload
        10: .line 312
      StackMap locals:
      StackMap stack: java.security.cert.X509Certificate
            areturn
        end local 3 // java.security.cert.X509Certificate[] certChain
        end local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lsun/security/mscapi/KeyStore;
            0   11     1      alias  Ljava/lang/String;
            3   11     2      entry  Lsun/security/mscapi/KeyStore$KeyEntry;
            7   11     3  certChain  [Ljava/security/cert/X509Certificate;
    MethodParameters:
       Name  Flags
      alias  

  public java.util.Date engineGetCreationDate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/Date;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
         0: .line 326
            aload 1 /* alias */
            ifnonnull 2
         1: .line 327
            aconst_null
            areturn
         2: .line 329
      StackMap locals:
      StackMap stack:
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            areturn
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lsun/security/mscapi/KeyStore;
            0    3     1  alias  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      alias  

  public void engineSetKeyEntry(java.lang.String, java.security.Key, char[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=8, args_size=5
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.Key key
        start local 3 // char[] password
        start local 4 // java.security.cert.Certificate[] chain
         0: .line 368
            aload 1 /* alias */
            ifnonnull 2
         1: .line 369
            new java.security.KeyStoreException
            dup
            ldc "alias must not be null"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 372
      StackMap locals:
      StackMap stack:
            aload 3 /* password */
            ifnull 4
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
            ifne 4
         3: .line 373
            new java.security.KeyStoreException
            dup
            ldc "Password must be null"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 376
      StackMap locals:
      StackMap stack:
            aload 2 /* key */
            instanceof java.security.interfaces.RSAPrivateCrtKey
            ifeq 26
         5: .line 378
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 5 /* entry */
        start local 5 // sun.security.mscapi.KeyStore$KeyEntry entry
         6: .line 381
            aload 4 /* chain */
            ifnull 13
         7: .line 382
            aload 4 /* chain */
            instanceof java.security.cert.X509Certificate[]
            ifeq 10
         8: .line 383
            aload 4 /* chain */
            checkcast java.security.cert.X509Certificate[]
            astore 6 /* xchain */
        start local 6 // java.security.cert.X509Certificate[] xchain
         9: .line 384
            goto 14
        end local 6 // java.security.cert.X509Certificate[] xchain
        10: .line 385
      StackMap locals: sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
            aload 4 /* chain */
            arraylength
            anewarray java.security.cert.X509Certificate
            astore 6 /* xchain */
        start local 6 // java.security.cert.X509Certificate[] xchain
        11: .line 386
            aload 4 /* chain */
            iconst_0
            aload 6 /* xchain */
            iconst_0
            aload 4 /* chain */
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        12: .line 388
            goto 14
        end local 6 // java.security.cert.X509Certificate[] xchain
        13: .line 389
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 6 /* xchain */
        start local 6 // java.security.cert.X509Certificate[] xchain
        14: .line 392
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            aload 5 /* entry */
            ifnonnull 18
        15: .line 395
            new sun.security.mscapi.KeyStore$KeyEntry
            dup
            aload 0 /* this */
            aload 1 /* alias */
            aconst_null
            aload 6 /* xchain */
            invokespecial sun.security.mscapi.KeyStore$KeyEntry.<init>:(Lsun/security/mscapi/KeyStore;Ljava/lang/String;Lsun/security/mscapi/Key;[Ljava/security/cert/X509Certificate;)V
        16: .line 393
            astore 5 /* entry */
        17: .line 396
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* entry */
            invokevirtual sun.security.mscapi.KeyStore.storeWithUniqueAlias:(Ljava/lang/String;Lsun/security/mscapi/KeyStore$KeyEntry;)V
        18: .line 399
      StackMap locals:
      StackMap stack:
            aload 5 /* entry */
            aload 1 /* alias */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.setAlias:(Ljava/lang/String;)V
        19: .line 402
            aload 5 /* entry */
            aload 2 /* key */
            checkcast java.security.interfaces.RSAPrivateCrtKey
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.setPrivateKey:(Ljava/security/interfaces/RSAPrivateCrtKey;)V
        20: .line 403
            aload 5 /* entry */
            aload 6 /* xchain */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.setCertificateChain:([Ljava/security/cert/X509Certificate;)V
        21: .line 405
            goto 29
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
        22: astore 7 /* ce */
        start local 7 // java.security.cert.CertificateException ce
        23: .line 406
            new java.security.KeyStoreException
            dup
            aload 7 /* ce */
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 7 // java.security.cert.CertificateException ce
        24: .line 408
      StackMap locals:
      StackMap stack: java.security.InvalidKeyException
            astore 7 /* ike */
        start local 7 // java.security.InvalidKeyException ike
        25: .line 409
            new java.security.KeyStoreException
            dup
            aload 7 /* ike */
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 7 // java.security.InvalidKeyException ike
        end local 6 // java.security.cert.X509Certificate[] xchain
        end local 5 // sun.security.mscapi.KeyStore$KeyEntry entry
        26: .line 413
      StackMap locals:
      StackMap stack:
            new java.lang.UnsupportedOperationException
            dup
        27: .line 414
            ldc "Cannot assign the key to the given alias."
        28: .line 413
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        29: .line 416
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.security.cert.Certificate[] chain
        end local 3 // char[] password
        end local 2 // java.security.Key key
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   30     0      this  Lsun/security/mscapi/KeyStore;
            0   30     1     alias  Ljava/lang/String;
            0   30     2       key  Ljava/security/Key;
            0   30     3  password  [C
            0   30     4     chain  [Ljava/security/cert/Certificate;
            6   26     5     entry  Lsun/security/mscapi/KeyStore$KeyEntry;
            9   10     6    xchain  [Ljava/security/cert/X509Certificate;
           11   13     6    xchain  [Ljava/security/cert/X509Certificate;
           14   26     6    xchain  [Ljava/security/cert/X509Certificate;
           23   24     7        ce  Ljava/security/cert/CertificateException;
           25   26     7       ike  Ljava/security/InvalidKeyException;
      Exception table:
        from    to  target  type
          19    21      22  Class java.security.cert.CertificateException
          19    21      24  Class java.security.InvalidKeyException
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
          Name  Flags
      alias     
      key       
      password  
      chain     

  public void engineSetKeyEntry(java.lang.String, byte[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;[B[Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // byte[] key
        start local 3 // java.security.cert.Certificate[] chain
         0: .line 445
            new java.lang.UnsupportedOperationException
            dup
         1: .line 446
            ldc "Cannot assign the encoded key to the given alias."
         2: .line 445
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // java.security.cert.Certificate[] chain
        end local 2 // byte[] key
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lsun/security/mscapi/KeyStore;
            0    3     1  alias  Ljava/lang/String;
            0    3     2    key  [B
            0    3     3  chain  [Ljava/security/cert/Certificate;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      key    
      chain  

  public void engineSetCertificateEntry(java.lang.String, java.security.cert.Certificate);
    descriptor: (Ljava/lang/String;Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=3
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.cert.Certificate cert
         0: .line 466
            aload 1 /* alias */
            ifnonnull 2
         1: .line 467
            new java.security.KeyStoreException
            dup
            ldc "alias must not be null"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 470
      StackMap locals:
      StackMap stack:
            aload 2 /* cert */
            instanceof java.security.cert.X509Certificate
            ifeq 16
         3: .line 474
            iconst_1
            anewarray java.security.cert.X509Certificate
            dup
            iconst_0
            aload 2 /* cert */
            checkcast java.security.cert.X509Certificate
            aastore
         4: .line 473
            astore 3 /* chain */
        start local 3 // java.security.cert.X509Certificate[] chain
         5: .line 475
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 4 /* entry */
        start local 4 // sun.security.mscapi.KeyStore$KeyEntry entry
         6: .line 477
            aload 4 /* entry */
            ifnonnull 10
         7: .line 479
            new sun.security.mscapi.KeyStore$KeyEntry
            dup
            aload 0 /* this */
            aload 1 /* alias */
            aconst_null
            aload 3 /* chain */
            invokespecial sun.security.mscapi.KeyStore$KeyEntry.<init>:(Lsun/security/mscapi/KeyStore;Ljava/lang/String;Lsun/security/mscapi/Key;[Ljava/security/cert/X509Certificate;)V
         8: .line 478
            astore 4 /* entry */
         9: .line 480
            aload 0 /* this */
            aload 1 /* alias */
            aload 4 /* entry */
            invokevirtual sun.security.mscapi.KeyStore.storeWithUniqueAlias:(Ljava/lang/String;Lsun/security/mscapi/KeyStore$KeyEntry;)V
        10: .line 483
      StackMap locals: java.security.cert.X509Certificate[] sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
            aload 4 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getPrivateKey:()Lsun/security/mscapi/Key;
            ifnonnull 19
        11: .line 484
            aload 4 /* entry */
            aload 1 /* alias */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.setAlias:(Ljava/lang/String;)V
        12: .line 487
            aload 4 /* entry */
            aload 3 /* chain */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.setCertificateChain:([Ljava/security/cert/X509Certificate;)V
        13: .line 489
            goto 19
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
        14: astore 5 /* ce */
        start local 5 // java.security.cert.CertificateException ce
        15: .line 490
            new java.security.KeyStoreException
            dup
            aload 5 /* ce */
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.security.cert.CertificateException ce
        end local 4 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 3 // java.security.cert.X509Certificate[] chain
        16: .line 495
      StackMap locals:
      StackMap stack:
            new java.lang.UnsupportedOperationException
            dup
        17: .line 496
            ldc "Cannot assign the certificate to the given alias."
        18: .line 495
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 498
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.security.cert.Certificate cert
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   20     0   this  Lsun/security/mscapi/KeyStore;
            0   20     1  alias  Ljava/lang/String;
            0   20     2   cert  Ljava/security/cert/Certificate;
            5   16     3  chain  [Ljava/security/cert/X509Certificate;
            6   16     4  entry  Lsun/security/mscapi/KeyStore$KeyEntry;
           15   16     5     ce  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
          12    13      14  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      cert   

  public void engineDeleteEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
         0: .line 510
            aload 1 /* alias */
            ifnonnull 2
         1: .line 511
            new java.security.KeyStoreException
            dup
            ldc "alias must not be null"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 514
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 2 /* entry */
        start local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
         3: .line 515
            aload 2 /* entry */
            ifnull 18
         4: .line 517
            aload 2 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getCertificateChain:()[Ljava/security/cert/X509Certificate;
            astore 3 /* certChain */
        start local 3 // java.security.cert.X509Certificate[] certChain
         5: .line 518
            aload 3 /* certChain */
            ifnull 13
         6: .line 522
            aload 3 /* certChain */
            iconst_0
            aaload
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            astore 4 /* encoding */
        start local 4 // byte[] encoding
         7: .line 523
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.mscapi.KeyStore.getName:()Ljava/lang/String;
            aload 2 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getAlias:()Ljava/lang/String;
            aload 4 /* encoding */
         8: .line 524
            aload 4 /* encoding */
            arraylength
         9: .line 523
            invokevirtual sun.security.mscapi.KeyStore.removeCertificate:(Ljava/lang/String;Ljava/lang/String;[BI)V
        end local 4 // byte[] encoding
        10: .line 526
            goto 13
      StackMap locals: sun.security.mscapi.KeyStore java.lang.String sun.security.mscapi.KeyStore$KeyEntry java.security.cert.X509Certificate[]
      StackMap stack: java.security.cert.CertificateException
        11: astore 4 /* e */
        start local 4 // java.security.cert.CertificateException e
        12: .line 527
            new java.security.KeyStoreException
            dup
            ldc "Cannot remove entry: "
            aload 4 /* e */
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.security.cert.CertificateException e
        13: .line 530
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getPrivateKey:()Lsun/security/mscapi/Key;
            astore 4 /* privateKey */
        start local 4 // sun.security.mscapi.Key privateKey
        14: .line 531
            aload 4 /* privateKey */
            ifnull 18
        15: .line 532
            aload 0 /* this */
        16: .line 533
            aload 4 /* privateKey */
            invokevirtual sun.security.mscapi.Key.getHCryptProvider:()J
            invokestatic sun.security.mscapi.Key.getContainerName:(J)Ljava/lang/String;
        17: .line 532
            invokevirtual sun.security.mscapi.KeyStore.destroyKeyContainer:(Ljava/lang/String;)V
        end local 4 // sun.security.mscapi.Key privateKey
        end local 3 // java.security.cert.X509Certificate[] certChain
        18: .line 536
      StackMap locals:
      StackMap stack:
            return
        end local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   19     0        this  Lsun/security/mscapi/KeyStore;
            0   19     1       alias  Ljava/lang/String;
            3   19     2       entry  Lsun/security/mscapi/KeyStore$KeyEntry;
            5   18     3   certChain  [Ljava/security/cert/X509Certificate;
            7   10     4    encoding  [B
           12   13     4           e  Ljava/security/cert/CertificateException;
           14   18     4  privateKey  Lsun/security/mscapi/Key;
      Exception table:
        from    to  target  type
           6    10      11  Class java.security.cert.CertificateException
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  

  public java.util.Enumeration<java.lang.String> engineAliases();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // sun.security.mscapi.KeyStore this
         0: .line 544
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 1 /* iter */
        start local 1 // java.util.Iterator iter
         1: .line 546
            new sun.security.mscapi.KeyStore$1
            dup
            aload 0 /* this */
            aload 1 /* iter */
            invokespecial sun.security.mscapi.KeyStore$1.<init>:(Lsun/security/mscapi/KeyStore;Ljava/util/Iterator;)V
            areturn
        end local 1 // java.util.Iterator iter
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/mscapi/KeyStore;
            1    2     1  iter  Ljava/util/Iterator<Ljava/lang/String;>;
    Signature: ()Ljava/util/Enumeration<Ljava/lang/String;>;

  public boolean engineContainsAlias(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
         0: .line 568
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lsun/security/mscapi/KeyStore;
            0    1     1  alias  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      alias  

  public int engineSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.mscapi.KeyStore this
         0: .line 577
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            invokeinterface java.util.Map.size:()I
            ireturn
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/mscapi/KeyStore;

  public boolean engineIsKeyEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
         0: .line 589
            aload 1 /* alias */
            ifnonnull 2
         1: .line 590
            iconst_0
            ireturn
         2: .line 593
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 2 /* entry */
        start local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
         3: .line 594
            aload 2 /* entry */
            ifnull 4
            aload 2 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getPrivateKey:()Lsun/security/mscapi/Key;
            ifnull 4
            iconst_1
            ireturn
      StackMap locals: sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
         4: iconst_0
            ireturn
        end local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lsun/security/mscapi/KeyStore;
            0    5     1  alias  Ljava/lang/String;
            3    5     2  entry  Lsun/security/mscapi/KeyStore$KeyEntry;
    MethodParameters:
       Name  Flags
      alias  

  public boolean engineIsCertificateEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
         0: .line 606
            aload 1 /* alias */
            ifnonnull 2
         1: .line 607
            iconst_0
            ireturn
         2: .line 610
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 2 /* entry */
        start local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
         3: .line 611
            aload 2 /* entry */
            ifnull 4
            aload 2 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getPrivateKey:()Lsun/security/mscapi/Key;
            ifnonnull 4
            iconst_1
            ireturn
      StackMap locals: sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
         4: iconst_0
            ireturn
        end local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lsun/security/mscapi/KeyStore;
            0    5     1  alias  Ljava/lang/String;
            3    5     2  entry  Lsun/security/mscapi/KeyStore$KeyEntry;
    MethodParameters:
       Name  Flags
      alias  

  public java.lang.String engineGetCertificateAlias(java.security.cert.Certificate);
    descriptor: (Ljava/security/cert/Certificate;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.security.cert.Certificate cert
         0: .line 632
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 5
      StackMap locals: sun.security.mscapi.KeyStore java.security.cert.Certificate top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* mapEntry */
        start local 2 // java.util.Map$Entry mapEntry
         2: .line 633
            aload 2 /* mapEntry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 4 /* entry */
        start local 4 // sun.security.mscapi.KeyStore$KeyEntry entry
         3: .line 634
            aload 4 /* entry */
            getfield sun.security.mscapi.KeyStore$KeyEntry.certChain:[Ljava/security/cert/X509Certificate;
            ifnull 5
            aload 4 /* entry */
            getfield sun.security.mscapi.KeyStore$KeyEntry.certChain:[Ljava/security/cert/X509Certificate;
            iconst_0
            aaload
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 635
            aload 4 /* entry */
            invokevirtual sun.security.mscapi.KeyStore$KeyEntry.getAlias:()Ljava/lang/String;
            areturn
        end local 4 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 2 // java.util.Map$Entry mapEntry
         5: .line 632
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         6: .line 639
            aconst_null
            areturn
        end local 1 // java.security.cert.Certificate cert
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lsun/security/mscapi/KeyStore;
            0    7     1      cert  Ljava/security/cert/Certificate;
            2    5     2  mapEntry  Ljava/util/Map$Entry<Ljava/lang/String;Lsun/security/mscapi/KeyStore$KeyEntry;>;
            3    5     4     entry  Lsun/security/mscapi/KeyStore$KeyEntry;
    MethodParameters:
      Name  Flags
      cert  

  public void engineStore(java.io.OutputStream, char[]);
    descriptor: (Ljava/io/OutputStream;[C)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.io.OutputStream stream
        start local 2 // char[] password
         0: .line 664
            aload 1 /* stream */
            ifnull 2
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
            ifne 2
         1: .line 665
            new java.io.IOException
            dup
            ldc "Keystore output stream must be null"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 668
      StackMap locals:
      StackMap stack:
            aload 2 /* password */
            ifnull 4
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
            ifne 4
         3: .line 669
            new java.io.IOException
            dup
            ldc "Keystore password must be null"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 671
      StackMap locals:
      StackMap stack:
            return
        end local 2 // char[] password
        end local 1 // java.io.OutputStream stream
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lsun/security/mscapi/KeyStore;
            0    5     1    stream  Ljava/io/OutputStream;
            0    5     2  password  [C
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  public void engineLoad(java.io.InputStream, char[]);
    descriptor: (Ljava/io/InputStream;[C)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=3
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.io.InputStream stream
        start local 2 // char[] password
         0: .line 703
            aload 1 /* stream */
            ifnull 2
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
            ifne 2
         1: .line 704
            new java.io.IOException
            dup
            ldc "Keystore input stream must be null"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 707
      StackMap locals:
      StackMap stack:
            aload 2 /* password */
            ifnull 4
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.keyStoreCompatibilityMode:Z
            ifne 4
         3: .line 708
            new java.io.IOException
            dup
            ldc "Keystore password must be null"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 714
      StackMap locals:
      StackMap stack:
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 3 /* sm */
        start local 3 // java.lang.SecurityManager sm
         5: .line 715
            aload 3 /* sm */
            ifnull 9
         6: .line 716
            aload 3 /* sm */
            new java.security.SecurityPermission
            dup
         7: .line 717
            ldc "authProvider.SunMSCAPI"
            invokespecial java.security.SecurityPermission.<init>:(Ljava/lang/String;)V
         8: .line 716
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         9: .line 721
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        10: .line 726
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.mscapi.KeyStore.getName:()Ljava/lang/String;
            invokevirtual sun.security.mscapi.KeyStore.loadKeysOrCertificateChains:(Ljava/lang/String;)V
        11: .line 728
            goto 14
      StackMap locals:
      StackMap stack: java.security.KeyStoreException
        12: astore 4 /* e */
        start local 4 // java.security.KeyStoreException e
        13: .line 729
            new java.io.IOException
            dup
            aload 4 /* e */
            invokespecial java.io.IOException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.security.KeyStoreException e
        14: .line 731
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.SecurityManager sm
        end local 2 // char[] password
        end local 1 // java.io.InputStream stream
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   15     0      this  Lsun/security/mscapi/KeyStore;
            0   15     1    stream  Ljava/io/InputStream;
            0   15     2  password  [C
            5   15     3        sm  Ljava/lang/SecurityManager;
           13   14     4         e  Ljava/security/KeyStoreException;
      Exception table:
        from    to  target  type
          10    11      12  Class java.security.KeyStoreException
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  private void storeWithUniqueAlias(java.lang.String, sun.security.mscapi.KeyStore$KeyEntry);
    descriptor: (Ljava/lang/String;Lsun/security/mscapi/KeyStore$KeyEntry;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
         0: .line 741
            aload 1 /* alias */
            astore 3 /* uniqAlias */
        start local 3 // java.lang.String uniqAlias
         1: .line 742
            iconst_1
            istore 4 /* uniqNum */
        start local 4 // int uniqNum
         2: .line 745
      StackMap locals: java.lang.String int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 3 /* uniqAlias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 5 /* val */
        start local 5 // sun.security.mscapi.KeyStore$KeyEntry val
         3: .line 746
            aload 5 /* val */
            ifnonnull 5
         4: .line 747
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.entries:Ljava/util/Map;
            aload 3 /* uniqAlias */
            aload 2 /* entry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.mscapi.KeyStore$KeyEntry
            astore 5 /* val */
         5: .line 749
      StackMap locals: sun.security.mscapi.KeyStore$KeyEntry
      StackMap stack:
            aload 5 /* val */
            ifnonnull 7
         6: .line 750
            goto 9
         7: .line 752
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 1 /* alias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " ("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 4 /* uniqNum */
            iinc 4 /* uniqNum */ 1
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* uniqAlias */
        end local 5 // sun.security.mscapi.KeyStore$KeyEntry val
         8: .line 744
            goto 2
         9: .line 754
      StackMap locals:
      StackMap stack:
            return
        end local 4 // int uniqNum
        end local 3 // java.lang.String uniqAlias
        end local 2 // sun.security.mscapi.KeyStore$KeyEntry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   10     0       this  Lsun/security/mscapi/KeyStore;
            0   10     1      alias  Ljava/lang/String;
            0   10     2      entry  Lsun/security/mscapi/KeyStore$KeyEntry;
            1   10     3  uniqAlias  Ljava/lang/String;
            2   10     4    uniqNum  I
            3    8     5        val  Lsun/security/mscapi/KeyStore$KeyEntry;
    MethodParameters:
       Name  Flags
      alias  
      entry  

  private void generateCertificateChain(java.lang.String, java.util.Collection<? extends java.security.cert.Certificate>);
    descriptor: (Ljava/lang/String;Ljava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=6, args_size=3
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.util.Collection certCollection
         0: .line 768
            aload 2 /* certCollection */
            invokeinterface java.util.Collection.size:()I
            anewarray java.security.cert.X509Certificate
         1: .line 767
            astore 3 /* certChain */
        start local 3 // java.security.cert.X509Certificate[] certChain
         2: .line 770
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         3: .line 772
            aload 2 /* certCollection */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
         4: .line 771
            astore 5 /* iter */
        start local 5 // java.util.Iterator iter
         5: .line 772
            goto 8
         6: .line 774
      StackMap locals: java.security.cert.X509Certificate[] int java.util.Iterator
      StackMap stack:
            aload 3 /* certChain */
            iload 4 /* i */
            aload 5 /* iter */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            aastore
         7: .line 772
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: aload 5 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        end local 5 // java.util.Iterator iter
         9: .line 777
            aload 0 /* this */
            aload 1 /* alias */
        10: .line 778
            new sun.security.mscapi.KeyStore$KeyEntry
            dup
            aload 0 /* this */
            aload 1 /* alias */
            aconst_null
            aload 3 /* certChain */
            invokespecial sun.security.mscapi.KeyStore$KeyEntry.<init>:(Lsun/security/mscapi/KeyStore;Ljava/lang/String;Lsun/security/mscapi/Key;[Ljava/security/cert/X509Certificate;)V
        11: .line 777
            invokevirtual sun.security.mscapi.KeyStore.storeWithUniqueAlias:(Ljava/lang/String;Lsun/security/mscapi/KeyStore$KeyEntry;)V
        end local 4 // int i
        end local 3 // java.security.cert.X509Certificate[] certChain
        12: .line 779
            goto 14
        13: .line 780
      StackMap locals: sun.security.mscapi.KeyStore java.lang.String java.util.Collection
      StackMap stack: java.lang.Throwable
            pop
        14: .line 786
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.Collection certCollection
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   15     0            this  Lsun/security/mscapi/KeyStore;
            0   15     1           alias  Ljava/lang/String;
            0   15     2  certCollection  Ljava/util/Collection<+Ljava/security/cert/Certificate;>;
            2   12     3       certChain  [Ljava/security/cert/X509Certificate;
            3   12     4               i  I
            5    9     5            iter  Ljava/util/Iterator<+Ljava/security/cert/Certificate;>;
      Exception table:
        from    to  target  type
           0    12      13  Class java.lang.Throwable
    Signature: (Ljava/lang/String;Ljava/util/Collection<+Ljava/security/cert/Certificate;>;)V
    MethodParameters:
                Name  Flags
      alias           
      certCollection  

  private void generateRSAKeyAndCertificateChain(java.lang.String, long, long, int, java.util.Collection<? extends java.security.cert.Certificate>);
    descriptor: (Ljava/lang/String;JJILjava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=13, locals=11, args_size=6
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // long hCryptProv
        start local 4 // long hCryptKey
        start local 6 // int keyLength
        start local 7 // java.util.Collection certCollection
         0: .line 800
            aload 7 /* certCollection */
            invokeinterface java.util.Collection.size:()I
            anewarray java.security.cert.X509Certificate
         1: .line 799
            astore 8 /* certChain */
        start local 8 // java.security.cert.X509Certificate[] certChain
         2: .line 802
            iconst_0
            istore 9 /* i */
        start local 9 // int i
         3: .line 804
            aload 7 /* certCollection */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
         4: .line 803
            astore 10 /* iter */
        start local 10 // java.util.Iterator iter
         5: .line 804
            goto 8
         6: .line 806
      StackMap locals: java.security.cert.X509Certificate[] int java.util.Iterator
      StackMap stack:
            aload 8 /* certChain */
            iload 9 /* i */
            aload 10 /* iter */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            aastore
         7: .line 804
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: aload 10 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        end local 10 // java.util.Iterator iter
         9: .line 809
            aload 0 /* this */
            aload 1 /* alias */
            new sun.security.mscapi.KeyStore$KeyEntry
            dup
            aload 0 /* this */
            aload 1 /* alias */
        10: .line 810
            new sun.security.mscapi.RSAPrivateKey
            dup
            lload 2 /* hCryptProv */
            lload 4 /* hCryptKey */
            iload 6 /* keyLength */
            invokespecial sun.security.mscapi.RSAPrivateKey.<init>:(JJI)V
        11: .line 811
            aload 8 /* certChain */
            invokespecial sun.security.mscapi.KeyStore$KeyEntry.<init>:(Lsun/security/mscapi/KeyStore;Ljava/lang/String;Lsun/security/mscapi/Key;[Ljava/security/cert/X509Certificate;)V
        12: .line 809
            invokevirtual sun.security.mscapi.KeyStore.storeWithUniqueAlias:(Ljava/lang/String;Lsun/security/mscapi/KeyStore$KeyEntry;)V
        end local 9 // int i
        end local 8 // java.security.cert.X509Certificate[] certChain
        13: .line 812
            goto 15
        14: .line 813
      StackMap locals: sun.security.mscapi.KeyStore java.lang.String long long int java.util.Collection
      StackMap stack: java.lang.Throwable
            pop
        15: .line 819
      StackMap locals:
      StackMap stack:
            return
        end local 7 // java.util.Collection certCollection
        end local 6 // int keyLength
        end local 4 // long hCryptKey
        end local 2 // long hCryptProv
        end local 1 // java.lang.String alias
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   16     0            this  Lsun/security/mscapi/KeyStore;
            0   16     1           alias  Ljava/lang/String;
            0   16     2      hCryptProv  J
            0   16     4       hCryptKey  J
            0   16     6       keyLength  I
            0   16     7  certCollection  Ljava/util/Collection<+Ljava/security/cert/Certificate;>;
            2   13     8       certChain  [Ljava/security/cert/X509Certificate;
            3   13     9               i  I
            5    9    10            iter  Ljava/util/Iterator<+Ljava/security/cert/Certificate;>;
      Exception table:
        from    to  target  type
           0    13      14  Class java.lang.Throwable
    Signature: (Ljava/lang/String;JJILjava/util/Collection<+Ljava/security/cert/Certificate;>;)V
    MethodParameters:
                Name  Flags
      alias           
      hCryptProv      
      hCryptKey       
      keyLength       
      certCollection  

  private void generateCertificate(byte[], java.util.Collection<java.security.cert.Certificate>);
    descriptor: ([BLjava/util/Collection;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // sun.security.mscapi.KeyStore this
        start local 1 // byte[] data
        start local 2 // java.util.Collection certCollection
         0: .line 832
            new java.io.ByteArrayInputStream
            dup
            aload 1 /* data */
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 3 /* bis */
        start local 3 // java.io.ByteArrayInputStream bis
         1: .line 835
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.certificateFactory:Ljava/security/cert/CertificateFactory;
            ifnonnull 3
         2: .line 836
            aload 0 /* this */
            ldc "X.509"
            ldc "SUN"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            putfield sun.security.mscapi.KeyStore.certificateFactory:Ljava/security/cert/CertificateFactory;
         3: .line 841
      StackMap locals: java.io.ByteArrayInputStream
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.certificateFactory:Ljava/security/cert/CertificateFactory;
            aload 3 /* bis */
            invokevirtual java.security.cert.CertificateFactory.generateCertificates:(Ljava/io/InputStream;)Ljava/util/Collection;
         4: .line 840
            astore 4 /* c */
        start local 4 // java.util.Collection c
         5: .line 842
            aload 2 /* certCollection */
            aload 4 /* c */
            invokeinterface java.util.Collection.addAll:(Ljava/util/Collection;)Z
            pop
        end local 4 // java.util.Collection c
        end local 3 // java.io.ByteArrayInputStream bis
         6: .line 843
            goto 9
         7: .line 844
      StackMap locals: sun.security.mscapi.KeyStore byte[] java.util.Collection
      StackMap stack: java.security.cert.CertificateException
            pop
            goto 9
         8: .line 850
      StackMap locals:
      StackMap stack: java.lang.Throwable
            pop
         9: .line 856
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.Collection certCollection
        end local 1 // byte[] data
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   10     0            this  Lsun/security/mscapi/KeyStore;
            0   10     1            data  [B
            0   10     2  certCollection  Ljava/util/Collection<Ljava/security/cert/Certificate;>;
            1    6     3             bis  Ljava/io/ByteArrayInputStream;
            5    6     4               c  Ljava/util/Collection<+Ljava/security/cert/Certificate;>;
      Exception table:
        from    to  target  type
           0     6       7  Class java.security.cert.CertificateException
           0     6       8  Class java.lang.Throwable
    Signature: ([BLjava/util/Collection<Ljava/security/cert/Certificate;>;)V
    MethodParameters:
                Name  Flags
      data            
      certCollection  

  private java.lang.String getName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.mscapi.KeyStore this
         0: .line 863
            aload 0 /* this */
            getfield sun.security.mscapi.KeyStore.storeName:Ljava/lang/String;
            areturn
        end local 0 // sun.security.mscapi.KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/mscapi/KeyStore;

  private native void loadKeysOrCertificateChains(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
      Name  Flags
      name  

  private native void storeCertificate(java.lang.String, java.lang.String, byte[], int, long, long);
    descriptor: (Ljava/lang/String;Ljava/lang/String;[BIJJ)V
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.cert.CertificateException, java.security.KeyStoreException
    MethodParameters:
                Name  Flags
      name            
      alias           
      encoding        
      encodingLength  
      hCryptProvider  
      hCryptKey       

  private native void removeCertificate(java.lang.String, java.lang.String, byte[], int);
    descriptor: (Ljava/lang/String;Ljava/lang/String;[BI)V
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.cert.CertificateException, java.security.KeyStoreException
    MethodParameters:
                Name  Flags
      name            
      alias           
      encoding        
      encodingLength  

  private native void destroyKeyContainer(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
                  Name  Flags
      keyContainerName  

  private native byte[] generatePrivateKeyBlob(int, byte[], byte[], byte[], byte[], byte[], byte[], byte[], byte[]);
    descriptor: (I[B[B[B[B[B[B[B[B)[B
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
                 Name  Flags
      keyBitLength     
      modulus          
      publicExponent   
      privateExponent  
      primeP           
      primeQ           
      exponentP        
      exponentQ        
      crtCoefficient   

  private native sun.security.mscapi.RSAPrivateKey storePrivateKey(byte[], java.lang.String, int);
    descriptor: ([BLjava/lang/String;I)Lsun/security/mscapi/RSAPrivateKey;
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
                  Name  Flags
      keyBlob           
      keyContainerName  
      keySize           
}
SourceFile: "KeyStore.java"
NestMembers:
  sun.security.mscapi.KeyStore$1  sun.security.mscapi.KeyStore$KeyEntry  sun.security.mscapi.KeyStore$MY  sun.security.mscapi.KeyStore$ROOT
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map
  sun.security.mscapi.KeyStore$1
  KeyEntry = sun.security.mscapi.KeyStore$KeyEntry of sun.security.mscapi.KeyStore
  public final MY = sun.security.mscapi.KeyStore$MY of sun.security.mscapi.KeyStore
  public final ROOT = sun.security.mscapi.KeyStore$ROOT of sun.security.mscapi.KeyStore