abstract class sun.security.provider.JavaKeyStore extends java.security.KeyStoreSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: sun.security.provider.JavaKeyStore
  super_class: java.security.KeyStoreSpi
{
  private static final sun.security.util.Debug debug;
    descriptor: Lsun/security/util/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int MAGIC;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -17957139

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

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

  private final java.util.Hashtable<java.lang.String, java.lang.Object> entries;
    descriptor: Ljava/util/Hashtable;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 77
            ldc "keystore"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.provider.JavaKeyStore.debug:Lsun/security/util/Debug;
         1: .line 80
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.provider.JavaKeyStore this
         0: .line 101
            aload 0 /* this */
            invokespecial java.security.KeyStoreSpi.<init>:()V
         1: .line 102
            aload 0 /* this */
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            putfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
         2: .line 103
            return
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/provider/JavaKeyStore;

  abstract java.lang.String convertAlias(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0400) ACC_ABSTRACT
    MethodParameters:
       Name  Flags
      alias  

  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=10, args_size=3
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
        start local 2 // char[] password
         0: .line 128
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* entry */
        start local 3 // java.lang.Object entry
         1: .line 130
            aload 3 /* entry */
            ifnull 2
            aload 3 /* entry */
            instanceof sun.security.provider.JavaKeyStore$KeyEntry
            ifne 3
         2: .line 131
      StackMap locals: java.lang.Object
      StackMap stack:
            aconst_null
            areturn
         3: .line 133
      StackMap locals:
      StackMap stack:
            aload 2 /* password */
            ifnonnull 5
         4: .line 134
            new java.security.UnrecoverableKeyException
            dup
            ldc "Password must not be null"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 137
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.provider.JavaKeyStore.convertToBytes:([C)[B
            astore 4 /* passwordBytes */
        start local 4 // byte[] passwordBytes
         6: .line 138
            new sun.security.provider.KeyProtector
            dup
            aload 4 /* passwordBytes */
            invokespecial sun.security.provider.KeyProtector.<init>:([B)V
            astore 5 /* keyProtector */
        start local 5 // sun.security.provider.KeyProtector keyProtector
         7: .line 139
            aload 3 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.protectedPrivKey:[B
            astore 6 /* encrBytes */
        start local 6 // byte[] encrBytes
         8: .line 142
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 6 /* encrBytes */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
            astore 7 /* encrInfo */
        start local 7 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
         9: .line 143
            aload 5 /* keyProtector */
            aload 7 /* encrInfo */
            invokevirtual sun.security.provider.KeyProtector.recover:(Lsun/security/pkcs/EncryptedPrivateKeyInfo;)Ljava/security/Key;
            astore 9
        10: .line 149
            aload 4 /* passwordBytes */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        11: .line 143
            aload 9
            areturn
        end local 7 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        12: .line 144
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String char[] java.lang.Object byte[] sun.security.provider.KeyProtector byte[]
      StackMap stack: java.io.IOException
            pop
        13: .line 145
            new java.security.UnrecoverableKeyException
            dup
            ldc "Private key not stored as PKCS #8 EncryptedPrivateKeyInfo"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 148
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 8
        15: .line 149
            aload 4 /* passwordBytes */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        16: .line 150
            aload 8
            athrow
        end local 6 // byte[] encrBytes
        end local 5 // sun.security.provider.KeyProtector keyProtector
        end local 4 // byte[] passwordBytes
        end local 3 // java.lang.Object entry
        end local 2 // char[] password
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   17     0           this  Lsun/security/provider/JavaKeyStore;
            0   17     1          alias  Ljava/lang/String;
            0   17     2       password  [C
            1   17     3          entry  Ljava/lang/Object;
            6   17     4  passwordBytes  [B
            7   17     5   keyProtector  Lsun/security/provider/KeyProtector;
            8   17     6      encrBytes  [B
            9   12     7       encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
      Exception table:
        from    to  target  type
           8    10      12  Class java.io.IOException
           8    10      14  any
          12    14      14  any
    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=3, locals=3, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
         0: .line 165
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         1: .line 167
            aload 2 /* entry */
            ifnull 5
            aload 2 /* entry */
            instanceof sun.security.provider.JavaKeyStore$KeyEntry
            ifeq 5
         2: .line 168
            aload 2 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 4
         3: .line 169
            aconst_null
            areturn
         4: .line 171
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 2 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            areturn
         5: .line 174
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Lsun/security/provider/JavaKeyStore;
            0    6     1  alias  Ljava/lang/String;
            1    6     2  entry  Ljava/lang/Object;
    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=3, locals=3, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
         0: .line 194
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         1: .line 196
            aload 2 /* entry */
            ifnull 7
         2: .line 197
            aload 2 /* entry */
            instanceof sun.security.provider.JavaKeyStore$TrustedCertEntry
            ifeq 4
         3: .line 198
            aload 2 /* entry */
            checkcast sun.security.provider.JavaKeyStore$TrustedCertEntry
            getfield sun.security.provider.JavaKeyStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            areturn
         4: .line 200
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 2 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 6
         5: .line 201
            aconst_null
            areturn
         6: .line 203
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aaload
            areturn
         7: .line 207
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    8     0   this  Lsun/security/provider/JavaKeyStore;
            0    8     1  alias  Ljava/lang/String;
            1    8     2  entry  Ljava/lang/Object;
    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=4, locals=3, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
         0: .line 220
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         1: .line 222
            aload 2 /* entry */
            ifnull 5
         2: .line 223
            aload 2 /* entry */
            instanceof sun.security.provider.JavaKeyStore$TrustedCertEntry
            ifeq 4
         3: .line 224
            new java.util.Date
            dup
            aload 2 /* entry */
            checkcast sun.security.provider.JavaKeyStore$TrustedCertEntry
            getfield sun.security.provider.JavaKeyStore$TrustedCertEntry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokespecial java.util.Date.<init>:(J)V
            areturn
         4: .line 226
      StackMap locals: java.lang.Object
      StackMap stack:
            new java.util.Date
            dup
            aload 2 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokespecial java.util.Date.<init>:(J)V
            areturn
         5: .line 229
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    6     0   this  Lsun/security/provider/JavaKeyStore;
            0    6     1  alias  Ljava/lang/String;
            1    6     2  entry  Ljava/lang/Object;
    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=3, locals=10, args_size=5
        start local 0 // sun.security.provider.JavaKeyStore 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 260
            aconst_null
            astore 6 /* passwordBytes */
        start local 6 // byte[] passwordBytes
         1: .line 262
            aload 2 /* key */
            instanceof java.security.PrivateKey
            ifne 3
         2: .line 263
            new java.security.KeyStoreException
            dup
            ldc "Cannot store non-PrivateKeys"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 266
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] top byte[]
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            dup
            astore 7
            monitorenter
         4: .line 267
            new sun.security.provider.JavaKeyStore$KeyEntry
            dup
            invokespecial sun.security.provider.JavaKeyStore$KeyEntry.<init>:()V
            astore 8 /* entry */
        start local 8 // sun.security.provider.JavaKeyStore$KeyEntry entry
         5: .line 268
            aload 8 /* entry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.provider.JavaKeyStore$KeyEntry.date:Ljava/util/Date;
         6: .line 271
            aload 0 /* this */
            aload 3 /* password */
            invokevirtual sun.security.provider.JavaKeyStore.convertToBytes:([C)[B
            astore 6 /* passwordBytes */
         7: .line 272
            new sun.security.provider.KeyProtector
            dup
            aload 6 /* passwordBytes */
            invokespecial sun.security.provider.KeyProtector.<init>:([B)V
            astore 5 /* keyProtector */
        start local 5 // sun.security.provider.KeyProtector keyProtector
         8: .line 273
            aload 8 /* entry */
            aload 5 /* keyProtector */
            aload 2 /* key */
            invokevirtual sun.security.provider.KeyProtector.protect:(Ljava/security/Key;)[B
            putfield sun.security.provider.JavaKeyStore$KeyEntry.protectedPrivKey:[B
         9: .line 276
            aload 4 /* chain */
            ifnull 13
        10: .line 277
            aload 4 /* chain */
            arraylength
            ifeq 13
        11: .line 278
            aload 8 /* entry */
            aload 4 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        12: .line 279
            goto 14
        13: .line 280
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] sun.security.provider.KeyProtector byte[] java.util.Hashtable sun.security.provider.JavaKeyStore$KeyEntry
      StackMap stack:
            aload 8 /* entry */
            aconst_null
            putfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        14: .line 283
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            aload 8 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 8 // sun.security.provider.JavaKeyStore$KeyEntry entry
        15: .line 266
            aload 7
            monitorexit
        16: goto 25
        end local 5 // sun.security.provider.KeyProtector keyProtector
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] top byte[] java.util.Hashtable
      StackMap stack: java.lang.Throwable
        17: aload 7
            monitorexit
        18: athrow
        19: .line 285
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] top byte[]
      StackMap stack: java.security.NoSuchAlgorithmException
            pop
        20: .line 286
            new java.security.KeyStoreException
            dup
            ldc "Key protection algorithm not found"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 287
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 9
        22: .line 288
            aload 6 /* passwordBytes */
            ifnull 24
        23: .line 289
            aload 6 /* passwordBytes */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        24: .line 290
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] top byte[] top top java.lang.Throwable
      StackMap stack:
            aload 9
            athrow
        start local 5 // sun.security.provider.KeyProtector keyProtector
        25: .line 288
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] sun.security.provider.KeyProtector byte[]
      StackMap stack:
            aload 6 /* passwordBytes */
            ifnull 27
        26: .line 289
            aload 6 /* passwordBytes */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        27: .line 291
      StackMap locals:
      StackMap stack:
            return
        end local 6 // byte[] passwordBytes
        end local 5 // sun.security.provider.KeyProtector keyProtector
        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.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   28     0           this  Lsun/security/provider/JavaKeyStore;
            0   28     1          alias  Ljava/lang/String;
            0   28     2            key  Ljava/security/Key;
            0   28     3       password  [C
            0   28     4          chain  [Ljava/security/cert/Certificate;
            8   17     5   keyProtector  Lsun/security/provider/KeyProtector;
           25   28     5   keyProtector  Lsun/security/provider/KeyProtector;
            1   28     6  passwordBytes  [B
            5   15     8          entry  Lsun/security/provider/JavaKeyStore$KeyEntry;
      Exception table:
        from    to  target  type
           4    16      17  any
          17    18      17  any
           3    19      19  Class java.security.NoSuchAlgorithmException
           3    21      21  any
    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=6, args_size=4
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
        start local 2 // byte[] key
        start local 3 // java.security.cert.Certificate[] chain
         0: .line 320
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            dup
            astore 4
            monitorenter
         1: .line 324
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            aload 2 /* key */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
         2: .line 325
            goto 5
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String byte[] java.security.cert.Certificate[] java.util.Hashtable
      StackMap stack: java.io.IOException
         3: pop
         4: .line 326
            new java.security.KeyStoreException
            dup
            ldc "key is not encoded as EncryptedPrivateKeyInfo"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 330
      StackMap locals:
      StackMap stack:
            new sun.security.provider.JavaKeyStore$KeyEntry
            dup
            invokespecial sun.security.provider.JavaKeyStore$KeyEntry.<init>:()V
            astore 5 /* entry */
        start local 5 // sun.security.provider.JavaKeyStore$KeyEntry entry
         6: .line 331
            aload 5 /* entry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.provider.JavaKeyStore$KeyEntry.date:Ljava/util/Date;
         7: .line 333
            aload 5 /* entry */
            aload 2 /* key */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield sun.security.provider.JavaKeyStore$KeyEntry.protectedPrivKey:[B
         8: .line 334
            aload 3 /* chain */
            ifnull 12
         9: .line 335
            aload 3 /* chain */
            arraylength
            ifeq 12
        10: .line 336
            aload 5 /* entry */
            aload 3 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        11: .line 337
            goto 13
        12: .line 338
      StackMap locals: sun.security.provider.JavaKeyStore$KeyEntry
      StackMap stack:
            aload 5 /* entry */
            aconst_null
            putfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        13: .line 341
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            aload 5 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // sun.security.provider.JavaKeyStore$KeyEntry entry
        14: .line 320
            aload 4
            monitorexit
        15: goto 18
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String byte[] java.security.cert.Certificate[] java.util.Hashtable
      StackMap stack: java.lang.Throwable
        16: aload 4
            monitorexit
        17: athrow
        18: .line 343
      StackMap locals:
      StackMap stack:
            return
        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.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   19     0   this  Lsun/security/provider/JavaKeyStore;
            0   19     1  alias  Ljava/lang/String;
            0   19     2    key  [B
            0   19     3  chain  [Ljava/security/cert/Certificate;
            6   14     5  entry  Lsun/security/provider/JavaKeyStore$KeyEntry;
      Exception table:
        from    to  target  type
           1     2       3  Class java.io.IOException
           1    15      16  any
          16    17      16  any
    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=3, locals=6, args_size=3
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.cert.Certificate cert
         0: .line 362
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            dup
            astore 3
            monitorenter
         1: .line 364
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 4 /* entry */
        start local 4 // java.lang.Object entry
         2: .line 365
            aload 4 /* entry */
            ifnull 6
            aload 4 /* entry */
            instanceof sun.security.provider.JavaKeyStore$KeyEntry
            ifeq 6
         3: .line 366
            new java.security.KeyStoreException
            dup
         4: .line 367
            ldc "Cannot overwrite own certificate"
         5: .line 366
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 370
      StackMap locals: java.util.Hashtable java.lang.Object
      StackMap stack:
            new sun.security.provider.JavaKeyStore$TrustedCertEntry
            dup
            invokespecial sun.security.provider.JavaKeyStore$TrustedCertEntry.<init>:()V
            astore 5 /* trustedCertEntry */
        start local 5 // sun.security.provider.JavaKeyStore$TrustedCertEntry trustedCertEntry
         7: .line 371
            aload 5 /* trustedCertEntry */
            aload 2 /* cert */
            putfield sun.security.provider.JavaKeyStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
         8: .line 372
            aload 5 /* trustedCertEntry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.provider.JavaKeyStore$TrustedCertEntry.date:Ljava/util/Date;
         9: .line 373
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            aload 5 /* trustedCertEntry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 5 // sun.security.provider.JavaKeyStore$TrustedCertEntry trustedCertEntry
        end local 4 // java.lang.Object entry
        10: .line 362
            aload 3
            monitorexit
        11: goto 14
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.security.cert.Certificate java.util.Hashtable
      StackMap stack: java.lang.Throwable
        12: aload 3
            monitorexit
        13: athrow
        14: .line 375
      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.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   15     0              this  Lsun/security/provider/JavaKeyStore;
            0   15     1             alias  Ljava/lang/String;
            0   15     2              cert  Ljava/security/cert/Certificate;
            2   10     4             entry  Ljava/lang/Object;
            7   10     5  trustedCertEntry  Lsun/security/provider/JavaKeyStore$TrustedCertEntry;
      Exception table:
        from    to  target  type
           1    11      12  any
          12    13      12  any
    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=3, locals=3, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
         0: .line 387
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            dup
            astore 2
            monitorenter
         1: .line 388
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 387
            aload 2
            monitorexit
         3: goto 6
      StackMap locals: sun.security.provider.JavaKeyStore java.lang.String java.util.Hashtable
      StackMap stack: java.lang.Throwable
         4: aload 2
            monitorexit
         5: athrow
         6: .line 390
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Lsun/security/provider/JavaKeyStore;
            0    7     1  alias  Ljava/lang/String;
      Exception table:
        from    to  target  type
           1     3       4  any
           4     5       4  any
    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=1, locals=1, args_size=1
        start local 0 // sun.security.provider.JavaKeyStore this
         0: .line 398
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            areturn
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/JavaKeyStore;
    Signature: ()Ljava/util/Enumeration<Ljava/lang/String;>;

  public boolean engineContainsAlias(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
         0: .line 409
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.containsKey:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lsun/security/provider/JavaKeyStore;
            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.provider.JavaKeyStore this
         0: .line 418
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.size:()I
            ireturn
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/JavaKeyStore;

  public boolean engineIsKeyEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
         0: .line 429
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         1: .line 430
            aload 2 /* entry */
            ifnull 3
            aload 2 /* entry */
            instanceof sun.security.provider.JavaKeyStore$KeyEntry
            ifeq 3
         2: .line 431
            iconst_1
            ireturn
         3: .line 433
      StackMap locals: java.lang.Object
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lsun/security/provider/JavaKeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Ljava/lang/Object;
    MethodParameters:
       Name  Flags
      alias  

  public boolean engineIsCertificateEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.lang.String alias
         0: .line 445
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.provider.JavaKeyStore.convertAlias:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         1: .line 446
            aload 2 /* entry */
            ifnull 3
            aload 2 /* entry */
            instanceof sun.security.provider.JavaKeyStore$TrustedCertEntry
            ifeq 3
         2: .line 447
            iconst_1
            ireturn
         3: .line 449
      StackMap locals: java.lang.Object
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lsun/security/provider/JavaKeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Ljava/lang/Object;
    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=6, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.security.cert.Certificate cert
         0: .line 472
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            astore 3 /* e */
        start local 3 // java.util.Enumeration e
         1: goto 11
         2: .line 473
      StackMap locals: sun.security.provider.JavaKeyStore java.security.cert.Certificate top java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* alias */
        start local 4 // java.lang.String alias
         3: .line 474
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 4 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 5 /* entry */
        start local 5 // java.lang.Object entry
         4: .line 475
            aload 5 /* entry */
            instanceof sun.security.provider.JavaKeyStore$TrustedCertEntry
            ifeq 7
         5: .line 476
            aload 5 /* entry */
            checkcast sun.security.provider.JavaKeyStore$TrustedCertEntry
            getfield sun.security.provider.JavaKeyStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            astore 2 /* certElem */
        start local 2 // java.security.cert.Certificate certElem
         6: .line 477
            goto 9
        end local 2 // java.security.cert.Certificate certElem
      StackMap locals: java.lang.String java.lang.Object
      StackMap stack:
         7: aload 5 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 11
         8: .line 478
            aload 5 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aaload
            astore 2 /* certElem */
        start local 2 // java.security.cert.Certificate certElem
         9: .line 482
      StackMap locals: sun.security.provider.JavaKeyStore java.security.cert.Certificate java.security.cert.Certificate java.util.Enumeration java.lang.String java.lang.Object
      StackMap stack:
            aload 2 /* certElem */
            aload 1 /* cert */
            invokevirtual java.security.cert.Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 11
        10: .line 483
            aload 4 /* alias */
            areturn
        end local 5 // java.lang.Object entry
        end local 4 // java.lang.String alias
        end local 2 // java.security.cert.Certificate certElem
        11: .line 472
      StackMap locals: sun.security.provider.JavaKeyStore java.security.cert.Certificate top java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 2
        end local 3 // java.util.Enumeration e
        12: .line 486
            aconst_null
            areturn
        end local 1 // java.security.cert.Certificate cert
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   13     0      this  Lsun/security/provider/JavaKeyStore;
            0   13     1      cert  Ljava/security/cert/Certificate;
            6    7     2  certElem  Ljava/security/cert/Certificate;
            9   11     2  certElem  Ljava/security/cert/Certificate;
            1   12     3         e  Ljava/util/Enumeration<Ljava/lang/String;>;
            3   11     4     alias  Ljava/lang/String;
            4   11     5     entry  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      cert  

  public void engineStore(java.io.OutputStream, char[]);
    descriptor: (Ljava/io/OutputStream;[C)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=12, args_size=3
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.io.OutputStream stream
        start local 2 // char[] password
         0: .line 505
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            dup
            astore 3
            monitorenter
         1: .line 539
            aload 2 /* password */
            ifnonnull 3
         2: .line 540
            new java.lang.IllegalArgumentException
            dup
            ldc "password can't be null"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 545
      StackMap locals: java.util.Hashtable
      StackMap stack:
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.provider.JavaKeyStore.getPreKeyedHash:([C)Ljava/security/MessageDigest;
            astore 5 /* md */
        start local 5 // java.security.MessageDigest md
         4: .line 547
            new java.io.DataOutputStream
            dup
            new java.security.DigestOutputStream
            dup
            aload 1 /* stream */
            aload 5 /* md */
            invokespecial java.security.DigestOutputStream.<init>:(Ljava/io/OutputStream;Ljava/security/MessageDigest;)V
            invokespecial java.io.DataOutputStream.<init>:(Ljava/io/OutputStream;)V
         5: .line 546
            astore 6 /* dos */
        start local 6 // java.io.DataOutputStream dos
         6: .line 549
            aload 6 /* dos */
            ldc -17957139
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
         7: .line 551
            aload 6 /* dos */
            iconst_2
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
         8: .line 553
            aload 6 /* dos */
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.size:()I
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
         9: .line 555
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            astore 7 /* e */
        start local 7 // java.util.Enumeration e
        10: goto 40
        11: .line 557
      StackMap locals: sun.security.provider.JavaKeyStore java.io.OutputStream char[] java.util.Hashtable top java.security.MessageDigest java.io.DataOutputStream java.util.Enumeration
      StackMap stack:
            aload 7 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 8 /* alias */
        start local 8 // java.lang.String alias
        12: .line 558
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 8 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 9 /* entry */
        start local 9 // java.lang.Object entry
        13: .line 560
            aload 9 /* entry */
            instanceof sun.security.provider.JavaKeyStore$KeyEntry
            ifeq 33
        14: .line 563
            aload 6 /* dos */
            iconst_1
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        15: .line 566
            aload 6 /* dos */
            aload 8 /* alias */
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
        16: .line 569
            aload 6 /* dos */
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokevirtual java.io.DataOutputStream.writeLong:(J)V
        17: .line 572
            aload 6 /* dos */
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.protectedPrivKey:[B
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        18: .line 573
            aload 6 /* dos */
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.protectedPrivKey:[B
            invokevirtual java.io.DataOutputStream.write:([B)V
        19: .line 577
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 22
        20: .line 578
            iconst_0
            istore 10 /* chainLen */
        start local 10 // int chainLen
        21: .line 579
            goto 23
        end local 10 // int chainLen
        22: .line 580
      StackMap locals: java.lang.String java.lang.Object
      StackMap stack:
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            istore 10 /* chainLen */
        start local 10 // int chainLen
        23: .line 582
      StackMap locals: int
      StackMap stack:
            aload 6 /* dos */
            iload 10 /* chainLen */
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        24: .line 583
            iconst_0
            istore 11 /* i */
        start local 11 // int i
        25: goto 31
        26: .line 584
      StackMap locals: int
      StackMap stack:
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            iload 11 /* i */
            aaload
            invokevirtual java.security.cert.Certificate.getEncoded:()[B
            astore 4 /* encoded */
        start local 4 // byte[] encoded
        27: .line 585
            aload 6 /* dos */
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$KeyEntry
            getfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
            iload 11 /* i */
            aaload
            invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
        28: .line 586
            aload 6 /* dos */
            aload 4 /* encoded */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        29: .line 587
            aload 6 /* dos */
            aload 4 /* encoded */
            invokevirtual java.io.DataOutputStream.write:([B)V
        30: .line 583
            iinc 11 /* i */ 1
        end local 4 // byte[] encoded
      StackMap locals:
      StackMap stack:
        31: iload 11 /* i */
            iload 10 /* chainLen */
            if_icmplt 26
        end local 11 // int i
        end local 10 // int chainLen
        32: .line 589
            goto 40
        33: .line 592
      StackMap locals:
      StackMap stack:
            aload 6 /* dos */
            iconst_2
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        34: .line 595
            aload 6 /* dos */
            aload 8 /* alias */
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
        35: .line 598
            aload 6 /* dos */
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$TrustedCertEntry
            getfield sun.security.provider.JavaKeyStore$TrustedCertEntry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokevirtual java.io.DataOutputStream.writeLong:(J)V
        36: .line 601
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$TrustedCertEntry
            getfield sun.security.provider.JavaKeyStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            invokevirtual java.security.cert.Certificate.getEncoded:()[B
            astore 4 /* encoded */
        start local 4 // byte[] encoded
        37: .line 602
            aload 6 /* dos */
            aload 9 /* entry */
            checkcast sun.security.provider.JavaKeyStore$TrustedCertEntry
            getfield sun.security.provider.JavaKeyStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
            invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
        38: .line 603
            aload 6 /* dos */
            aload 4 /* encoded */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        39: .line 604
            aload 6 /* dos */
            aload 4 /* encoded */
            invokevirtual java.io.DataOutputStream.write:([B)V
        end local 9 // java.lang.Object entry
        end local 8 // java.lang.String alias
        end local 4 // byte[] encoded
        40: .line 555
      StackMap locals:
      StackMap stack:
            aload 7 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 11
        end local 7 // java.util.Enumeration e
        41: .line 613
            aload 5 /* md */
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 7 /* digest */
        start local 7 // byte[] digest
        42: .line 615
            aload 6 /* dos */
            aload 7 /* digest */
            invokevirtual java.io.DataOutputStream.write:([B)V
        43: .line 616
            aload 6 /* dos */
            invokevirtual java.io.DataOutputStream.flush:()V
        end local 7 // byte[] digest
        end local 6 // java.io.DataOutputStream dos
        end local 5 // java.security.MessageDigest md
        44: .line 505
            aload 3
            monitorexit
        45: goto 48
      StackMap locals: sun.security.provider.JavaKeyStore java.io.OutputStream char[] java.util.Hashtable
      StackMap stack: java.lang.Throwable
        46: aload 3
            monitorexit
        47: athrow
        48: .line 618
      StackMap locals:
      StackMap stack:
            return
        end local 2 // char[] password
        end local 1 // java.io.OutputStream stream
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   49     0      this  Lsun/security/provider/JavaKeyStore;
            0   49     1    stream  Ljava/io/OutputStream;
            0   49     2  password  [C
           27   31     4   encoded  [B
           37   40     4   encoded  [B
            4   44     5        md  Ljava/security/MessageDigest;
            6   44     6       dos  Ljava/io/DataOutputStream;
           10   41     7         e  Ljava/util/Enumeration<Ljava/lang/String;>;
           12   40     8     alias  Ljava/lang/String;
           13   40     9     entry  Ljava/lang/Object;
           21   22    10  chainLen  I
           23   32    10  chainLen  I
           25   32    11         i  I
           42   44     7    digest  [B
      Exception table:
        from    to  target  type
           1    45      46  any
          46    47      46  any
    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=6, locals=23, args_size=3
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // java.io.InputStream stream
        start local 2 // char[] password
         0: .line 640
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            dup
            astore 3
            monitorenter
         1: .line 642
            aconst_null
            astore 5 /* md */
        start local 5 // java.security.MessageDigest md
         2: .line 643
            aconst_null
            astore 6 /* cf */
        start local 6 // java.security.cert.CertificateFactory cf
         3: .line 644
            aconst_null
            astore 7 /* cfs */
        start local 7 // java.util.Hashtable cfs
         4: .line 645
            aconst_null
            astore 8 /* bais */
        start local 8 // java.io.ByteArrayInputStream bais
         5: .line 646
            aconst_null
            astore 9 /* encoded */
        start local 9 // byte[] encoded
         6: .line 647
            iconst_0
            istore 10 /* trustedKeyCount */
        start local 10 // int trustedKeyCount
         7: iconst_0
            istore 11 /* privateKeyCount */
        start local 11 // int privateKeyCount
         8: .line 649
            aload 1 /* stream */
            ifnonnull 11
         9: .line 650
            aload 3
            monitorexit
        10: return
        11: .line 652
      StackMap locals: sun.security.provider.JavaKeyStore java.io.InputStream char[] java.util.Hashtable top java.security.MessageDigest java.security.cert.CertificateFactory java.util.Hashtable java.io.ByteArrayInputStream byte[] int int
      StackMap stack:
            aload 2 /* password */
            ifnull 15
        12: .line 653
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.provider.JavaKeyStore.getPreKeyedHash:([C)Ljava/security/MessageDigest;
            astore 5 /* md */
        13: .line 654
            new java.io.DataInputStream
            dup
            new java.security.DigestInputStream
            dup
            aload 1 /* stream */
            aload 5 /* md */
            invokespecial java.security.DigestInputStream.<init>:(Ljava/io/InputStream;Ljava/security/MessageDigest;)V
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 4 /* dis */
        start local 4 // java.io.DataInputStream dis
        14: .line 655
            goto 16
        end local 4 // java.io.DataInputStream dis
        15: .line 656
      StackMap locals:
      StackMap stack:
            new java.io.DataInputStream
            dup
            aload 1 /* stream */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 4 /* dis */
        start local 4 // java.io.DataInputStream dis
        16: .line 661
      StackMap locals: sun.security.provider.JavaKeyStore java.io.InputStream char[] java.util.Hashtable java.io.DataInputStream java.security.MessageDigest java.security.cert.CertificateFactory java.util.Hashtable java.io.ByteArrayInputStream byte[] int int
      StackMap stack:
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 12 /* xMagic */
        start local 12 // int xMagic
        17: .line 662
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 13 /* xVersion */
        start local 13 // int xVersion
        18: .line 664
            iload 12 /* xMagic */
            ldc -17957139
            if_icmpne 20
        19: .line 665
            iload 13 /* xVersion */
            iconst_1
            if_icmpeq 21
            iload 13 /* xVersion */
            iconst_2
            if_icmpeq 21
        20: .line 666
      StackMap locals: int int
      StackMap stack:
            new java.io.IOException
            dup
            ldc "Invalid keystore format"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 669
      StackMap locals:
      StackMap stack:
            iload 13 /* xVersion */
            iconst_1
            if_icmpne 24
        22: .line 670
            ldc "X509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 6 /* cf */
        23: .line 671
            goto 25
        24: .line 673
      StackMap locals:
      StackMap stack:
            new java.util.Hashtable
            dup
            iconst_3
            invokespecial java.util.Hashtable.<init>:(I)V
            astore 7 /* cfs */
        25: .line 676
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.clear:()V
        26: .line 677
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 14 /* count */
        start local 14 // int count
        27: .line 679
            iconst_0
            istore 15 /* i */
        start local 15 // int i
        28: goto 84
        29: .line 683
      StackMap locals: int int
      StackMap stack:
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 16 /* tag */
        start local 16 // int tag
        30: .line 685
            iload 16 /* tag */
            iconst_1
            if_icmpne 62
        31: .line 686
            iinc 11 /* privateKeyCount */ 1
        32: .line 687
            new sun.security.provider.JavaKeyStore$KeyEntry
            dup
            invokespecial sun.security.provider.JavaKeyStore$KeyEntry.<init>:()V
            astore 18 /* entry */
        start local 18 // sun.security.provider.JavaKeyStore$KeyEntry entry
        33: .line 690
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 17 /* alias */
        start local 17 // java.lang.String alias
        34: .line 693
            aload 18 /* entry */
            new java.util.Date
            dup
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readLong:()J
            invokespecial java.util.Date.<init>:(J)V
            putfield sun.security.provider.JavaKeyStore$KeyEntry.date:Ljava/util/Date;
        35: .line 696
            aload 18 /* entry */
        36: .line 697
            aload 4 /* dis */
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            invokestatic sun.misc.IOUtils.readExactlyNBytes:(Ljava/io/InputStream;I)[B
        37: .line 696
            putfield sun.security.provider.JavaKeyStore$KeyEntry.protectedPrivKey:[B
        38: .line 700
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 19 /* numOfCerts */
        start local 19 // int numOfCerts
        39: .line 701
            iload 19 /* numOfCerts */
            ifle 60
        40: .line 702
            new java.util.ArrayList
            dup
        41: .line 703
            iload 19 /* numOfCerts */
            bipush 10
            if_icmple 42
            bipush 10
            goto 43
      StackMap locals: sun.security.provider.JavaKeyStore java.io.InputStream char[] java.util.Hashtable java.io.DataInputStream java.security.MessageDigest java.security.cert.CertificateFactory java.util.Hashtable java.io.ByteArrayInputStream byte[] int int int int int int int java.lang.String sun.security.provider.JavaKeyStore$KeyEntry int
      StackMap stack: new 40 new 40
        42: iload 19 /* numOfCerts */
        43: .line 702
      StackMap locals: sun.security.provider.JavaKeyStore java.io.InputStream char[] java.util.Hashtable java.io.DataInputStream java.security.MessageDigest java.security.cert.CertificateFactory java.util.Hashtable java.io.ByteArrayInputStream byte[] int int int int int int int java.lang.String sun.security.provider.JavaKeyStore$KeyEntry int
      StackMap stack: new 40 new 40 int
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 20 /* certs */
        start local 20 // java.util.List certs
        44: .line 704
            iconst_0
            istore 21 /* j */
        start local 21 // int j
        45: goto 58
        46: .line 705
      StackMap locals: java.util.List int
      StackMap stack:
            iload 13 /* xVersion */
            iconst_2
            if_icmpne 53
        47: .line 709
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 22 /* certType */
        start local 22 // java.lang.String certType
        48: .line 710
            aload 7 /* cfs */
            aload 22 /* certType */
            invokevirtual java.util.Hashtable.containsKey:(Ljava/lang/Object;)Z
            ifeq 51
        49: .line 712
            aload 7 /* cfs */
            aload 22 /* certType */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.cert.CertificateFactory
            astore 6 /* cf */
        50: .line 713
            goto 53
        51: .line 715
      StackMap locals: java.lang.String
      StackMap stack:
            aload 22 /* certType */
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 6 /* cf */
        52: .line 718
            aload 7 /* cfs */
            aload 22 /* certType */
            aload 6 /* cf */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 22 // java.lang.String certType
        53: .line 722
      StackMap locals:
      StackMap stack:
            aload 4 /* dis */
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            invokestatic sun.misc.IOUtils.readExactlyNBytes:(Ljava/io/InputStream;I)[B
            astore 9 /* encoded */
        54: .line 723
            new java.io.ByteArrayInputStream
            dup
            aload 9 /* encoded */
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 8 /* bais */
        55: .line 724
            aload 20 /* certs */
            aload 6 /* cf */
            aload 8 /* bais */
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        56: .line 725
            aload 8 /* bais */
            invokevirtual java.io.ByteArrayInputStream.close:()V
        57: .line 704
            iinc 21 /* j */ 1
      StackMap locals:
      StackMap stack:
        58: iload 21 /* j */
            iload 19 /* numOfCerts */
            if_icmplt 46
        end local 21 // int j
        59: .line 728
            aload 18 /* entry */
            aload 20 /* certs */
            iload 19 /* numOfCerts */
            anewarray java.security.cert.Certificate
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield sun.security.provider.JavaKeyStore$KeyEntry.chain:[Ljava/security/cert/Certificate;
        end local 20 // java.util.List certs
        60: .line 732
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 17 /* alias */
            aload 18 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 19 // int numOfCerts
        end local 18 // sun.security.provider.JavaKeyStore$KeyEntry entry
        61: .line 734
            goto 83
        end local 17 // java.lang.String alias
      StackMap locals:
      StackMap stack:
        62: iload 16 /* tag */
            iconst_2
            if_icmpne 80
        63: .line 735
            iinc 10 /* trustedKeyCount */ 1
        64: .line 736
            new sun.security.provider.JavaKeyStore$TrustedCertEntry
            dup
            invokespecial sun.security.provider.JavaKeyStore$TrustedCertEntry.<init>:()V
            astore 18 /* entry */
        start local 18 // sun.security.provider.JavaKeyStore$TrustedCertEntry entry
        65: .line 739
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 17 /* alias */
        start local 17 // java.lang.String alias
        66: .line 742
            aload 18 /* entry */
            new java.util.Date
            dup
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readLong:()J
            invokespecial java.util.Date.<init>:(J)V
            putfield sun.security.provider.JavaKeyStore$TrustedCertEntry.date:Ljava/util/Date;
        67: .line 745
            iload 13 /* xVersion */
            iconst_2
            if_icmpne 74
        68: .line 749
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 19 /* certType */
        start local 19 // java.lang.String certType
        69: .line 750
            aload 7 /* cfs */
            aload 19 /* certType */
            invokevirtual java.util.Hashtable.containsKey:(Ljava/lang/Object;)Z
            ifeq 72
        70: .line 752
            aload 7 /* cfs */
            aload 19 /* certType */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.cert.CertificateFactory
            astore 6 /* cf */
        71: .line 753
            goto 74
        72: .line 755
      StackMap locals: java.lang.String sun.security.provider.JavaKeyStore$TrustedCertEntry java.lang.String
      StackMap stack:
            aload 19 /* certType */
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 6 /* cf */
        73: .line 758
            aload 7 /* cfs */
            aload 19 /* certType */
            aload 6 /* cf */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 19 // java.lang.String certType
        74: .line 761
      StackMap locals:
      StackMap stack:
            aload 4 /* dis */
            aload 4 /* dis */
            invokevirtual java.io.DataInputStream.readInt:()I
            invokestatic sun.misc.IOUtils.readExactlyNBytes:(Ljava/io/InputStream;I)[B
            astore 9 /* encoded */
        75: .line 762
            new java.io.ByteArrayInputStream
            dup
            aload 9 /* encoded */
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 8 /* bais */
        76: .line 763
            aload 18 /* entry */
            aload 6 /* cf */
            aload 8 /* bais */
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            putfield sun.security.provider.JavaKeyStore$TrustedCertEntry.cert:Ljava/security/cert/Certificate;
        77: .line 764
            aload 8 /* bais */
            invokevirtual java.io.ByteArrayInputStream.close:()V
        78: .line 767
            aload 0 /* this */
            getfield sun.security.provider.JavaKeyStore.entries:Ljava/util/Hashtable;
            aload 17 /* alias */
            aload 18 /* entry */
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 18 // sun.security.provider.JavaKeyStore$TrustedCertEntry entry
        79: .line 769
            goto 83
        end local 17 // java.lang.String alias
        80: .line 770
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unrecognized keystore entry: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        81: .line 771
            iload 16 /* tag */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        82: .line 770
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 16 // int tag
        83: .line 679
      StackMap locals:
      StackMap stack:
            iinc 15 /* i */ 1
      StackMap locals:
      StackMap stack:
        84: iload 15 /* i */
            iload 14 /* count */
            if_icmplt 29
        end local 15 // int i
        85: .line 775
            getstatic sun.security.provider.JavaKeyStore.debug:Lsun/security/util/Debug;
            ifnull 89
        86: .line 776
            getstatic sun.security.provider.JavaKeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "JavaKeyStore load: private key count: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        87: .line 777
            iload 11 /* privateKeyCount */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc ". trusted key count: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 10 /* trustedKeyCount */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        88: .line 776
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        89: .line 785
      StackMap locals:
      StackMap stack:
            aload 2 /* password */
            ifnull 101
        90: .line 787
            aload 5 /* md */
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 15 /* computed */
        start local 15 // byte[] computed
        91: .line 788
            aload 4 /* dis */
            aload 15 /* computed */
            arraylength
            invokestatic sun.misc.IOUtils.readExactlyNBytes:(Ljava/io/InputStream;I)[B
            astore 16 /* actual */
        start local 16 // byte[] actual
        92: .line 789
            aload 15 /* computed */
            aload 16 /* actual */
            invokestatic java.security.MessageDigest.isEqual:([B[B)Z
            ifne 101
        93: .line 790
            new java.security.UnrecoverableKeyException
            dup
        94: .line 791
            ldc "Password verification failed"
        95: .line 790
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            astore 17 /* t */
        start local 17 // java.lang.Throwable t
        96: .line 792
            new java.io.IOException
            dup
        97: .line 793
            ldc "Keystore was tampered with, or password was incorrect"
        98: .line 792
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
        99: .line 794
            aload 17 /* t */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
       100: .line 792
            checkcast java.io.IOException
            athrow
        end local 17 // java.lang.Throwable t
        end local 16 // byte[] actual
        end local 15 // byte[] computed
        end local 14 // int count
        end local 13 // int xVersion
        end local 12 // int xMagic
        end local 11 // int privateKeyCount
        end local 10 // int trustedKeyCount
        end local 9 // byte[] encoded
        end local 8 // java.io.ByteArrayInputStream bais
        end local 7 // java.util.Hashtable cfs
        end local 6 // java.security.cert.CertificateFactory cf
        end local 5 // java.security.MessageDigest md
        end local 4 // java.io.DataInputStream dis
       101: .line 640
      StackMap locals: sun.security.provider.JavaKeyStore java.io.InputStream char[] java.util.Hashtable
      StackMap stack:
            aload 3
            monitorexit
       102: goto 105
      StackMap locals:
      StackMap stack: java.lang.Throwable
       103: aload 3
            monitorexit
       104: athrow
       105: .line 798
      StackMap locals:
      StackMap stack:
            return
        end local 2 // char[] password
        end local 1 // java.io.InputStream stream
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0  106     0             this  Lsun/security/provider/JavaKeyStore;
            0  106     1           stream  Ljava/io/InputStream;
            0  106     2         password  [C
           14   15     4              dis  Ljava/io/DataInputStream;
           16  101     4              dis  Ljava/io/DataInputStream;
            2  101     5               md  Ljava/security/MessageDigest;
            3  101     6               cf  Ljava/security/cert/CertificateFactory;
            4  101     7              cfs  Ljava/util/Hashtable<Ljava/lang/String;Ljava/security/cert/CertificateFactory;>;
            5  101     8             bais  Ljava/io/ByteArrayInputStream;
            6  101     9          encoded  [B
            7  101    10  trustedKeyCount  I
            8  101    11  privateKeyCount  I
           17  101    12           xMagic  I
           18  101    13         xVersion  I
           27  101    14            count  I
           28   85    15                i  I
           30   83    16              tag  I
           34   62    17            alias  Ljava/lang/String;
           66   80    17            alias  Ljava/lang/String;
           33   61    18            entry  Lsun/security/provider/JavaKeyStore$KeyEntry;
           39   61    19       numOfCerts  I
           44   60    20            certs  Ljava/util/List<Ljava/security/cert/Certificate;>;
           45   59    21                j  I
           48   53    22         certType  Ljava/lang/String;
           65   79    18            entry  Lsun/security/provider/JavaKeyStore$TrustedCertEntry;
           69   74    19         certType  Ljava/lang/String;
           91  101    15         computed  [B
           92  101    16           actual  [B
           96  101    17                t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           1    10     103  any
          11   102     103  any
         103   104     103  any
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  private java.security.MessageDigest getPreKeyedHash(char[]);
    descriptor: ([C)Ljava/security/MessageDigest;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // char[] password
         0: .line 808
            ldc "SHA"
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
            astore 2 /* md */
        start local 2 // java.security.MessageDigest md
         1: .line 809
            aload 0 /* this */
            aload 1 /* password */
            invokevirtual sun.security.provider.JavaKeyStore.convertToBytes:([C)[B
            astore 3 /* passwdBytes */
        start local 3 // byte[] passwdBytes
         2: .line 810
            aload 2 /* md */
            aload 3 /* passwdBytes */
            invokevirtual java.security.MessageDigest.update:([B)V
         3: .line 811
            aload 3 /* passwdBytes */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
         4: .line 812
            aload 2 /* md */
            ldc "Mighty Aphrodite"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.security.MessageDigest.update:([B)V
         5: .line 813
            aload 2 /* md */
            areturn
        end local 3 // byte[] passwdBytes
        end local 2 // java.security.MessageDigest md
        end local 1 // char[] password
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    6     0         this  Lsun/security/provider/JavaKeyStore;
            0    6     1     password  [C
            1    6     2           md  Ljava/security/MessageDigest;
            2    6     3  passwdBytes  [B
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.io.UnsupportedEncodingException
    MethodParameters:
          Name  Flags
      password  

  private byte[] convertToBytes(char[]);
    descriptor: ([C)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // sun.security.provider.JavaKeyStore this
        start local 1 // char[] password
         0: .line 822
            aload 1 /* password */
            arraylength
            iconst_2
            imul
            newarray 8
            astore 4 /* passwdBytes */
        start local 4 // byte[] passwdBytes
         1: .line 823
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         2: iconst_0
            istore 3 /* j */
        start local 3 // int j
         3: goto 7
         4: .line 824
      StackMap locals: int int byte[]
      StackMap stack:
            aload 4 /* passwdBytes */
            iload 3 /* j */
            iinc 3 /* j */ 1
            aload 1 /* password */
            iload 2 /* i */
            caload
            bipush 8
            ishr
            i2b
            bastore
         5: .line 825
            aload 4 /* passwdBytes */
            iload 3 /* j */
            iinc 3 /* j */ 1
            aload 1 /* password */
            iload 2 /* i */
            caload
            i2b
            bastore
         6: .line 823
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         7: iload 2 /* i */
            aload 1 /* password */
            arraylength
            if_icmplt 4
         8: .line 827
            aload 4 /* passwdBytes */
            areturn
        end local 4 // byte[] passwdBytes
        end local 3 // int j
        end local 2 // int i
        end local 1 // char[] password
        end local 0 // sun.security.provider.JavaKeyStore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    9     0         this  Lsun/security/provider/JavaKeyStore;
            0    9     1     password  [C
            2    9     2            i  I
            3    9     3            j  I
            1    9     4  passwdBytes  [B
    MethodParameters:
          Name  Flags
      password  
}
SourceFile: "JavaKeyStore.java"
NestMembers:
  sun.security.provider.JavaKeyStore$CaseExactJKS  sun.security.provider.JavaKeyStore$DualFormatJKS  sun.security.provider.JavaKeyStore$JKS  sun.security.provider.JavaKeyStore$KeyEntry  sun.security.provider.JavaKeyStore$TrustedCertEntry
InnerClasses:
  public final CaseExactJKS = sun.security.provider.JavaKeyStore$CaseExactJKS of sun.security.provider.JavaKeyStore
  public final DualFormatJKS = sun.security.provider.JavaKeyStore$DualFormatJKS of sun.security.provider.JavaKeyStore
  public final JKS = sun.security.provider.JavaKeyStore$JKS of sun.security.provider.JavaKeyStore
  private KeyEntry = sun.security.provider.JavaKeyStore$KeyEntry of sun.security.provider.JavaKeyStore
  private TrustedCertEntry = sun.security.provider.JavaKeyStore$TrustedCertEntry of sun.security.provider.JavaKeyStore