public final class sun.security.pkcs12.PKCS12KeyStore extends java.security.KeyStoreSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.pkcs12.PKCS12KeyStore
  super_class: java.security.KeyStoreSpi
{
  public static final int VERSION_3;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 3

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

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

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

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

  private static final java.lang.String[] CORE_ATTRIBUTES;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  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[] keyBag;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] certBag;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] secretBag;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] pkcs9Name;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] pkcs9KeyId;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] pkcs9certType;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] pbeWithSHAAnd40BitRC2CBC;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] pbeWithSHAAnd3KeyTripleDESCBC;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] TrustedKeyUsage;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] AnyExtendedKeyUsage;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static sun.security.util.ObjectIdentifier PKCS8ShroudedKeyBag_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier CertBag_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier SecretBag_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier PKCS9FriendlyName_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier PKCS9LocalKeyId_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier PKCS9CertType_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier pbeWithSHAAnd40BitRC2CBC_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier pbeWithSHAAnd3KeyTripleDESCBC_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier TrustedKeyUsage_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier[] AnyUsage;
    descriptor: [Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

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

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

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

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

  private java.security.SecureRandom random;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0002) ACC_PRIVATE

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

  private java.util.ArrayList<sun.security.pkcs12.PKCS12KeyStore$KeyEntry> keyList;
    descriptor: Ljava/util/ArrayList;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/ArrayList<Lsun/security/pkcs12/PKCS12KeyStore$KeyEntry;>;

  private java.util.LinkedHashMap<javax.security.auth.x500.X500Principal, java.security.cert.X509Certificate> certsMap;
    descriptor: Ljava/util/LinkedHashMap;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/LinkedHashMap<Ljavax/security/auth/x500/X500Principal;Ljava/security/cert/X509Certificate;>;

  private java.util.ArrayList<sun.security.pkcs12.PKCS12KeyStore$CertEntry> certEntries;
    descriptor: Ljava/util/ArrayList;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/ArrayList<Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=0, args_size=0
         0: .line 140
            iconst_3
            anewarray java.lang.String
            dup
            iconst_0
         1: .line 141
            ldc "1.2.840.113549.1.9.20"
            aastore
            dup
            iconst_1
         2: .line 142
            ldc "1.2.840.113549.1.9.21"
            aastore
            dup
            iconst_2
         3: .line 143
            ldc "2.16.840.1.113894.746875.1.1"
            aastore
         4: .line 140
            putstatic sun.security.pkcs12.PKCS12KeyStore.CORE_ATTRIBUTES:[Ljava/lang/String;
         5: .line 146
            ldc "pkcs12"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
         6: .line 148
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            bipush 10
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_2
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.keyBag:[I
         7: .line 149
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            bipush 10
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_3
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.certBag:[I
         8: .line 150
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            bipush 10
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_5
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.secretBag:[I
         9: .line 152
            bipush 7
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 9
            iastore
            dup
            bipush 6
            bipush 20
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9Name:[I
        10: .line 153
            bipush 7
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 9
            iastore
            dup
            bipush 6
            bipush 21
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9KeyId:[I
        11: .line 155
            bipush 8
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 9
            iastore
            dup
            bipush 6
            bipush 22
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9certType:[I
        12: .line 158
            bipush 8
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            iconst_1
            iastore
            dup
            bipush 7
            bipush 6
            iastore
        13: .line 157
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd40BitRC2CBC:[I
        14: .line 160
            bipush 8
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            iconst_1
            iastore
            dup
            bipush 7
            iconst_3
            iastore
        15: .line 159
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd3KeyTripleDESCBC:[I
        16: .line 167
            bipush 8
            newarray 10
            dup
            iconst_0
            iconst_2
            iastore
            dup
            iconst_1
            bipush 16
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            iconst_1
            iastore
            dup
            iconst_4
            ldc 113894
            iastore
            dup
            iconst_5
            ldc 746875
            iastore
            dup
            bipush 6
            iconst_1
            iastore
            dup
            bipush 7
            iconst_1
            iastore
        17: .line 166
            putstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage:[I
        18: .line 168
            iconst_5
            newarray 10
            dup
            iconst_0
            iconst_2
            iastore
            dup
            iconst_1
            iconst_5
            iastore
            dup
            iconst_2
            bipush 29
            iastore
            dup
            iconst_3
            bipush 37
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.AnyExtendedKeyUsage:[I
        19: .line 199
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.keyBag:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS8ShroudedKeyBag_OID:Lsun/security/util/ObjectIdentifier;
        20: .line 200
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.certBag:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.CertBag_OID:Lsun/security/util/ObjectIdentifier;
        21: .line 201
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.secretBag:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.SecretBag_OID:Lsun/security/util/ObjectIdentifier;
        22: .line 202
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9Name:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9FriendlyName_OID:Lsun/security/util/ObjectIdentifier;
        23: .line 203
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9KeyId:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9LocalKeyId_OID:Lsun/security/util/ObjectIdentifier;
        24: .line 204
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9certType:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9CertType_OID:Lsun/security/util/ObjectIdentifier;
        25: .line 206
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd40BitRC2CBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
        26: .line 205
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd40BitRC2CBC_OID:Lsun/security/util/ObjectIdentifier;
        27: .line 208
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd3KeyTripleDESCBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
        28: .line 207
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd3KeyTripleDESCBC_OID:Lsun/security/util/ObjectIdentifier;
        29: .line 209
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
        30: .line 210
            iconst_1
            anewarray sun.security.util.ObjectIdentifier
            dup
            iconst_0
        31: .line 211
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.AnyExtendedKeyUsage:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            aastore
        32: .line 210
            putstatic sun.security.pkcs12.PKCS12KeyStore.AnyUsage:[Lsun/security/util/ObjectIdentifier;
        33: .line 212
            goto 35
      StackMap locals:
      StackMap stack: java.io.IOException
        34: pop
        35: .line 215
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
          19    33      34  Class java.io.IOException

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
         0: .line 130
            aload 0 /* this */
            invokespecial java.security.KeyStoreSpi.<init>:()V
         1: .line 181
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         2: .line 186
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
         3: .line 189
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
         4: .line 192
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
         5: .line 268
            aload 0 /* this */
         6: .line 269
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            invokestatic java.util.Collections.synchronizedMap:(Ljava/util/Map;)Ljava/util/Map;
            putfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
         7: .line 271
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
         8: .line 272
            aload 0 /* this */
         9: .line 273
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
        10: .line 274
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
        11: .line 130
            return
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lsun/security/pkcs12/PKCS12KeyStore;

  public java.security.Key engineGetKey(java.lang.String, char[]);
    descriptor: (Ljava/lang/String;[C)Ljava/security/Key;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=21, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // char[] password
         0: .line 294
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 3 /* entry */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         1: .line 295
            aconst_null
            astore 4 /* key */
        start local 4 // java.security.Key key
         2: .line 297
            aload 3 /* entry */
            ifnull 3
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifne 4
         3: .line 298
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key
      StackMap stack:
            aconst_null
            areturn
         4: .line 302
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 5 /* encrBytes */
        start local 5 // byte[] encrBytes
         5: .line 303
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 8
         6: .line 304
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
            astore 5 /* encrBytes */
         7: .line 305
            goto 12
      StackMap locals: byte[]
      StackMap stack:
         8: aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 11
         9: .line 306
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
            astore 5 /* encrBytes */
        10: .line 307
            goto 12
        11: .line 308
      StackMap locals:
      StackMap stack:
            new java.security.UnrecoverableKeyException
            dup
            ldc "Error locating key"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 318
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 5 /* encrBytes */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
        13: .line 317
            astore 9 /* encrInfo */
        start local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        14: .line 319
            aload 9 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncryptedData:()[B
            astore 6 /* encryptedKey */
        start local 6 // byte[] encryptedKey
        15: .line 322
            new sun.security.util.DerValue
            dup
            aload 9 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getAlgorithm:()Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.encode:()[B
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 10 /* val */
        start local 10 // sun.security.util.DerValue val
        16: .line 323
            aload 10 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 11 /* in */
        start local 11 // sun.security.util.DerInputStream in
        17: .line 324
            aload 11 /* in */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* algOid */
        start local 8 // sun.security.util.ObjectIdentifier algOid
        18: .line 325
            aload 0 /* this */
            aload 11 /* in */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.parseAlgParameters:(Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
            astore 7 /* algParams */
        end local 11 // sun.security.util.DerInputStream in
        end local 10 // sun.security.util.DerValue val
        end local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        start local 7 // java.security.AlgorithmParameters algParams
        19: .line 327
            goto 27
        end local 8 // sun.security.util.ObjectIdentifier algOid
        end local 7 // java.security.AlgorithmParameters algParams
        end local 6 // byte[] encryptedKey
      StackMap locals:
      StackMap stack: java.io.IOException
        20: astore 9 /* ioe */
        start local 9 // java.io.IOException ioe
        21: .line 329
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Private key not stored as PKCS#8 EncryptedPrivateKeyInfo: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        22: .line 330
            aload 9 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        23: .line 329
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        24: .line 328
            astore 10 /* uke */
        start local 10 // java.security.UnrecoverableKeyException uke
        25: .line 331
            aload 10 /* uke */
            aload 9 /* ioe */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        26: .line 332
            aload 10 /* uke */
            athrow
        end local 10 // java.security.UnrecoverableKeyException uke
        end local 9 // java.io.IOException ioe
        start local 6 // byte[] encryptedKey
        start local 7 // java.security.AlgorithmParameters algParams
        start local 8 // sun.security.util.ObjectIdentifier algOid
        27: .line 337
      StackMap locals: byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier
      StackMap stack:
            iconst_0
            istore 10 /* ic */
        start local 10 // int ic
        28: .line 339
            aload 7 /* algParams */
            ifnull 37
        29: .line 342
            aload 7 /* algParams */
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            checkcast javax.crypto.spec.PBEParameterSpec
        30: .line 341
            astore 9 /* pbeSpec */
        start local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
        31: .line 343
            goto 34
        end local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String char[] sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key byte[] byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier top int
      StackMap stack: java.security.spec.InvalidParameterSpecException
        32: pop
        33: .line 344
            new java.io.IOException
            dup
            ldc "Invalid PBE algorithm parameters"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
        34: .line 346
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String char[] sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key byte[] byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier javax.crypto.spec.PBEParameterSpec int
      StackMap stack:
            aload 9 /* pbeSpec */
            invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
            istore 10 /* ic */
        35: .line 348
            iload 10 /* ic */
            ldc 5000000
            if_icmple 37
        36: .line 349
            new java.io.IOException
            dup
            ldc "PBE iteration count too large"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
        37: .line 357
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String char[] sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key byte[] byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier top int
      StackMap stack:
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 12 /* skey */
        start local 12 // javax.crypto.SecretKey skey
        38: .line 358
            aload 8 /* algOid */
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 13 /* cipher */
        start local 13 // javax.crypto.Cipher cipher
        39: .line 359
            aload 13 /* cipher */
            iconst_2
            aload 12 /* skey */
            aload 7 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        40: .line 360
            aload 13 /* cipher */
            aload 6 /* encryptedKey */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 11 /* keyInfo */
        start local 11 // byte[] keyInfo
        41: .line 361
            goto 47
        end local 13 // javax.crypto.Cipher cipher
        end local 12 // javax.crypto.SecretKey skey
        end local 11 // byte[] keyInfo
        42: .line 362
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 12 /* e */
        start local 12 // java.lang.Exception e
        43: .line 363
            aload 2 /* password */
            arraylength
            ifne 46
        44: .line 366
            iconst_1
            newarray 5
            astore 2 /* password */
        45: .line 367
            goto 37
        46: .line 369
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String char[] sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key byte[] byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier top int top java.lang.Exception
      StackMap stack:
            aload 12 /* e */
            athrow
        end local 12 // java.lang.Exception e
        start local 11 // byte[] keyInfo
        47: .line 377
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String char[] sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key byte[] byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier top int byte[]
      StackMap stack:
            new sun.security.util.DerValue
            dup
            aload 11 /* keyInfo */
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 12 /* val */
        start local 12 // sun.security.util.DerValue val
        48: .line 378
            aload 12 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 13 /* in */
        start local 13 // sun.security.util.DerInputStream in
        49: .line 379
            aload 13 /* in */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
        50: .line 380
            aload 13 /* in */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 14 /* value */
        start local 14 // sun.security.util.DerValue[] value
        51: .line 381
            aload 14 /* value */
            arraylength
            iconst_1
            if_icmplt 52
            aload 14 /* value */
            arraylength
            iconst_2
            if_icmple 53
        52: .line 382
      StackMap locals: sun.security.util.DerValue sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            new java.io.IOException
            dup
            ldc "Invalid length for AlgorithmIdentifier"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        53: .line 384
      StackMap locals:
      StackMap stack:
            new sun.security.x509.AlgorithmId
            dup
            aload 14 /* value */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;)V
            astore 15 /* algId */
        start local 15 // sun.security.x509.AlgorithmId algId
        54: .line 385
            aload 15 /* algId */
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            astore 16 /* keyAlgo */
        start local 16 // java.lang.String keyAlgo
        55: .line 388
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 66
        56: .line 389
            aload 16 /* keyAlgo */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 17 /* kfac */
        start local 17 // java.security.KeyFactory kfac
        57: .line 390
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 11 /* keyInfo */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            astore 18 /* kspec */
        start local 18 // java.security.spec.PKCS8EncodedKeySpec kspec
        58: .line 391
            aload 17 /* kfac */
            aload 18 /* kspec */
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
            astore 4 /* key */
        59: .line 393
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 91
        60: .line 394
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Retrieved a protected private key at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        61: .line 395
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "' ("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        62: .line 396
            new sun.security.x509.AlgorithmId
            dup
            aload 8 /* algOid */
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;)V
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        63: .line 397
            ldc " iterations: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 10 /* ic */
            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;
        64: .line 394
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 18 // java.security.spec.PKCS8EncodedKeySpec kspec
        end local 17 // java.security.KeyFactory kfac
        65: .line 401
            goto 91
        66: .line 402
      StackMap locals: sun.security.x509.AlgorithmId java.lang.String
      StackMap stack:
            aload 13 /* in */
            invokevirtual sun.security.util.DerInputStream.getOctetString:()[B
            astore 17 /* keyBytes */
        start local 17 // byte[] keyBytes
        67: .line 404
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 17 /* keyBytes */
            aload 16 /* keyAlgo */
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
        68: .line 403
            astore 18 /* secretKeySpec */
        start local 18 // javax.crypto.spec.SecretKeySpec secretKeySpec
        69: .line 407
            aload 16 /* keyAlgo */
            ldc "PBE"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 76
        70: .line 409
            aload 16 /* keyAlgo */
            invokestatic javax.crypto.SecretKeyFactory.getInstance:(Ljava/lang/String;)Ljavax/crypto/SecretKeyFactory;
        71: .line 408
            astore 19 /* sKeyFactory */
        start local 19 // javax.crypto.SecretKeyFactory sKeyFactory
        72: .line 411
            aload 19 /* sKeyFactory */
            aload 18 /* secretKeySpec */
            ldc Ljavax/crypto/spec/PBEKeySpec;
            invokevirtual javax.crypto.SecretKeyFactory.getKeySpec:(Ljavax/crypto/SecretKey;Ljava/lang/Class;)Ljava/security/spec/KeySpec;
        73: .line 410
            astore 20 /* pbeKeySpec */
        start local 20 // java.security.spec.KeySpec pbeKeySpec
        74: .line 412
            aload 19 /* sKeyFactory */
            aload 20 /* pbeKeySpec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            astore 4 /* key */
        end local 20 // java.security.spec.KeySpec pbeKeySpec
        end local 19 // javax.crypto.SecretKeyFactory sKeyFactory
        75: .line 413
            goto 77
        76: .line 414
      StackMap locals: byte[] javax.crypto.spec.SecretKeySpec
      StackMap stack:
            aload 18 /* secretKeySpec */
            astore 4 /* key */
        77: .line 417
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 91
        78: .line 418
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Retrieved a protected secret key at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        79: .line 419
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "' ("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        80: .line 420
            new sun.security.x509.AlgorithmId
            dup
            aload 8 /* algOid */
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;)V
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        81: .line 421
            ldc " iterations: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 10 /* ic */
            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;
        82: .line 418
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 18 // javax.crypto.spec.SecretKeySpec secretKeySpec
        end local 17 // byte[] keyBytes
        end local 16 // java.lang.String keyAlgo
        end local 15 // sun.security.x509.AlgorithmId algId
        end local 14 // sun.security.util.DerValue[] value
        end local 13 // sun.security.util.DerInputStream in
        end local 12 // sun.security.util.DerValue val
        end local 11 // byte[] keyInfo
        end local 10 // int ic
        83: .line 424
            goto 91
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String char[] sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key byte[] byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier
      StackMap stack: java.lang.Exception
        84: astore 9 /* e */
        start local 9 // java.lang.Exception e
        85: .line 426
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Get Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        86: .line 427
            aload 9 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        87: .line 426
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        88: .line 425
            astore 10 /* uke */
        start local 10 // java.security.UnrecoverableKeyException uke
        89: .line 428
            aload 10 /* uke */
            aload 9 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        90: .line 429
            aload 10 /* uke */
            athrow
        end local 10 // java.security.UnrecoverableKeyException uke
        end local 9 // java.lang.Exception e
        91: .line 431
      StackMap locals:
      StackMap stack:
            aload 4 /* key */
            areturn
        end local 8 // sun.security.util.ObjectIdentifier algOid
        end local 7 // java.security.AlgorithmParameters algParams
        end local 6 // byte[] encryptedKey
        end local 5 // byte[] encrBytes
        end local 4 // java.security.Key key
        end local 3 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 2 // char[] password
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   92     0           this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   92     1          alias  Ljava/lang/String;
            0   92     2       password  [C
            1   92     3          entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            2   92     4            key  Ljava/security/Key;
            5   92     5      encrBytes  [B
           15   20     6   encryptedKey  [B
           27   92     6   encryptedKey  [B
           19   20     7      algParams  Ljava/security/AlgorithmParameters;
           27   92     7      algParams  Ljava/security/AlgorithmParameters;
           18   20     8         algOid  Lsun/security/util/ObjectIdentifier;
           27   92     8         algOid  Lsun/security/util/ObjectIdentifier;
           14   19     9       encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           16   19    10            val  Lsun/security/util/DerValue;
           17   19    11             in  Lsun/security/util/DerInputStream;
           21   27     9            ioe  Ljava/io/IOException;
           25   27    10            uke  Ljava/security/UnrecoverableKeyException;
           31   32     9        pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           34   37     9        pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           28   83    10             ic  I
           41   42    11        keyInfo  [B
           47   83    11        keyInfo  [B
           38   42    12           skey  Ljavax/crypto/SecretKey;
           39   42    13         cipher  Ljavax/crypto/Cipher;
           43   47    12              e  Ljava/lang/Exception;
           48   83    12            val  Lsun/security/util/DerValue;
           49   83    13             in  Lsun/security/util/DerInputStream;
           51   83    14          value  [Lsun/security/util/DerValue;
           54   83    15          algId  Lsun/security/x509/AlgorithmId;
           55   83    16        keyAlgo  Ljava/lang/String;
           57   65    17           kfac  Ljava/security/KeyFactory;
           58   65    18          kspec  Ljava/security/spec/PKCS8EncodedKeySpec;
           67   83    17       keyBytes  [B
           69   83    18  secretKeySpec  Ljavax/crypto/spec/SecretKeySpec;
           72   75    19    sKeyFactory  Ljavax/crypto/SecretKeyFactory;
           74   75    20     pbeKeySpec  Ljava/security/spec/KeySpec;
           85   91     9              e  Ljava/lang/Exception;
           89   91    10            uke  Ljava/security/UnrecoverableKeyException;
      Exception table:
        from    to  target  type
          12    19      20  Class java.io.IOException
          29    31      32  Class java.security.spec.InvalidParameterSpecException
          37    41      42  Class java.lang.Exception
          27    83      84  Class java.lang.Exception
    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=4, locals=3, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
         0: .line 446
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 2 /* entry */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         1: .line 447
            aload 2 /* entry */
            ifnull 10
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 10
         2: .line 448
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 4
         3: .line 449
            aconst_null
            areturn
         4: .line 452
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 9
         5: .line 453
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Retrieved a "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 454
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         7: .line 455
            ldc "-certificate chain at alias '"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 453
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         9: .line 458
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            areturn
        10: .line 461
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   11     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   11     1  alias  Ljava/lang/String;
            1   11     2  entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
    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=4, locals=3, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
         0: .line 481
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 2 /* entry */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         1: .line 482
            aload 2 /* entry */
            ifnonnull 3
         2: .line 483
            aconst_null
            areturn
         3: .line 485
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 18
         4: .line 486
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 18
         5: .line 488
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 17
         6: .line 489
            getstatic sun.security.pkcs12.PKCS12KeyStore.AnyUsage:[Lsun/security/util/ObjectIdentifier;
         7: .line 490
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
         8: .line 489
            invokestatic java.util.Arrays.equals:([Ljava/lang/Object;[Ljava/lang/Object;)Z
         9: .line 490
            ifeq 14
        10: .line 491
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Retrieved a certificate at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        11: .line 492
            ldc "' (trusted for any purpose)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 491
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 493
            goto 17
        14: .line 494
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Retrieved a certificate at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        15: .line 495
            ldc "' (trusted for limited purposes)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 494
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        17: .line 499
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
        18: .line 501
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 26
        19: .line 502
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 21
        20: .line 503
            aconst_null
            areturn
        21: .line 506
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 25
        22: .line 507
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Retrieved a certificate at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        23: .line 508
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        24: .line 507
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        25: .line 511
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aaload
            areturn
        26: .line 515
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   27     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   27     1  alias  Ljava/lang/String;
            1   27     2  entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
    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.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
         0: .line 528
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 2 /* entry */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         1: .line 529
            aload 2 /* entry */
            ifnull 3
         2: .line 530
            new java.util.Date
            dup
            aload 2 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokespecial java.util.Date.<init>:(J)V
            areturn
         3: .line 532
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            aconst_null
            areturn
        end local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
    MethodParameters:
       Name  Flags
      alias  

  public synchronized 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: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // sun.security.pkcs12.PKCS12KeyStore 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 562
            aload 0 /* this */
            aload 1 /* alias */
            aload 2 /* key */
            aload 3 /* password */
            aload 4 /* chain */
            aconst_null
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setKeyEntry:(Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;Ljava/util/Set;)V
         1: .line 563
            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.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    2     1     alias  Ljava/lang/String;
            0    2     2       key  Ljava/security/Key;
            0    2     3  password  [C
            0    2     4     chain  [Ljava/security/cert/Certificate;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
          Name  Flags
      alias     
      key       
      password  
      chain     

  private void setKeyEntry(java.lang.String, java.security.Key, char[], java.security.cert.Certificate[], java.util.Set<sun.security.pkcs12.PKCS12Attribute>);
    descriptor: (Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;Ljava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=11, args_size=6
        start local 0 // sun.security.pkcs12.PKCS12KeyStore 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
        start local 5 // java.util.Set attributes
         0: .line 576
            aload 2 /* key */
            instanceof java.security.PrivateKey
            ifeq 28
         1: .line 577
            new sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.<init>:()V
            astore 7 /* keyEntry */
        start local 7 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         2: .line 578
            aload 7 /* keyEntry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.date:Ljava/util/Date;
         3: .line 580
            aload 2 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            ldc "PKCS#8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 5
         4: .line 581
            aload 2 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            ldc "PKCS8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 15
         5: .line 583
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.util.Set top sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 11
         6: .line 584
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
         7: .line 585
            new java.lang.StringBuilder
            dup
            ldc "Setting a protected private key at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 586
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         9: .line 585
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 584
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 590
      StackMap locals:
      StackMap stack:
            aload 7 /* keyEntry */
        12: .line 591
            aload 0 /* this */
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            aload 3 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.encryptPrivateKey:([B[C)[B
        13: .line 590
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        14: .line 592
            goto 16
        15: .line 593
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
            ldc "Private key is not encodedas PKCS#8"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        16: .line 598
      StackMap locals:
      StackMap stack:
            aload 4 /* chain */
            ifnull 25
        17: .line 600
            aload 4 /* chain */
            arraylength
            iconst_1
            if_icmple 19
            aload 0 /* this */
            aload 4 /* chain */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.validateChain:([Ljava/security/cert/Certificate;)Z
            ifne 19
        18: .line 601
            new java.security.KeyStoreException
            dup
            ldc "Certificate chain is not valid"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 603
      StackMap locals:
      StackMap stack:
            aload 7 /* keyEntry */
            aload 4 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
        20: .line 604
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            aload 4 /* chain */
            arraylength
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        21: .line 606
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 25
        22: .line 607
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Setting a "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* chain */
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        23: .line 608
            ldc "-certificate chain at alias '"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        24: .line 607
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        25: .line 611
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        26: .line 612
            aload 7 /* keyEntry */
            astore 6 /* entry */
        end local 7 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
        start local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        27: .line 614
            goto 49
        end local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.util.Set
      StackMap stack:
        28: aload 2 /* key */
            instanceof javax.crypto.SecretKey
            ifeq 48
        29: .line 615
            new sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.<init>:()V
            astore 7 /* keyEntry */
        start local 7 // sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry keyEntry
        30: .line 616
            aload 7 /* keyEntry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.date:Ljava/util/Date;
        31: .line 619
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 8 /* pkcs8 */
        start local 8 // sun.security.util.DerOutputStream pkcs8
        32: .line 620
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* secretKeyInfo */
        start local 9 // sun.security.util.DerOutputStream secretKeyInfo
        33: .line 621
            aload 9 /* secretKeyInfo */
            iconst_0
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        34: .line 622
            aload 2 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            invokestatic sun.security.x509.AlgorithmId.get:(Ljava/lang/String;)Lsun/security/x509/AlgorithmId;
            astore 10 /* algId */
        start local 10 // sun.security.x509.AlgorithmId algId
        35: .line 623
            aload 10 /* algId */
            aload 9 /* secretKeyInfo */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
        36: .line 624
            aload 9 /* secretKeyInfo */
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        37: .line 625
            aload 8 /* pkcs8 */
            bipush 48
            aload 9 /* secretKeyInfo */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        38: .line 628
            aload 7 /* keyEntry */
        39: .line 629
            aload 0 /* this */
            aload 8 /* pkcs8 */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            aload 3 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.encryptPrivateKey:([B[C)[B
        40: .line 628
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        41: .line 631
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 45
        42: .line 632
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Setting a protected secret key at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        43: .line 633
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        44: .line 632
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        45: .line 635
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.util.Set top sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.x509.AlgorithmId
      StackMap stack:
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        46: .line 636
            aload 7 /* keyEntry */
            astore 6 /* entry */
        end local 10 // sun.security.x509.AlgorithmId algId
        end local 9 // sun.security.util.DerOutputStream secretKeyInfo
        end local 8 // sun.security.util.DerOutputStream pkcs8
        end local 7 // sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry keyEntry
        start local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        47: .line 638
            goto 49
        end local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        48: .line 639
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.util.Set
      StackMap stack:
            new java.security.KeyStoreException
            dup
            ldc "Unsupported Key type"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        start local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        49: .line 642
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            aload 6 /* entry */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
        50: .line 643
            aload 5 /* attributes */
            ifnull 52
        51: .line 644
            aload 6 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            aload 5 /* attributes */
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
        52: .line 647
      StackMap locals:
      StackMap stack:
            aload 6 /* entry */
            new java.lang.StringBuilder
            dup
            ldc "Time "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            putfield sun.security.pkcs12.PKCS12KeyStore$Entry.keyId:[B
        53: .line 649
            aload 6 /* entry */
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            putfield sun.security.pkcs12.PKCS12KeyStore$Entry.alias:Ljava/lang/String;
        54: .line 651
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            aload 6 /* entry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        55: .line 653
            goto 60
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.util.Set
      StackMap stack: java.lang.Exception
        56: astore 6 /* nsae */
        start local 6 // java.lang.Exception nsae
        57: .line 654
            new java.security.KeyStoreException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Key protection  algorithm not found: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        58: .line 655
            aload 6 /* nsae */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 6 /* nsae */
        59: .line 654
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.lang.Exception nsae
        60: .line 657
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.util.Set attributes
        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.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   61     0           this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   61     1          alias  Ljava/lang/String;
            0   61     2            key  Ljava/security/Key;
            0   61     3       password  [C
            0   61     4          chain  [Ljava/security/cert/Certificate;
            0   61     5     attributes  Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;
           27   28     6          entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
           47   48     6          entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
           49   55     6          entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            2   27     7       keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
           30   47     7       keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$SecretKeyEntry;
           32   47     8          pkcs8  Lsun/security/util/DerOutputStream;
           33   47     9  secretKeyInfo  Lsun/security/util/DerOutputStream;
           35   47    10          algId  Lsun/security/x509/AlgorithmId;
           57   60     6           nsae  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0    55      56  Class java.lang.Exception
    Exceptions:
      throws java.security.KeyStoreException
    Signature: (Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;)V
    MethodParameters:
            Name  Flags
      alias       
      key         
      password    
      chain       
      attributes  

  public synchronized void engineSetKeyEntry(java.lang.String, byte[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;[B[Ljava/security/cert/Certificate;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // byte[] key
        start local 3 // java.security.cert.Certificate[] chain
         0: .line 689
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            aload 2 /* key */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
         1: .line 690
            goto 6
      StackMap locals:
      StackMap stack: java.io.IOException
         2: astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
         3: .line 691
            new java.security.KeyStoreException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Private key is not stored as PKCS#8 EncryptedPrivateKeyInfo: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         4: .line 692
            aload 4 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* ioe */
         5: .line 691
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.io.IOException ioe
         6: .line 695
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.<init>:()V
            astore 4 /* entry */
        start local 4 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
         7: .line 696
            aload 4 /* entry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.date:Ljava/util/Date;
         8: .line 698
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 12
         9: .line 699
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Setting a protected private key at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        10: .line 700
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 699
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 705
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
      StackMap stack:
            aload 4 /* entry */
            new java.lang.StringBuilder
            dup
            ldc "Time "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.date:Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.keyId:[B
        13: .line 706
            goto 15
      StackMap locals:
      StackMap stack: java.io.UnsupportedEncodingException
        14: pop
        15: .line 710
      StackMap locals:
      StackMap stack:
            aload 4 /* entry */
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.alias:Ljava/lang/String;
        16: .line 712
            aload 4 /* entry */
            aload 2 /* key */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        17: .line 713
            aload 3 /* chain */
            ifnull 26
        18: .line 715
            aload 3 /* chain */
            arraylength
            iconst_1
            if_icmple 20
            aload 0 /* this */
            aload 3 /* chain */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.validateChain:([Ljava/security/cert/Certificate;)Z
            ifne 20
        19: .line 716
            new java.security.KeyStoreException
            dup
            ldc "Certificate chain is not valid"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 719
      StackMap locals:
      StackMap stack:
            aload 4 /* entry */
            aload 3 /* chain */
            invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
        21: .line 720
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            aload 3 /* chain */
            arraylength
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        22: .line 722
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 26
        23: .line 723
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Setting a "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        24: .line 724
            ldc "-certificate chain at alias '"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        25: .line 723
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        26: .line 729
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        27: .line 730
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            aload 4 /* entry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        28: .line 731
            return
        end local 4 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
        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.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   29     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   29     1  alias  Ljava/lang/String;
            0   29     2    key  [B
            0   29     3  chain  [Ljava/security/cert/Certificate;
            3    6     4    ioe  Ljava/io/IOException;
            7   29     4  entry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
      Exception table:
        from    to  target  type
           0     1       2  Class java.io.IOException
          12    13      14  Class java.io.UnsupportedEncodingException
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      key    
      chain  

  private byte[] getSalt();
    descriptor: ()[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
         0: .line 740
            bipush 20
            newarray 8
            astore 1 /* salt */
        start local 1 // byte[] salt
         1: .line 741
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.random:Ljava/security/SecureRandom;
            ifnonnull 3
         2: .line 742
            aload 0 /* this */
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.random:Ljava/security/SecureRandom;
         3: .line 744
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.random:Ljava/security/SecureRandom;
            aload 1 /* salt */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         4: .line 745
            aload 1 /* salt */
            areturn
        end local 1 // byte[] salt
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/pkcs12/PKCS12KeyStore;
            1    5     1  salt  [B

  private java.security.AlgorithmParameters getPBEAlgorithmParameters(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/AlgorithmParameters;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String algorithm
         0: .line 754
            aconst_null
            astore 2 /* algParams */
        start local 2 // java.security.AlgorithmParameters algParams
         1: .line 758
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getSalt:()[B
            ldc 50000
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
         2: .line 757
            astore 3 /* paramSpec */
        start local 3 // javax.crypto.spec.PBEParameterSpec paramSpec
         3: .line 760
            aload 1 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 2 /* algParams */
         4: .line 761
            aload 2 /* algParams */
            aload 3 /* paramSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         5: .line 762
            goto 10
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.AlgorithmParameters javax.crypto.spec.PBEParameterSpec
      StackMap stack: java.lang.Exception
         6: astore 4 /* e */
        start local 4 // java.lang.Exception e
         7: .line 763
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getPBEAlgorithmParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 764
            aload 4 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* e */
         9: .line 763
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Exception e
        10: .line 766
      StackMap locals:
      StackMap stack:
            aload 2 /* algParams */
            areturn
        end local 3 // javax.crypto.spec.PBEParameterSpec paramSpec
        end local 2 // java.security.AlgorithmParameters algParams
        end local 1 // java.lang.String algorithm
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   11     1  algorithm  Ljava/lang/String;
            1   11     2  algParams  Ljava/security/AlgorithmParameters;
            3   11     3  paramSpec  Ljavax/crypto/spec/PBEParameterSpec;
            7   10     4          e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           3     5       6  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
           Name  Flags
      algorithm  

  private java.security.AlgorithmParameters parseAlgParameters(sun.security.util.DerInputStream);
    descriptor: (Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // sun.security.util.DerInputStream in
         0: .line 775
            aconst_null
            astore 2 /* algParams */
        start local 2 // java.security.AlgorithmParameters algParams
         1: .line 778
            aload 1 /* in */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifne 4
         2: .line 779
            aconst_null
            astore 3 /* params */
        start local 3 // sun.security.util.DerValue params
         3: .line 780
            goto 7
        end local 3 // sun.security.util.DerValue params
         4: .line 781
      StackMap locals: java.security.AlgorithmParameters
      StackMap stack:
            aload 1 /* in */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* params */
        start local 3 // sun.security.util.DerValue params
         5: .line 782
            aload 3 /* params */
            getfield sun.security.util.DerValue.tag:B
            iconst_5
            if_icmpne 7
         6: .line 783
            aconst_null
            astore 3 /* params */
         7: .line 786
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 3 /* params */
            ifnull 15
         8: .line 787
            ldc "PBE"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 2 /* algParams */
         9: .line 788
            aload 2 /* algParams */
            aload 3 /* params */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokevirtual java.security.AlgorithmParameters.init:([B)V
        end local 3 // sun.security.util.DerValue params
        10: .line 790
            goto 15
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream java.security.AlgorithmParameters
      StackMap stack: java.lang.Exception
        11: astore 3 /* e */
        start local 3 // java.lang.Exception e
        12: .line 791
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "parseAlgParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        13: .line 792
            aload 3 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 3 /* e */
        14: .line 791
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        15: .line 794
      StackMap locals:
      StackMap stack:
            aload 2 /* algParams */
            areturn
        end local 2 // java.security.AlgorithmParameters algParams
        end local 1 // sun.security.util.DerInputStream in
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   16     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   16     1         in  Lsun/security/util/DerInputStream;
            1   16     2  algParams  Ljava/security/AlgorithmParameters;
            3    4     3     params  Lsun/security/util/DerValue;
            5   10     3     params  Lsun/security/util/DerValue;
           12   15     3          e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    10      11  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      in    

  private javax.crypto.SecretKey getPBEKey(char[]);
    descriptor: ([C)Ljavax/crypto/SecretKey;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // char[] password
         0: .line 802
            aconst_null
            astore 2 /* skey */
        start local 2 // javax.crypto.SecretKey skey
         1: .line 805
            new javax.crypto.spec.PBEKeySpec
            dup
            aload 1 /* password */
            invokespecial javax.crypto.spec.PBEKeySpec.<init>:([C)V
            astore 3 /* keySpec */
        start local 3 // javax.crypto.spec.PBEKeySpec keySpec
         2: .line 806
            ldc "PBE"
            invokestatic javax.crypto.SecretKeyFactory.getInstance:(Ljava/lang/String;)Ljavax/crypto/SecretKeyFactory;
            astore 4 /* skFac */
        start local 4 // javax.crypto.SecretKeyFactory skFac
         3: .line 807
            aload 4 /* skFac */
            aload 3 /* keySpec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            astore 2 /* skey */
         4: .line 808
            aload 3 /* keySpec */
            invokevirtual javax.crypto.spec.PBEKeySpec.clearPassword:()V
        end local 4 // javax.crypto.SecretKeyFactory skFac
        end local 3 // javax.crypto.spec.PBEKeySpec keySpec
         5: .line 809
            goto 10
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] javax.crypto.SecretKey
      StackMap stack: java.lang.Exception
         6: astore 3 /* e */
        start local 3 // java.lang.Exception e
         7: .line 810
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getSecretKey failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 811
            aload 3 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 3 /* e */
         9: .line 810
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        10: .line 813
      StackMap locals:
      StackMap stack:
            aload 2 /* skey */
            areturn
        end local 2 // javax.crypto.SecretKey skey
        end local 1 // char[] password
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   11     1  password  [C
            1   11     2      skey  Ljavax/crypto/SecretKey;
            2    5     3   keySpec  Ljavax/crypto/spec/PBEKeySpec;
            3    5     4     skFac  Ljavax/crypto/SecretKeyFactory;
            7   10     3         e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     5       6  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
          Name  Flags
      password  

  private byte[] encryptPrivateKey(byte[], char[]);
    descriptor: ([B[C)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=10, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // byte[] data
        start local 2 // char[] password
         0: .line 828
            aconst_null
            astore 3 /* key */
        start local 3 // byte[] key
         1: .line 833
            aload 0 /* this */
            ldc "PBEWithSHA1AndDESede"
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
         2: .line 832
            astore 4 /* algParams */
        start local 4 // java.security.AlgorithmParameters algParams
         3: .line 836
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 5 /* skey */
        start local 5 // javax.crypto.SecretKey skey
         4: .line 837
            ldc "PBEWithSHA1AndDESede"
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 6 /* cipher */
        start local 6 // javax.crypto.Cipher cipher
         5: .line 838
            aload 6 /* cipher */
            iconst_1
            aload 5 /* skey */
            aload 4 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
         6: .line 839
            aload 6 /* cipher */
            aload 1 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 7 /* encryptedKey */
        start local 7 // byte[] encryptedKey
         7: .line 841
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 11
         8: .line 842
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  (Cipher algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* cipher */
            invokevirtual javax.crypto.Cipher.getAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         9: .line 843
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        10: .line 842
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 849
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] char[] byte[] java.security.AlgorithmParameters javax.crypto.SecretKey javax.crypto.Cipher byte[]
      StackMap stack:
            new sun.security.x509.AlgorithmId
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd3KeyTripleDESCBC_OID:Lsun/security/util/ObjectIdentifier;
            aload 4 /* algParams */
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)V
        12: .line 848
            astore 8 /* algid */
        start local 8 // sun.security.x509.AlgorithmId algid
        13: .line 851
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 8 /* algid */
            aload 7 /* encryptedKey */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:(Lsun/security/x509/AlgorithmId;[B)V
        14: .line 850
            astore 9 /* encrInfo */
        start local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        15: .line 852
            aload 9 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncoded:()[B
            astore 3 /* key */
        end local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        end local 8 // sun.security.x509.AlgorithmId algid
        end local 7 // byte[] encryptedKey
        end local 6 // javax.crypto.Cipher cipher
        end local 5 // javax.crypto.SecretKey skey
        end local 4 // java.security.AlgorithmParameters algParams
        16: .line 853
            goto 24
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] char[] byte[]
      StackMap stack: java.lang.Exception
        17: astore 4 /* e */
        start local 4 // java.lang.Exception e
        18: .line 855
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Encrypt Private Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        19: .line 856
            aload 4 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 855
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        21: .line 854
            astore 5 /* uke */
        start local 5 // java.security.UnrecoverableKeyException uke
        22: .line 857
            aload 5 /* uke */
            aload 4 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        23: .line 858
            aload 5 /* uke */
            athrow
        end local 5 // java.security.UnrecoverableKeyException uke
        end local 4 // java.lang.Exception e
        24: .line 861
      StackMap locals:
      StackMap stack:
            aload 3 /* key */
            areturn
        end local 3 // byte[] key
        end local 2 // char[] password
        end local 1 // byte[] data
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   25     0          this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   25     1          data  [B
            0   25     2      password  [C
            1   25     3           key  [B
            3   16     4     algParams  Ljava/security/AlgorithmParameters;
            4   16     5          skey  Ljavax/crypto/SecretKey;
            5   16     6        cipher  Ljavax/crypto/Cipher;
            7   16     7  encryptedKey  [B
           13   16     8         algid  Lsun/security/x509/AlgorithmId;
           15   16     9      encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           18   24     4             e  Ljava/lang/Exception;
           22   24     5           uke  Ljava/security/UnrecoverableKeyException;
      Exception table:
        from    to  target  type
           1    16      17  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
          Name  Flags
      data      
      password  

  public synchronized void engineSetCertificateEntry(java.lang.String, java.security.cert.Certificate);
    descriptor: (Ljava/lang/String;Ljava/security/cert/Certificate;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.cert.Certificate cert
         0: .line 881
            aload 0 /* this */
            aload 1 /* alias */
            aload 2 /* cert */
            aconst_null
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setCertEntry:(Ljava/lang/String;Ljava/security/cert/Certificate;Ljava/util/Set;)V
         1: .line 882
            return
        end local 2 // java.security.cert.Certificate cert
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    2     1  alias  Ljava/lang/String;
            0    2     2   cert  Ljava/security/cert/Certificate;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      cert   

  private void setCertEntry(java.lang.String, java.security.cert.Certificate, java.util.Set<sun.security.pkcs12.PKCS12Attribute>);
    descriptor: (Ljava/lang/String;Ljava/security/cert/Certificate;Ljava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=6, args_size=4
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.cert.Certificate cert
        start local 3 // java.util.Set attributes
         0: .line 890
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 4 /* entry */
        start local 4 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         1: .line 891
            aload 4 /* entry */
            ifnull 3
            aload 4 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 3
         2: .line 892
            new java.security.KeyStoreException
            dup
            ldc "Cannot overwrite own certificate"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 896
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            new sun.security.pkcs12.PKCS12KeyStore$CertEntry
            dup
            aload 2 /* cert */
            checkcast java.security.cert.X509Certificate
            aconst_null
            aload 1 /* alias */
            getstatic sun.security.pkcs12.PKCS12KeyStore.AnyUsage:[Lsun/security/util/ObjectIdentifier;
         4: .line 897
            aload 3 /* attributes */
         5: .line 896
            invokespecial sun.security.pkcs12.PKCS12KeyStore$CertEntry.<init>:(Ljava/security/cert/X509Certificate;[BLjava/lang/String;[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)V
         6: .line 895
            astore 5 /* certEntry */
        start local 5 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
         7: .line 898
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
         8: .line 899
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            aload 5 /* certEntry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         9: .line 901
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 13
        10: .line 902
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Setting a trusted certificate at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        11: .line 903
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 902
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 905
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$CertEntry
      StackMap stack:
            return
        end local 5 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
        end local 4 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 3 // java.util.Set attributes
        end local 2 // java.security.cert.Certificate cert
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0        this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   14     1       alias  Ljava/lang/String;
            0   14     2        cert  Ljava/security/cert/Certificate;
            0   14     3  attributes  Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;
            1   14     4       entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            7   14     5   certEntry  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
    Exceptions:
      throws java.security.KeyStoreException
    Signature: (Ljava/lang/String;Ljava/security/cert/Certificate;Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;)V
    MethodParameters:
            Name  Flags
      alias       
      cert        
      attributes  

  public synchronized void engineDeleteEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
         0: .line 917
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 918
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Removing entry at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         2: .line 921
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 2 /* entry */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         3: .line 922
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 9
         4: .line 923
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            astore 3 /* keyEntry */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         5: .line 924
            aload 3 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 7
         6: .line 925
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            aload 3 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            arraylength
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
         7: .line 927
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
      StackMap stack:
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        end local 3 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         8: .line 928
            goto 14
      StackMap locals:
      StackMap stack:
         9: aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 12
        10: .line 929
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        11: .line 930
            goto 14
      StackMap locals:
      StackMap stack:
        12: aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 14
        13: .line 931
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            iconst_1
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        14: .line 933
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        15: .line 934
            return
        end local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   16     0      this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   16     1     alias  Ljava/lang/String;
            3   16     2     entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            5    8     3  keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
    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.pkcs12.PKCS12KeyStore this
         0: .line 942
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokestatic java.util.Collections.enumeration:(Ljava/util/Collection;)Ljava/util/Enumeration;
            areturn
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/pkcs12/PKCS12KeyStore;
    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.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
         0: .line 953
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            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.pkcs12.PKCS12KeyStore this
         0: .line 962
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            invokeinterface java.util.Map.size:()I
            ireturn
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/pkcs12/PKCS12KeyStore;

  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.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
         0: .line 973
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 2 /* entry */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         1: .line 974
            aload 2 /* entry */
            ifnull 3
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 3
         2: .line 975
            iconst_1
            ireturn
         3: .line 977
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
    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.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
         0: .line 989
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 2 /* entry */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         1: .line 990
            aload 2 /* entry */
            ifnull 4
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 4
         2: .line 991
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 4
         3: .line 992
            iconst_1
            ireturn
         4: .line 994
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    5     1  alias  Ljava/lang/String;
            1    5     2  entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
    MethodParameters:
       Name  Flags
      alias  

  public boolean engineEntryInstanceOf(java.lang.String, java.lang.Class<? extends java.security.KeyStore$Entry>);
    descriptor: (Ljava/lang/String;Ljava/lang/Class;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.lang.Class entryClass
         0: .line 1017
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$TrustedCertificateEntry;
            if_acmpne 2
         1: .line 1018
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ireturn
         2: .line 1021
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 3 /* entry */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         3: .line 1022
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$PrivateKeyEntry;
            if_acmpne 6
         4: .line 1023
            aload 3 /* entry */
            ifnull 5
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 5
            iconst_1
            ireturn
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
         5: iconst_0
            ireturn
         6: .line 1025
      StackMap locals:
      StackMap stack:
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$SecretKeyEntry;
            if_acmpne 9
         7: .line 1026
            aload 3 /* entry */
            ifnull 8
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 8
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         8: iconst_0
            ireturn
         9: .line 1028
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 3 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 2 // java.lang.Class entryClass
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0        this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   10     1       alias  Ljava/lang/String;
            0   10     2  entryClass  Ljava/lang/Class<+Ljava/security/KeyStore$Entry;>;
            3   10     3       entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
    Signature: (Ljava/lang/String;Ljava/lang/Class<+Ljava/security/KeyStore$Entry;>;)Z
    MethodParameters:
            Name  Flags
      alias       
      entryClass  

  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.pkcs12.PKCS12KeyStore this
        start local 1 // java.security.cert.Certificate cert
         0: .line 1048
            aconst_null
            astore 2 /* certElem */
        start local 2 // java.security.cert.Certificate certElem
         1: .line 1050
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineAliases:()Ljava/util/Enumeration;
            astore 3 /* e */
        start local 3 // java.util.Enumeration e
         2: goto 14
         3: .line 1051
      StackMap locals: java.security.cert.Certificate 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
         4: .line 1052
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 4 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 5 /* entry */
        start local 5 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         5: .line 1053
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 9
         6: .line 1054
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 12
         7: .line 1055
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            iconst_0
            aaload
            astore 2 /* certElem */
         8: .line 1057
            goto 12
      StackMap locals: java.lang.String sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
         9: aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 14
        10: .line 1058
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 14
        11: .line 1059
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            astore 2 /* certElem */
        12: .line 1063
      StackMap locals:
      StackMap stack:
            aload 2 /* certElem */
            ifnull 14
            aload 2 /* certElem */
            aload 1 /* cert */
            invokevirtual java.security.cert.Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 14
        13: .line 1064
            aload 4 /* alias */
            areturn
        end local 5 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 4 // java.lang.String alias
        14: .line 1050
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        end local 3 // java.util.Enumeration e
        15: .line 1067
            aconst_null
            areturn
        end local 2 // java.security.cert.Certificate certElem
        end local 1 // java.security.cert.Certificate cert
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   16     0      this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   16     1      cert  Ljava/security/cert/Certificate;
            1   16     2  certElem  Ljava/security/cert/Certificate;
            2   15     3         e  Ljava/util/Enumeration<Ljava/lang/String;>;
            4   14     4     alias  Ljava/lang/String;
            5   14     5     entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
    MethodParameters:
      Name  Flags
      cert  

  public synchronized void engineStore(java.io.OutputStream, char[]);
    descriptor: (Ljava/io/OutputStream;[C)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=6, locals=15, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.io.OutputStream stream
        start local 2 // char[] password
         0: .line 1087
            aload 2 /* password */
            ifnonnull 2
         1: .line 1088
            new java.lang.IllegalArgumentException
            dup
            ldc "password can't be null"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 1092
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* pfx */
        start local 3 // sun.security.util.DerOutputStream pfx
         3: .line 1095
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 4 /* version */
        start local 4 // sun.security.util.DerOutputStream version
         4: .line 1096
            aload 4 /* version */
            iconst_3
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
         5: .line 1097
            aload 4 /* version */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 5 /* pfxVersion */
        start local 5 // byte[] pfxVersion
         6: .line 1098
            aload 3 /* pfx */
            aload 5 /* pfxVersion */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
         7: .line 1101
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 6 /* authSafe */
        start local 6 // sun.security.util.DerOutputStream authSafe
         8: .line 1104
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 7 /* authSafeContentInfo */
        start local 7 // sun.security.util.DerOutputStream authSafeContentInfo
         9: .line 1107
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            ifgt 10
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            ifle 17
        10: .line 1109
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.OutputStream char[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream byte[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 14
        11: .line 1110
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Storing "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            iadd
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        12: .line 1111
            ldc " protected key(s) in a PKCS#7 data"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 1110
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 1114
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.createSafeContent:()[B
            astore 8 /* safeContentData */
        start local 8 // byte[] safeContentData
        15: .line 1115
            new sun.security.pkcs.ContentInfo
            dup
            aload 8 /* safeContentData */
            invokespecial sun.security.pkcs.ContentInfo.<init>:([B)V
            astore 9 /* dataContentInfo */
        start local 9 // sun.security.pkcs.ContentInfo dataContentInfo
        16: .line 1116
            aload 9 /* dataContentInfo */
            aload 7 /* authSafeContentInfo */
            invokevirtual sun.security.pkcs.ContentInfo.encode:(Lsun/security/util/DerOutputStream;)V
        end local 9 // sun.security.pkcs.ContentInfo dataContentInfo
        end local 8 // byte[] safeContentData
        17: .line 1120
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            ifle 28
        18: .line 1122
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 22
        19: .line 1123
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Storing "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        20: .line 1124
            ldc " certificate(s) in a PKCS#7 encryptedData"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        21: .line 1123
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        22: .line 1127
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.createEncryptedData:([C)[B
            astore 8 /* encrData */
        start local 8 // byte[] encrData
        23: .line 1129
            new sun.security.pkcs.ContentInfo
            dup
            getstatic sun.security.pkcs.ContentInfo.ENCRYPTED_DATA_OID:Lsun/security/util/ObjectIdentifier;
        24: .line 1130
            new sun.security.util.DerValue
            dup
            aload 8 /* encrData */
            invokespecial sun.security.util.DerValue.<init>:([B)V
        25: .line 1129
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/ObjectIdentifier;Lsun/security/util/DerValue;)V
        26: .line 1128
            astore 9 /* encrContentInfo */
        start local 9 // sun.security.pkcs.ContentInfo encrContentInfo
        27: .line 1131
            aload 9 /* encrContentInfo */
            aload 7 /* authSafeContentInfo */
            invokevirtual sun.security.pkcs.ContentInfo.encode:(Lsun/security/util/DerOutputStream;)V
        end local 9 // sun.security.pkcs.ContentInfo encrContentInfo
        end local 8 // byte[] encrData
        28: .line 1135
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 8 /* cInfo */
        start local 8 // sun.security.util.DerOutputStream cInfo
        29: .line 1136
            aload 8 /* cInfo */
            bipush 48
            aload 7 /* authSafeContentInfo */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        30: .line 1137
            aload 8 /* cInfo */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 9 /* authenticatedSafe */
        start local 9 // byte[] authenticatedSafe
        31: .line 1140
            new sun.security.pkcs.ContentInfo
            dup
            aload 9 /* authenticatedSafe */
            invokespecial sun.security.pkcs.ContentInfo.<init>:([B)V
            astore 10 /* contentInfo */
        start local 10 // sun.security.pkcs.ContentInfo contentInfo
        32: .line 1141
            aload 10 /* contentInfo */
            aload 6 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.encode:(Lsun/security/util/DerOutputStream;)V
        33: .line 1142
            aload 6 /* authSafe */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 11 /* authSafeData */
        start local 11 // byte[] authSafeData
        34: .line 1143
            aload 3 /* pfx */
            aload 11 /* authSafeData */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        35: .line 1146
            aload 0 /* this */
            aload 2 /* password */
            aload 9 /* authenticatedSafe */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.calculateMac:([C[B)[B
            astore 12 /* macData */
        start local 12 // byte[] macData
        36: .line 1147
            aload 3 /* pfx */
            aload 12 /* macData */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        37: .line 1150
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 13 /* pfxout */
        start local 13 // sun.security.util.DerOutputStream pfxout
        38: .line 1151
            aload 13 /* pfxout */
            bipush 48
            aload 3 /* pfx */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        39: .line 1152
            aload 13 /* pfxout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 14 /* pfxData */
        start local 14 // byte[] pfxData
        40: .line 1153
            aload 1 /* stream */
            aload 14 /* pfxData */
            invokevirtual java.io.OutputStream.write:([B)V
        41: .line 1154
            aload 1 /* stream */
            invokevirtual java.io.OutputStream.flush:()V
        42: .line 1155
            return
        end local 14 // byte[] pfxData
        end local 13 // sun.security.util.DerOutputStream pfxout
        end local 12 // byte[] macData
        end local 11 // byte[] authSafeData
        end local 10 // sun.security.pkcs.ContentInfo contentInfo
        end local 9 // byte[] authenticatedSafe
        end local 8 // sun.security.util.DerOutputStream cInfo
        end local 7 // sun.security.util.DerOutputStream authSafeContentInfo
        end local 6 // sun.security.util.DerOutputStream authSafe
        end local 5 // byte[] pfxVersion
        end local 4 // sun.security.util.DerOutputStream version
        end local 3 // sun.security.util.DerOutputStream pfx
        end local 2 // char[] password
        end local 1 // java.io.OutputStream stream
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   43     0                 this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   43     1               stream  Ljava/io/OutputStream;
            0   43     2             password  [C
            3   43     3                  pfx  Lsun/security/util/DerOutputStream;
            4   43     4              version  Lsun/security/util/DerOutputStream;
            6   43     5           pfxVersion  [B
            8   43     6             authSafe  Lsun/security/util/DerOutputStream;
            9   43     7  authSafeContentInfo  Lsun/security/util/DerOutputStream;
           15   17     8      safeContentData  [B
           16   17     9      dataContentInfo  Lsun/security/pkcs/ContentInfo;
           23   28     8             encrData  [B
           27   28     9      encrContentInfo  Lsun/security/pkcs/ContentInfo;
           29   43     8                cInfo  Lsun/security/util/DerOutputStream;
           31   43     9    authenticatedSafe  [B
           32   43    10          contentInfo  Lsun/security/pkcs/ContentInfo;
           34   43    11         authSafeData  [B
           36   43    12              macData  [B
           38   43    13               pfxout  Lsun/security/util/DerOutputStream;
           40   43    14              pfxData  [B
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  public java.security.KeyStore$Entry engineGetEntry(java.lang.String, java.security.KeyStore$ProtectionParameter);
    descriptor: (Ljava/lang/String;Ljava/security/KeyStore$ProtectionParameter;)Ljava/security/KeyStore$Entry;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=9, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.KeyStore$ProtectionParameter protParam
         0: .line 1188
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineContainsAlias:(Ljava/lang/String;)Z
            ifne 2
         1: .line 1189
            aconst_null
            areturn
         2: .line 1192
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 1 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 3 /* entry */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         3: .line 1193
            invokestatic sun.misc.SharedSecrets.getJavaSecurityKeyStoreAccess:()Lsun/misc/JavaSecurityKeyStoreAccess;
            astore 4 /* jsksa */
        start local 4 // sun.misc.JavaSecurityKeyStoreAccess jsksa
         4: .line 1194
            aload 2 /* protParam */
            ifnonnull 18
         5: .line 1195
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 15
         6: .line 1196
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 18
         7: .line 1197
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 18
         8: .line 1199
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 12
         9: .line 1200
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Retrieved a trusted certificate at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        10: .line 1201
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 1200
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 1204
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry sun.misc.JavaSecurityKeyStoreAccess
      StackMap stack:
            aload 4 /* jsksa */
        13: .line 1205
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            aload 0 /* this */
            aload 3 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getAttributes:(Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
        14: .line 1204
            invokeinterface sun.misc.JavaSecurityKeyStoreAccess.constructTrustedCertificateEntry:(Ljava/security/cert/Certificate;Ljava/util/Set;)Ljava/security/KeyStore$TrustedCertificateEntry;
            areturn
        15: .line 1208
      StackMap locals:
      StackMap stack:
            new java.security.UnrecoverableKeyException
            dup
        16: .line 1209
            ldc "requested entry requires a password"
        17: .line 1208
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 1213
      StackMap locals:
      StackMap stack:
            aload 2 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifeq 41
        19: .line 1214
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 23
        20: .line 1215
            new java.lang.UnsupportedOperationException
            dup
        21: .line 1216
            ldc "trusted certificate entries are not password-protected"
        22: .line 1215
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        23: .line 1217
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifeq 37
        24: .line 1219
            aload 2 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
        25: .line 1218
            astore 5 /* pp */
        start local 5 // java.security.KeyStore$PasswordProtection pp
        26: .line 1220
            aload 5 /* pp */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            astore 6 /* password */
        start local 6 // char[] password
        27: .line 1222
            aload 0 /* this */
            aload 1 /* alias */
            aload 6 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineGetKey:(Ljava/lang/String;[C)Ljava/security/Key;
            astore 7 /* key */
        start local 7 // java.security.Key key
        28: .line 1223
            aload 7 /* key */
            instanceof java.security.PrivateKey
            ifeq 33
        29: .line 1224
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineGetCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/Certificate;
            astore 8 /* chain */
        start local 8 // java.security.cert.Certificate[] chain
        30: .line 1226
            aload 4 /* jsksa */
            aload 7 /* key */
            checkcast java.security.PrivateKey
            aload 8 /* chain */
        31: .line 1227
            aload 0 /* this */
            aload 3 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getAttributes:(Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
        32: .line 1226
            invokeinterface sun.misc.JavaSecurityKeyStoreAccess.constructPrivateKeyEntry:(Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;Ljava/util/Set;)Ljava/security/KeyStore$PrivateKeyEntry;
            areturn
        end local 8 // java.security.cert.Certificate[] chain
        33: .line 1229
      StackMap locals: java.security.KeyStore$PasswordProtection char[] java.security.Key
      StackMap stack:
            aload 7 /* key */
            instanceof javax.crypto.SecretKey
            ifeq 41
        34: .line 1231
            aload 4 /* jsksa */
            aload 7 /* key */
            checkcast javax.crypto.SecretKey
        35: .line 1232
            aload 0 /* this */
            aload 3 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getAttributes:(Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
        36: .line 1231
            invokeinterface sun.misc.JavaSecurityKeyStoreAccess.constructSecretKeyEntry:(Ljavax/crypto/SecretKey;Ljava/util/Set;)Ljava/security/KeyStore$SecretKeyEntry;
            areturn
        end local 7 // java.security.Key key
        end local 6 // char[] password
        end local 5 // java.security.KeyStore$PasswordProtection pp
        37: .line 1234
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifne 41
        38: .line 1235
            new java.lang.UnsupportedOperationException
            dup
        39: .line 1236
            ldc "untrusted certificate entries are not password-protected"
        40: .line 1235
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        41: .line 1241
      StackMap locals:
      StackMap stack:
            new java.lang.UnsupportedOperationException
            dup
            invokespecial java.lang.UnsupportedOperationException.<init>:()V
            athrow
        end local 4 // sun.misc.JavaSecurityKeyStoreAccess jsksa
        end local 3 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 2 // java.security.KeyStore$ProtectionParameter protParam
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   42     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   42     1      alias  Ljava/lang/String;
            0   42     2  protParam  Ljava/security/KeyStore$ProtectionParameter;
            3   42     3      entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            4   42     4      jsksa  Lsun/misc/JavaSecurityKeyStoreAccess;
           26   37     5         pp  Ljava/security/KeyStore$PasswordProtection;
           27   37     6   password  [C
           28   37     7        key  Ljava/security/Key;
           30   33     8      chain  [Ljava/security/cert/Certificate;
    Exceptions:
      throws java.security.KeyStoreException, java.security.NoSuchAlgorithmException, java.security.UnrecoverableEntryException
    MethodParameters:
           Name  Flags
      alias      
      protParam  

  public synchronized void engineSetEntry(java.lang.String, java.security.KeyStore$Entry, java.security.KeyStore$ProtectionParameter);
    descriptor: (Ljava/lang/String;Ljava/security/KeyStore$Entry;Ljava/security/KeyStore$ProtectionParameter;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=7, locals=7, args_size=4
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.KeyStore$Entry entry
        start local 3 // java.security.KeyStore$ProtectionParameter protParam
         0: .line 1267
            aload 3 /* protParam */
            ifnull 3
         1: .line 1268
            aload 3 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifne 3
         2: .line 1269
            new java.security.KeyStoreException
            dup
            ldc "unsupported protection parameter"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 1271
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* pProtect */
        start local 4 // java.security.KeyStore$PasswordProtection pProtect
         4: .line 1272
            aload 3 /* protParam */
            ifnull 6
         5: .line 1273
            aload 3 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
            astore 4 /* pProtect */
         6: .line 1277
      StackMap locals: java.security.KeyStore$PasswordProtection
      StackMap stack:
            invokestatic sun.misc.SharedSecrets.getJavaSecurityKeyStoreAccess:()Lsun/misc/JavaSecurityKeyStoreAccess;
            astore 5 /* jsksa */
        start local 5 // sun.misc.JavaSecurityKeyStoreAccess jsksa
         7: .line 1278
            aload 2 /* entry */
            instanceof java.security.KeyStore$TrustedCertificateEntry
            ifeq 18
         8: .line 1279
            aload 3 /* protParam */
            ifnull 12
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnull 12
         9: .line 1281
            new java.security.KeyStoreException
            dup
        10: .line 1282
            ldc "trusted certificate entries are not password-protected"
        11: .line 1281
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 1285
      StackMap locals: sun.misc.JavaSecurityKeyStoreAccess
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$TrustedCertificateEntry
        13: .line 1284
            astore 6 /* tce */
        start local 6 // java.security.KeyStore$TrustedCertificateEntry tce
        14: .line 1286
            aload 0 /* this */
            aload 1 /* alias */
            aload 6 /* tce */
            invokevirtual java.security.KeyStore$TrustedCertificateEntry.getTrustedCertificate:()Ljava/security/cert/Certificate;
        15: .line 1287
            aload 5 /* jsksa */
            aload 6 /* tce */
            invokeinterface sun.misc.JavaSecurityKeyStoreAccess.getTrustedCertificateEntryAttributes:(Ljava/security/KeyStore$TrustedCertificateEntry;)Ljava/util/Set;
        16: .line 1286
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setCertEntry:(Ljava/lang/String;Ljava/security/cert/Certificate;Ljava/util/Set;)V
        17: .line 1289
            return
        end local 6 // java.security.KeyStore$TrustedCertificateEntry tce
        18: .line 1291
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$PrivateKeyEntry
            ifeq 29
        19: .line 1292
            aload 4 /* pProtect */
            ifnull 20
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 23
        20: .line 1294
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        21: .line 1295
            ldc "non-null password required to create PrivateKeyEntry"
        22: .line 1294
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        23: .line 1297
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$PrivateKeyEntry
            astore 6 /* pke */
        start local 6 // java.security.KeyStore$PrivateKeyEntry pke
        24: .line 1298
            aload 0 /* this */
            aload 1 /* alias */
            aload 6 /* pke */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getPrivateKey:()Ljava/security/PrivateKey;
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
        25: .line 1299
            aload 6 /* pke */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
        26: .line 1300
            aload 5 /* jsksa */
            aload 6 /* pke */
            invokeinterface sun.misc.JavaSecurityKeyStoreAccess.getPrivateKeyEntryAttributes:(Ljava/security/KeyStore$PrivateKeyEntry;)Ljava/util/Set;
        27: .line 1298
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setKeyEntry:(Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;Ljava/util/Set;)V
        28: .line 1302
            return
        end local 6 // java.security.KeyStore$PrivateKeyEntry pke
        29: .line 1304
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$SecretKeyEntry
            ifeq 40
        30: .line 1305
            aload 4 /* pProtect */
            ifnull 31
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 34
        31: .line 1307
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        32: .line 1308
            ldc "non-null password required to create SecretKeyEntry"
        33: .line 1307
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        34: .line 1310
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$SecretKeyEntry
            astore 6 /* ske */
        start local 6 // java.security.KeyStore$SecretKeyEntry ske
        35: .line 1311
            aload 0 /* this */
            aload 1 /* alias */
            aload 6 /* ske */
            invokevirtual java.security.KeyStore$SecretKeyEntry.getSecretKey:()Ljavax/crypto/SecretKey;
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
        36: .line 1312
            aconst_null
        37: .line 1313
            aload 5 /* jsksa */
            aload 6 /* ske */
            invokeinterface sun.misc.JavaSecurityKeyStoreAccess.getSecretKeyEntryAttributes:(Ljava/security/KeyStore$SecretKeyEntry;)Ljava/util/Set;
        38: .line 1311
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setKeyEntry:(Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;Ljava/util/Set;)V
        39: .line 1315
            return
        end local 6 // java.security.KeyStore$SecretKeyEntry ske
        40: .line 1319
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        41: .line 1320
            new java.lang.StringBuilder
            dup
            ldc "unsupported entry type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* entry */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        42: .line 1319
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // sun.misc.JavaSecurityKeyStoreAccess jsksa
        end local 4 // java.security.KeyStore$PasswordProtection pProtect
        end local 3 // java.security.KeyStore$ProtectionParameter protParam
        end local 2 // java.security.KeyStore$Entry entry
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   43     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   43     1      alias  Ljava/lang/String;
            0   43     2      entry  Ljava/security/KeyStore$Entry;
            0   43     3  protParam  Ljava/security/KeyStore$ProtectionParameter;
            4   43     4   pProtect  Ljava/security/KeyStore$PasswordProtection;
            7   43     5      jsksa  Lsun/misc/JavaSecurityKeyStoreAccess;
           14   18     6        tce  Ljava/security/KeyStore$TrustedCertificateEntry;
           24   29     6        pke  Ljava/security/KeyStore$PrivateKeyEntry;
           35   40     6        ske  Ljava/security/KeyStore$SecretKeyEntry;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
           Name  Flags
      alias      
      entry      
      protParam  

  private java.util.Set<sun.security.pkcs12.PKCS12Attribute> getAttributes(sun.security.pkcs12.PKCS12KeyStore$Entry);
    descriptor: (Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=4, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         0: .line 1328
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            ifnonnull 2
         1: .line 1329
            aload 1 /* entry */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
         2: .line 1333
      StackMap locals:
      StackMap stack:
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new sun.security.pkcs12.PKCS12Attribute
            dup
         3: .line 1334
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9FriendlyName_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.alias:Ljava/lang/String;
            invokespecial sun.security.pkcs12.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         4: .line 1333
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         5: .line 1337
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.keyId:[B
            astore 2 /* keyIdValue */
        start local 2 // byte[] keyIdValue
         6: .line 1338
            aload 2 /* keyIdValue */
            ifnull 10
         7: .line 1339
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new sun.security.pkcs12.PKCS12Attribute
            dup
         8: .line 1340
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9LocalKeyId_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            aload 2 /* keyIdValue */
            invokestatic sun.security.util.Debug.toString:([B)Ljava/lang/String;
            invokespecial sun.security.pkcs12.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         9: .line 1339
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        10: .line 1344
      StackMap locals: byte[]
      StackMap stack:
            aload 1 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 24
        11: .line 1346
            aload 1 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
        12: .line 1345
            astore 3 /* trustedKeyUsageValue */
        start local 3 // sun.security.util.ObjectIdentifier[] trustedKeyUsageValue
        13: .line 1347
            aload 3 /* trustedKeyUsageValue */
            ifnull 24
        14: .line 1348
            aload 3 /* trustedKeyUsageValue */
            arraylength
            iconst_1
            if_icmpne 20
        15: .line 1349
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new sun.security.pkcs12.PKCS12Attribute
            dup
        16: .line 1350
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        17: .line 1351
            aload 3 /* trustedKeyUsageValue */
            iconst_0
            aaload
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokespecial sun.security.pkcs12.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        18: .line 1349
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        19: .line 1352
            goto 24
        20: .line 1353
      StackMap locals: sun.security.util.ObjectIdentifier[]
      StackMap stack:
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new sun.security.pkcs12.PKCS12Attribute
            dup
        21: .line 1354
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        22: .line 1355
            aload 3 /* trustedKeyUsageValue */
            invokestatic java.util.Arrays.toString:([Ljava/lang/Object;)Ljava/lang/String;
            invokespecial sun.security.pkcs12.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        23: .line 1353
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // sun.security.util.ObjectIdentifier[] trustedKeyUsageValue
        24: .line 1360
      StackMap locals:
      StackMap stack:
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            areturn
        end local 2 // byte[] keyIdValue
        end local 1 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   25     0                  this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   25     1                 entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            6   25     2            keyIdValue  [B
           13   24     3  trustedKeyUsageValue  [Lsun/security/util/ObjectIdentifier;
    Signature: (Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;
    MethodParameters:
       Name  Flags
      entry  

  private byte[] generateHash(byte[]);
    descriptor: ([B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // byte[] data
         0: .line 1368
            aconst_null
            astore 2 /* digest */
        start local 2 // byte[] digest
         1: .line 1371
            ldc "SHA1"
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
            astore 3 /* md */
        start local 3 // java.security.MessageDigest md
         2: .line 1372
            aload 3 /* md */
            aload 1 /* data */
            invokevirtual java.security.MessageDigest.update:([B)V
         3: .line 1373
            aload 3 /* md */
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 2 /* digest */
        end local 3 // java.security.MessageDigest md
         4: .line 1374
            goto 7
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] byte[]
      StackMap stack: java.lang.Exception
         5: astore 3 /* e */
        start local 3 // java.lang.Exception e
         6: .line 1375
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "generateHash failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 3 /* e */
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
         7: .line 1377
      StackMap locals:
      StackMap stack:
            aload 2 /* digest */
            areturn
        end local 2 // byte[] digest
        end local 1 // byte[] data
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    8     1    data  [B
            1    8     2  digest  [B
            2    4     3      md  Ljava/security/MessageDigest;
            6    7     3       e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     4       5  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      data  

  private byte[] calculateMac(char[], byte[]);
    descriptor: ([C[B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=12, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // char[] passwd
        start local 2 // byte[] data
         0: .line 1390
            aconst_null
            astore 3 /* mData */
        start local 3 // byte[] mData
         1: .line 1391
            ldc "SHA1"
            astore 4 /* algName */
        start local 4 // java.lang.String algName
         2: .line 1395
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getSalt:()[B
            astore 5 /* salt */
        start local 5 // byte[] salt
         3: .line 1398
            ldc "HmacPBESHA1"
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;)Ljavax/crypto/Mac;
            astore 6 /* m */
        start local 6 // javax.crypto.Mac m
         4: .line 1400
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 5 /* salt */
            ldc 100000
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
         5: .line 1399
            astore 7 /* params */
        start local 7 // javax.crypto.spec.PBEParameterSpec params
         6: .line 1401
            aload 0 /* this */
            aload 1 /* passwd */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 8 /* key */
        start local 8 // javax.crypto.SecretKey key
         7: .line 1402
            aload 6 /* m */
            aload 8 /* key */
            aload 7 /* params */
            invokevirtual javax.crypto.Mac.init:(Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
         8: .line 1403
            aload 6 /* m */
            aload 2 /* data */
            invokevirtual javax.crypto.Mac.update:([B)V
         9: .line 1404
            aload 6 /* m */
            invokevirtual javax.crypto.Mac.doFinal:()[B
            astore 9 /* macResult */
        start local 9 // byte[] macResult
        10: .line 1407
            new sun.security.pkcs12.MacData
            dup
            aload 4 /* algName */
            aload 9 /* macResult */
            aload 5 /* salt */
        11: .line 1408
            ldc 100000
        12: .line 1407
            invokespecial sun.security.pkcs12.MacData.<init>:(Ljava/lang/String;[B[BI)V
            astore 10 /* macData */
        start local 10 // sun.security.pkcs12.MacData macData
        13: .line 1409
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 11 /* bytes */
        start local 11 // sun.security.util.DerOutputStream bytes
        14: .line 1410
            aload 11 /* bytes */
            aload 10 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        15: .line 1411
            aload 11 /* bytes */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 3 /* mData */
        end local 11 // sun.security.util.DerOutputStream bytes
        end local 10 // sun.security.pkcs12.MacData macData
        end local 9 // byte[] macResult
        end local 8 // javax.crypto.SecretKey key
        end local 7 // javax.crypto.spec.PBEParameterSpec params
        end local 6 // javax.crypto.Mac m
        end local 5 // byte[] salt
        16: .line 1412
            goto 19
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] byte[] byte[] java.lang.String
      StackMap stack: java.lang.Exception
        17: astore 5 /* e */
        start local 5 // java.lang.Exception e
        18: .line 1413
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "calculateMac failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 5 /* e */
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.lang.Exception e
        19: .line 1415
      StackMap locals:
      StackMap stack:
            aload 3 /* mData */
            areturn
        end local 4 // java.lang.String algName
        end local 3 // byte[] mData
        end local 2 // byte[] data
        end local 1 // char[] passwd
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   20     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   20     1     passwd  [C
            0   20     2       data  [B
            1   20     3      mData  [B
            2   20     4    algName  Ljava/lang/String;
            3   16     5       salt  [B
            4   16     6          m  Ljavax/crypto/Mac;
            6   16     7     params  Ljavax/crypto/spec/PBEParameterSpec;
            7   16     8        key  Ljavax/crypto/SecretKey;
           10   16     9  macResult  [B
           13   16    10    macData  Lsun/security/pkcs12/MacData;
           14   16    11      bytes  Lsun/security/util/DerOutputStream;
           18   19     5          e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2    16      17  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      passwd  
      data    

  private boolean validateChain(java.security.cert.Certificate[]);
    descriptor: ([Ljava/security/cert/Certificate;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.security.cert.Certificate[] certChain
         0: .line 1424
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 9
         2: .line 1426
      StackMap locals: int
      StackMap stack:
            aload 1 /* certChain */
            iload 2 /* i */
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
         3: .line 1425
            astore 3 /* issuerDN */
        start local 3 // javax.security.auth.x500.X500Principal issuerDN
         4: .line 1428
            aload 1 /* certChain */
            iload 2 /* i */
            iconst_1
            iadd
            aaload
            checkcast java.security.cert.X509Certificate
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
         5: .line 1427
            astore 4 /* subjectDN */
        start local 4 // javax.security.auth.x500.X500Principal subjectDN
         6: .line 1429
            aload 3 /* issuerDN */
            aload 4 /* subjectDN */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 8
         7: .line 1430
            iconst_0
            ireturn
        end local 4 // javax.security.auth.x500.X500Principal subjectDN
        end local 3 // javax.security.auth.x500.X500Principal issuerDN
         8: .line 1424
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 2 /* i */
            aload 1 /* certChain */
            arraylength
            iconst_1
            isub
            if_icmplt 2
        end local 2 // int i
        10: .line 1436
            new java.util.HashSet
            dup
            aload 1 /* certChain */
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 2 /* set */
        start local 2 // java.util.Set set
        11: .line 1437
            aload 2 /* set */
            invokeinterface java.util.Set.size:()I
            aload 1 /* certChain */
            arraylength
            if_icmpne 12
            iconst_1
            ireturn
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.security.cert.Certificate[] java.util.Set
      StackMap stack:
        12: iconst_0
            ireturn
        end local 2 // java.util.Set set
        end local 1 // java.security.cert.Certificate[] certChain
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   13     1  certChain  [Ljava/security/cert/Certificate;
            1   10     2          i  I
            4    8     3   issuerDN  Ljavax/security/auth/x500/X500Principal;
            6    8     4  subjectDN  Ljavax/security/auth/x500/X500Principal;
           11   13     2        set  Ljava/util/Set<Ljava/security/cert/Certificate;>;
    MethodParameters:
           Name  Flags
      certChain  

  private byte[] getBagAttributes(java.lang.String, byte[], java.util.Set<sun.security.pkcs12.PKCS12Attribute>);
    descriptor: (Ljava/lang/String;[BLjava/util/Set;)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // byte[] keyId
        start local 3 // java.util.Set attributes
         0: .line 1478
            aload 0 /* this */
            aload 1 /* alias */
            aload 2 /* keyId */
            aconst_null
            aload 3 /* attributes */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[B[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)[B
            areturn
        end local 3 // java.util.Set attributes
        end local 2 // byte[] keyId
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    1     1       alias  Ljava/lang/String;
            0    1     2       keyId  [B
            0    1     3  attributes  Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/lang/String;[BLjava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;)[B
    MethodParameters:
            Name  Flags
      alias       
      keyId       
      attributes  

  private byte[] getBagAttributes(java.lang.String, byte[], sun.security.util.ObjectIdentifier[], java.util.Set<sun.security.pkcs12.PKCS12Attribute>);
    descriptor: (Ljava/lang/String;[B[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=16, args_size=5
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String alias
        start local 2 // byte[] keyId
        start local 3 // sun.security.util.ObjectIdentifier[] trustedUsage
        start local 4 // java.util.Set attributes
         0: .line 1485
            aconst_null
            astore 5 /* localKeyID */
        start local 5 // byte[] localKeyID
         1: .line 1486
            aconst_null
            astore 6 /* friendlyName */
        start local 6 // byte[] friendlyName
         2: .line 1487
            aconst_null
            astore 7 /* trustedKeyUsage */
        start local 7 // byte[] trustedKeyUsage
         3: .line 1490
            aload 1 /* alias */
            ifnonnull 5
            aload 2 /* keyId */
            ifnonnull 5
            aload 7 /* trustedKeyUsage */
            ifnonnull 5
         4: .line 1491
            aconst_null
            areturn
         5: .line 1495
      StackMap locals: byte[] byte[] byte[]
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 8 /* bagAttrs */
        start local 8 // sun.security.util.DerOutputStream bagAttrs
         6: .line 1498
            aload 1 /* alias */
            ifnull 15
         7: .line 1499
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* bagAttr1 */
        start local 9 // sun.security.util.DerOutputStream bagAttr1
         8: .line 1500
            aload 9 /* bagAttr1 */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9FriendlyName_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
         9: .line 1501
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 10 /* bagAttrContent1 */
        start local 10 // sun.security.util.DerOutputStream bagAttrContent1
        10: .line 1502
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 11 /* bagAttrValue1 */
        start local 11 // sun.security.util.DerOutputStream bagAttrValue1
        11: .line 1503
            aload 10 /* bagAttrContent1 */
            aload 1 /* alias */
            invokevirtual sun.security.util.DerOutputStream.putBMPString:(Ljava/lang/String;)V
        12: .line 1504
            aload 9 /* bagAttr1 */
            bipush 49
            aload 10 /* bagAttrContent1 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        13: .line 1505
            aload 11 /* bagAttrValue1 */
            bipush 48
            aload 9 /* bagAttr1 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        14: .line 1506
            aload 11 /* bagAttrValue1 */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 6 /* friendlyName */
        end local 11 // sun.security.util.DerOutputStream bagAttrValue1
        end local 10 // sun.security.util.DerOutputStream bagAttrContent1
        end local 9 // sun.security.util.DerOutputStream bagAttr1
        15: .line 1510
      StackMap locals: sun.security.util.DerOutputStream
      StackMap stack:
            aload 2 /* keyId */
            ifnull 24
        16: .line 1511
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* bagAttr2 */
        start local 9 // sun.security.util.DerOutputStream bagAttr2
        17: .line 1512
            aload 9 /* bagAttr2 */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9LocalKeyId_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        18: .line 1513
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 10 /* bagAttrContent2 */
        start local 10 // sun.security.util.DerOutputStream bagAttrContent2
        19: .line 1514
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 11 /* bagAttrValue2 */
        start local 11 // sun.security.util.DerOutputStream bagAttrValue2
        20: .line 1515
            aload 10 /* bagAttrContent2 */
            aload 2 /* keyId */
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        21: .line 1516
            aload 9 /* bagAttr2 */
            bipush 49
            aload 10 /* bagAttrContent2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        22: .line 1517
            aload 11 /* bagAttrValue2 */
            bipush 48
            aload 9 /* bagAttr2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        23: .line 1518
            aload 11 /* bagAttrValue2 */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 5 /* localKeyID */
        end local 11 // sun.security.util.DerOutputStream bagAttrValue2
        end local 10 // sun.security.util.DerOutputStream bagAttrContent2
        end local 9 // sun.security.util.DerOutputStream bagAttr2
        24: .line 1522
      StackMap locals:
      StackMap stack:
            aload 3 /* trustedUsage */
            ifnull 37
        25: .line 1523
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* bagAttr3 */
        start local 9 // sun.security.util.DerOutputStream bagAttr3
        26: .line 1524
            aload 9 /* bagAttr3 */
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        27: .line 1525
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 10 /* bagAttrContent3 */
        start local 10 // sun.security.util.DerOutputStream bagAttrContent3
        28: .line 1526
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 11 /* bagAttrValue3 */
        start local 11 // sun.security.util.DerOutputStream bagAttrValue3
        29: .line 1527
            aload 3 /* trustedUsage */
            dup
            astore 15
            arraylength
            istore 14
            iconst_0
            istore 13
            goto 33
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set byte[] byte[] byte[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream top int int sun.security.util.ObjectIdentifier[]
      StackMap stack:
        30: aload 15
            iload 13
            aaload
            astore 12 /* usage */
        start local 12 // sun.security.util.ObjectIdentifier usage
        31: .line 1528
            aload 10 /* bagAttrContent3 */
            aload 12 /* usage */
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        end local 12 // sun.security.util.ObjectIdentifier usage
        32: .line 1527
            iinc 13 1
      StackMap locals:
      StackMap stack:
        33: iload 13
            iload 14
            if_icmplt 30
        34: .line 1530
            aload 9 /* bagAttr3 */
            bipush 49
            aload 10 /* bagAttrContent3 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        35: .line 1531
            aload 11 /* bagAttrValue3 */
            bipush 48
            aload 9 /* bagAttr3 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        36: .line 1532
            aload 11 /* bagAttrValue3 */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 7 /* trustedKeyUsage */
        end local 11 // sun.security.util.DerOutputStream bagAttrValue3
        end local 10 // sun.security.util.DerOutputStream bagAttrContent3
        end local 9 // sun.security.util.DerOutputStream bagAttr3
        37: .line 1535
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set byte[] byte[] byte[] sun.security.util.DerOutputStream
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* attrs */
        start local 9 // sun.security.util.DerOutputStream attrs
        38: .line 1536
            aload 6 /* friendlyName */
            ifnull 40
        39: .line 1537
            aload 9 /* attrs */
            aload 6 /* friendlyName */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        40: .line 1539
      StackMap locals: sun.security.util.DerOutputStream
      StackMap stack:
            aload 5 /* localKeyID */
            ifnull 42
        41: .line 1540
            aload 9 /* attrs */
            aload 5 /* localKeyID */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        42: .line 1542
      StackMap locals:
      StackMap stack:
            aload 7 /* trustedKeyUsage */
            ifnull 44
        43: .line 1543
            aload 9 /* attrs */
            aload 7 /* trustedKeyUsage */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        44: .line 1546
      StackMap locals:
      StackMap stack:
            aload 4 /* attributes */
            ifnull 54
        45: .line 1547
            aload 4 /* attributes */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 11
            goto 53
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set byte[] byte[] byte[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream top java.util.Iterator
      StackMap stack:
        46: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12Attribute
            astore 10 /* attribute */
        start local 10 // sun.security.pkcs12.PKCS12Attribute attribute
        47: .line 1548
            aload 10 /* attribute */
            invokevirtual sun.security.pkcs12.PKCS12Attribute.getName:()Ljava/lang/String;
            astore 12 /* attributeName */
        start local 12 // java.lang.String attributeName
        48: .line 1550
            getstatic sun.security.pkcs12.PKCS12KeyStore.CORE_ATTRIBUTES:[Ljava/lang/String;
            iconst_0
            aaload
            aload 12 /* attributeName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 53
        49: .line 1551
            getstatic sun.security.pkcs12.PKCS12KeyStore.CORE_ATTRIBUTES:[Ljava/lang/String;
            iconst_1
            aaload
            aload 12 /* attributeName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 53
        50: .line 1552
            getstatic sun.security.pkcs12.PKCS12KeyStore.CORE_ATTRIBUTES:[Ljava/lang/String;
            iconst_2
            aaload
            aload 12 /* attributeName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 52
        51: .line 1553
            goto 53
        52: .line 1555
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set byte[] byte[] byte[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.pkcs12.PKCS12Attribute java.util.Iterator java.lang.String
      StackMap stack:
            aload 9 /* attrs */
            aload 10 /* attribute */
            invokevirtual sun.security.pkcs12.PKCS12Attribute.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        end local 12 // java.lang.String attributeName
        end local 10 // sun.security.pkcs12.PKCS12Attribute attribute
        53: .line 1547
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set byte[] byte[] byte[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream top java.util.Iterator
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 46
        54: .line 1559
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set byte[] byte[] byte[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream
      StackMap stack:
            aload 8 /* bagAttrs */
            bipush 49
            aload 9 /* attrs */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        55: .line 1560
            aload 8 /* bagAttrs */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 9 // sun.security.util.DerOutputStream attrs
        end local 8 // sun.security.util.DerOutputStream bagAttrs
        end local 7 // byte[] trustedKeyUsage
        end local 6 // byte[] friendlyName
        end local 5 // byte[] localKeyID
        end local 4 // java.util.Set attributes
        end local 3 // sun.security.util.ObjectIdentifier[] trustedUsage
        end local 2 // byte[] keyId
        end local 1 // java.lang.String alias
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   56     0             this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   56     1            alias  Ljava/lang/String;
            0   56     2            keyId  [B
            0   56     3     trustedUsage  [Lsun/security/util/ObjectIdentifier;
            0   56     4       attributes  Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;
            1   56     5       localKeyID  [B
            2   56     6     friendlyName  [B
            3   56     7  trustedKeyUsage  [B
            6   56     8         bagAttrs  Lsun/security/util/DerOutputStream;
            8   15     9         bagAttr1  Lsun/security/util/DerOutputStream;
           10   15    10  bagAttrContent1  Lsun/security/util/DerOutputStream;
           11   15    11    bagAttrValue1  Lsun/security/util/DerOutputStream;
           17   24     9         bagAttr2  Lsun/security/util/DerOutputStream;
           19   24    10  bagAttrContent2  Lsun/security/util/DerOutputStream;
           20   24    11    bagAttrValue2  Lsun/security/util/DerOutputStream;
           26   37     9         bagAttr3  Lsun/security/util/DerOutputStream;
           28   37    10  bagAttrContent3  Lsun/security/util/DerOutputStream;
           29   37    11    bagAttrValue3  Lsun/security/util/DerOutputStream;
           31   32    12            usage  Lsun/security/util/ObjectIdentifier;
           38   56     9            attrs  Lsun/security/util/DerOutputStream;
           47   53    10        attribute  Lsun/security/pkcs12/PKCS12Attribute;
           48   53    12    attributeName  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/lang/String;[B[Lsun/security/util/ObjectIdentifier;Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;)[B
    MethodParameters:
              Name  Flags
      alias         
      keyId         
      trustedUsage  
      attributes    

  private byte[] createEncryptedData(char[]);
    descriptor: ([C)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=17, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // char[] password
         0: .line 1572
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* out */
        start local 2 // sun.security.util.DerOutputStream out
         1: .line 1573
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineAliases:()Ljava/util/Enumeration;
            astore 3 /* e */
        start local 3 // java.util.Enumeration e
         2: goto 65
         3: .line 1575
      StackMap locals: sun.security.util.DerOutputStream 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
         4: .line 1576
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 4 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 5 /* entry */
        start local 5 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         5: .line 1581
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 12
         6: .line 1582
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            astore 7 /* keyEntry */
        start local 7 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         7: .line 1583
            aload 7 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 10
         8: .line 1584
            aload 7 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            astore 6 /* certs */
        start local 6 // java.security.cert.Certificate[] certs
         9: .line 1585
            goto 16
        end local 6 // java.security.cert.Certificate[] certs
        10: .line 1586
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] sun.security.util.DerOutputStream java.util.Enumeration java.lang.String sun.security.pkcs12.PKCS12KeyStore$Entry top sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
      StackMap stack:
            iconst_0
            anewarray java.security.cert.Certificate
            astore 6 /* certs */
        end local 7 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
        start local 6 // java.security.cert.Certificate[] certs
        11: .line 1588
            goto 16
        end local 6 // java.security.cert.Certificate[] certs
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] sun.security.util.DerOutputStream java.util.Enumeration java.lang.String sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
        12: aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 15
        13: .line 1589
            iconst_1
            anewarray java.security.cert.Certificate
            dup
            iconst_0
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            aastore
            astore 6 /* certs */
        start local 6 // java.security.cert.Certificate[] certs
        14: .line 1590
            goto 16
        end local 6 // java.security.cert.Certificate[] certs
        15: .line 1591
      StackMap locals:
      StackMap stack:
            iconst_0
            anewarray java.security.cert.Certificate
            astore 6 /* certs */
        start local 6 // java.security.cert.Certificate[] certs
        16: .line 1594
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        17: goto 64
        18: .line 1596
      StackMap locals: int
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 8 /* safeBag */
        start local 8 // sun.security.util.DerOutputStream safeBag
        19: .line 1597
            aload 8 /* safeBag */
            getstatic sun.security.pkcs12.PKCS12KeyStore.CertBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        20: .line 1600
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* certBag */
        start local 9 // sun.security.util.DerOutputStream certBag
        21: .line 1601
            aload 9 /* certBag */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9CertType_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        22: .line 1604
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 10 /* certValue */
        start local 10 // sun.security.util.DerOutputStream certValue
        23: .line 1605
            aload 6 /* certs */
            iload 7 /* i */
            aaload
            checkcast java.security.cert.X509Certificate
            astore 11 /* cert */
        start local 11 // java.security.cert.X509Certificate cert
        24: .line 1606
            aload 10 /* certValue */
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        25: .line 1607
            aload 9 /* certBag */
            bipush -128
        26: .line 1608
            iconst_1
            iconst_0
        27: .line 1607
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        28: .line 1608
            aload 10 /* certValue */
        29: .line 1607
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        30: .line 1611
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 12 /* certout */
        start local 12 // sun.security.util.DerOutputStream certout
        31: .line 1612
            aload 12 /* certout */
            bipush 48
            aload 9 /* certBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        32: .line 1613
            aload 12 /* certout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 13 /* certBagValue */
        start local 13 // byte[] certBagValue
        33: .line 1616
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 14 /* bagValue */
        start local 14 // sun.security.util.DerOutputStream bagValue
        34: .line 1617
            aload 14 /* bagValue */
            aload 13 /* certBagValue */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        35: .line 1619
            aload 8 /* safeBag */
            bipush -128
        36: .line 1620
            iconst_1
            iconst_0
        37: .line 1619
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        38: .line 1620
            aload 14 /* bagValue */
        39: .line 1619
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        40: .line 1625
            aconst_null
            astore 15 /* bagAttrs */
        start local 15 // byte[] bagAttrs
        41: .line 1626
            iload 7 /* i */
            ifne 56
        42: .line 1628
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 49
        43: .line 1629
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 16 /* keyEntry */
        start local 16 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
        44: .line 1631
            aload 0 /* this */
            aload 16 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.alias:Ljava/lang/String;
            aload 16 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.keyId:[B
        45: .line 1632
            aload 16 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
        46: .line 1631
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[BLjava/util/Set;)[B
        47: .line 1630
            astore 15 /* bagAttrs */
        end local 16 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
        48: .line 1633
            goto 60
        49: .line 1634
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] sun.security.util.DerOutputStream java.util.Enumeration java.lang.String sun.security.pkcs12.PKCS12KeyStore$Entry java.security.cert.Certificate[] int sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream java.security.cert.X509Certificate sun.security.util.DerOutputStream byte[] sun.security.util.DerOutputStream byte[]
      StackMap stack:
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            astore 16 /* certEntry */
        start local 16 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
        50: .line 1636
            aload 0 /* this */
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.alias:Ljava/lang/String;
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.keyId:[B
        51: .line 1637
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
        52: .line 1638
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.attributes:Ljava/util/Set;
        53: .line 1636
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[B[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)[B
        54: .line 1635
            astore 15 /* bagAttrs */
        end local 16 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
        55: .line 1640
            goto 60
        56: .line 1647
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        57: .line 1648
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.getName:()Ljava/lang/String;
            aconst_null
        58: .line 1649
            aload 5 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
        59: .line 1647
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[BLjava/util/Set;)[B
            astore 15 /* bagAttrs */
        60: .line 1651
      StackMap locals:
      StackMap stack:
            aload 15 /* bagAttrs */
            ifnull 62
        61: .line 1652
            aload 8 /* safeBag */
            aload 15 /* bagAttrs */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        62: .line 1656
      StackMap locals:
      StackMap stack:
            aload 2 /* out */
            bipush 48
            aload 8 /* safeBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        end local 15 // byte[] bagAttrs
        end local 14 // sun.security.util.DerOutputStream bagValue
        end local 13 // byte[] certBagValue
        end local 12 // sun.security.util.DerOutputStream certout
        end local 11 // java.security.cert.X509Certificate cert
        end local 10 // sun.security.util.DerOutputStream certValue
        end local 9 // sun.security.util.DerOutputStream certBag
        end local 8 // sun.security.util.DerOutputStream safeBag
        63: .line 1594
            iinc 7 /* i */ 1
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] sun.security.util.DerOutputStream java.util.Enumeration java.lang.String sun.security.pkcs12.PKCS12KeyStore$Entry java.security.cert.Certificate[] int
      StackMap stack:
        64: iload 7 /* i */
            aload 6 /* certs */
            arraylength
            if_icmplt 18
        end local 7 // int i
        end local 6 // java.security.cert.Certificate[] certs
        end local 5 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 4 // java.lang.String alias
        65: .line 1573
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] sun.security.util.DerOutputStream java.util.Enumeration
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        end local 3 // java.util.Enumeration e
        66: .line 1661
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* safeBagValue */
        start local 3 // sun.security.util.DerOutputStream safeBagValue
        67: .line 1662
            aload 3 /* safeBagValue */
            bipush 48
            aload 2 /* out */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        68: .line 1663
            aload 3 /* safeBagValue */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 4 /* safeBagData */
        start local 4 // byte[] safeBagData
        69: .line 1666
            aload 0 /* this */
            aload 4 /* safeBagData */
            aload 1 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.encryptContent:([B[C)[B
            astore 5 /* encrContentInfo */
        start local 5 // byte[] encrContentInfo
        70: .line 1669
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 6 /* encrData */
        start local 6 // sun.security.util.DerOutputStream encrData
        71: .line 1670
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 7 /* encrDataContent */
        start local 7 // sun.security.util.DerOutputStream encrDataContent
        72: .line 1671
            aload 6 /* encrData */
            iconst_0
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        73: .line 1672
            aload 6 /* encrData */
            aload 5 /* encrContentInfo */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        74: .line 1673
            aload 7 /* encrDataContent */
            bipush 48
            aload 6 /* encrData */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        75: .line 1674
            aload 7 /* encrDataContent */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 7 // sun.security.util.DerOutputStream encrDataContent
        end local 6 // sun.security.util.DerOutputStream encrData
        end local 5 // byte[] encrContentInfo
        end local 4 // byte[] safeBagData
        end local 3 // sun.security.util.DerOutputStream safeBagValue
        end local 2 // sun.security.util.DerOutputStream out
        end local 1 // char[] password
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   76     0             this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   76     1         password  [C
            1   76     2              out  Lsun/security/util/DerOutputStream;
            2   66     3                e  Ljava/util/Enumeration<Ljava/lang/String;>;
            4   65     4            alias  Ljava/lang/String;
            5   65     5            entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            9   10     6            certs  [Ljava/security/cert/Certificate;
           11   12     6            certs  [Ljava/security/cert/Certificate;
           14   15     6            certs  [Ljava/security/cert/Certificate;
           16   65     6            certs  [Ljava/security/cert/Certificate;
            7   11     7         keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
           17   65     7                i  I
           19   63     8          safeBag  Lsun/security/util/DerOutputStream;
           21   63     9          certBag  Lsun/security/util/DerOutputStream;
           23   63    10        certValue  Lsun/security/util/DerOutputStream;
           24   63    11             cert  Ljava/security/cert/X509Certificate;
           31   63    12          certout  Lsun/security/util/DerOutputStream;
           33   63    13     certBagValue  [B
           34   63    14         bagValue  Lsun/security/util/DerOutputStream;
           41   63    15         bagAttrs  [B
           44   48    16         keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$KeyEntry;
           50   55    16        certEntry  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
           67   76     3     safeBagValue  Lsun/security/util/DerOutputStream;
           69   76     4      safeBagData  [B
           70   76     5  encrContentInfo  [B
           71   76     6         encrData  Lsun/security/util/DerOutputStream;
           72   76     7  encrDataContent  Lsun/security/util/DerOutputStream;
    Exceptions:
      throws java.security.cert.CertificateException, java.io.IOException
    MethodParameters:
          Name  Flags
      password  

  private byte[] createSafeContent();
    descriptor: ()[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=12, args_size=1
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
         0: .line 1687
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 1 /* out */
        start local 1 // sun.security.util.DerOutputStream out
         1: .line 1688
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineAliases:()Ljava/util/Enumeration;
            astore 2 /* e */
        start local 2 // java.util.Enumeration e
         2: goto 54
         3: .line 1690
      StackMap locals: sun.security.util.DerOutputStream java.util.Enumeration
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 3 /* alias */
        start local 3 // java.lang.String alias
         4: .line 1691
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 3 /* alias */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$Entry
            astore 4 /* entry */
        start local 4 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         5: .line 1692
            aload 4 /* entry */
            ifnull 54
            aload 4 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifne 7
         6: .line 1693
            goto 54
         7: .line 1695
      StackMap locals: java.lang.String sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 5 /* safeBag */
        start local 5 // sun.security.util.DerOutputStream safeBag
         8: .line 1696
            aload 4 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 6 /* keyEntry */
        start local 6 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
         9: .line 1699
            aload 6 /* keyEntry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 27
        10: .line 1701
            aload 5 /* safeBag */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS8ShroudedKeyBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        11: .line 1704
            aload 6 /* keyEntry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
            astore 7 /* encrBytes */
        start local 7 // byte[] encrBytes
        12: .line 1705
            aconst_null
            astore 8 /* encrInfo */
        start local 8 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        13: .line 1707
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 7 /* encrBytes */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
            astore 8 /* encrInfo */
        14: .line 1709
            goto 19
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerOutputStream java.util.Enumeration java.lang.String sun.security.pkcs12.PKCS12KeyStore$Entry sun.security.util.DerOutputStream sun.security.pkcs12.PKCS12KeyStore$KeyEntry byte[] sun.security.pkcs.EncryptedPrivateKeyInfo
      StackMap stack: java.io.IOException
        15: astore 9 /* ioe */
        start local 9 // java.io.IOException ioe
        16: .line 1710
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Private key not stored as PKCS#8 EncryptedPrivateKeyInfo"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        17: .line 1712
            aload 9 /* ioe */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 1710
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 9 // java.io.IOException ioe
        19: .line 1716
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* bagValue */
        start local 9 // sun.security.util.DerOutputStream bagValue
        20: .line 1717
            aload 9 /* bagValue */
            aload 8 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        21: .line 1718
            aload 5 /* safeBag */
            bipush -128
        22: .line 1719
            iconst_1
            iconst_0
        23: .line 1718
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        24: .line 1719
            aload 9 /* bagValue */
        25: .line 1718
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        end local 9 // sun.security.util.DerOutputStream bagValue
        end local 8 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        end local 7 // byte[] encrBytes
        26: .line 1722
            goto 50
      StackMap locals:
      StackMap stack:
        27: aload 6 /* keyEntry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 54
        28: .line 1724
            aload 5 /* safeBag */
            getstatic sun.security.pkcs12.PKCS12KeyStore.SecretBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        29: .line 1727
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 7 /* secretBag */
        start local 7 // sun.security.util.DerOutputStream secretBag
        30: .line 1728
            aload 7 /* secretBag */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS8ShroudedKeyBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        31: .line 1731
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 8 /* secretKeyValue */
        start local 8 // sun.security.util.DerOutputStream secretKeyValue
        32: .line 1732
            aload 8 /* secretKeyValue */
        33: .line 1733
            aload 6 /* keyEntry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        34: .line 1732
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        35: .line 1734
            aload 7 /* secretBag */
            bipush -128
        36: .line 1735
            iconst_1
            iconst_0
        37: .line 1734
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        38: .line 1735
            aload 8 /* secretKeyValue */
        39: .line 1734
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        40: .line 1738
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* secretBagSeq */
        start local 9 // sun.security.util.DerOutputStream secretBagSeq
        41: .line 1739
            aload 9 /* secretBagSeq */
            bipush 48
            aload 7 /* secretBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        42: .line 1740
            aload 9 /* secretBagSeq */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 10 /* secretBagValue */
        start local 10 // byte[] secretBagValue
        43: .line 1743
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 11 /* bagValue */
        start local 11 // sun.security.util.DerOutputStream bagValue
        44: .line 1744
            aload 11 /* bagValue */
            aload 10 /* secretBagValue */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        45: .line 1747
            aload 5 /* safeBag */
            bipush -128
        46: .line 1748
            iconst_1
            iconst_0
        47: .line 1747
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        48: .line 1748
            aload 11 /* bagValue */
        49: .line 1747
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        end local 11 // sun.security.util.DerOutputStream bagValue
        end local 10 // byte[] secretBagValue
        end local 9 // sun.security.util.DerOutputStream secretBagSeq
        end local 8 // sun.security.util.DerOutputStream secretKeyValue
        end local 7 // sun.security.util.DerOutputStream secretBag
        50: .line 1755
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* alias */
            aload 4 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.keyId:[B
            aload 4 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[BLjava/util/Set;)[B
        51: .line 1754
            astore 7 /* bagAttrs */
        start local 7 // byte[] bagAttrs
        52: .line 1756
            aload 5 /* safeBag */
            aload 7 /* bagAttrs */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        53: .line 1759
            aload 1 /* out */
            bipush 48
            aload 5 /* safeBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        end local 7 // byte[] bagAttrs
        end local 6 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
        end local 5 // sun.security.util.DerOutputStream safeBag
        end local 4 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 3 // java.lang.String alias
        54: .line 1688
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerOutputStream java.util.Enumeration
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        end local 2 // java.util.Enumeration e
        55: .line 1763
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* safeBagValue */
        start local 2 // sun.security.util.DerOutputStream safeBagValue
        56: .line 1764
            aload 2 /* safeBagValue */
            bipush 48
            aload 1 /* out */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        57: .line 1765
            aload 2 /* safeBagValue */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 2 // sun.security.util.DerOutputStream safeBagValue
        end local 1 // sun.security.util.DerOutputStream out
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   58     0            this  Lsun/security/pkcs12/PKCS12KeyStore;
            1   58     1             out  Lsun/security/util/DerOutputStream;
            2   55     2               e  Ljava/util/Enumeration<Ljava/lang/String;>;
            4   54     3           alias  Ljava/lang/String;
            5   54     4           entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            8   54     5         safeBag  Lsun/security/util/DerOutputStream;
            9   54     6        keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$KeyEntry;
           12   26     7       encrBytes  [B
           13   26     8        encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           16   19     9             ioe  Ljava/io/IOException;
           20   26     9        bagValue  Lsun/security/util/DerOutputStream;
           30   50     7       secretBag  Lsun/security/util/DerOutputStream;
           32   50     8  secretKeyValue  Lsun/security/util/DerOutputStream;
           41   50     9    secretBagSeq  Lsun/security/util/DerOutputStream;
           43   50    10  secretBagValue  [B
           44   50    11        bagValue  Lsun/security/util/DerOutputStream;
           52   54     7        bagAttrs  [B
           56   58     2    safeBagValue  Lsun/security/util/DerOutputStream;
      Exception table:
        from    to  target  type
          13    14      15  Class java.io.IOException
    Exceptions:
      throws java.security.cert.CertificateException, java.io.IOException

  private byte[] encryptContent(byte[], char[]);
    descriptor: ([B[C)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=11, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // byte[] data
        start local 2 // char[] password
         0: .line 1781
            aconst_null
            astore 3 /* encryptedData */
        start local 3 // byte[] encryptedData
         1: .line 1785
            aload 0 /* this */
            ldc "PBEWithSHA1AndRC2_40"
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
         2: .line 1784
            astore 4 /* algParams */
        start local 4 // java.security.AlgorithmParameters algParams
         3: .line 1786
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 5 /* bytes */
        start local 5 // sun.security.util.DerOutputStream bytes
         4: .line 1788
            new sun.security.x509.AlgorithmId
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd40BitRC2CBC_OID:Lsun/security/util/ObjectIdentifier;
            aload 4 /* algParams */
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)V
         5: .line 1787
            astore 6 /* algId */
        start local 6 // sun.security.x509.AlgorithmId algId
         6: .line 1789
            aload 6 /* algId */
            aload 5 /* bytes */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
         7: .line 1790
            aload 5 /* bytes */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 7 /* encodedAlgId */
        start local 7 // byte[] encodedAlgId
         8: .line 1794
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 8 /* skey */
        start local 8 // javax.crypto.SecretKey skey
         9: .line 1795
            ldc "PBEWithSHA1AndRC2_40"
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 9 /* cipher */
        start local 9 // javax.crypto.Cipher cipher
        10: .line 1796
            aload 9 /* cipher */
            iconst_1
            aload 8 /* skey */
            aload 4 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        11: .line 1797
            aload 9 /* cipher */
            aload 1 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 3 /* encryptedData */
        12: .line 1799
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 21
        13: .line 1800
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "  (Cipher algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* cipher */
            invokevirtual javax.crypto.Cipher.getAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        14: .line 1801
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 1800
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        end local 9 // javax.crypto.Cipher cipher
        end local 8 // javax.crypto.SecretKey skey
        16: .line 1804
            goto 21
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] char[] byte[] java.security.AlgorithmParameters sun.security.util.DerOutputStream sun.security.x509.AlgorithmId byte[]
      StackMap stack: java.lang.Exception
        17: astore 8 /* e */
        start local 8 // java.lang.Exception e
        18: .line 1805
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Failed to encrypt safe contents entry: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        19: .line 1806
            aload 8 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 8 /* e */
        20: .line 1805
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 8 // java.lang.Exception e
        21: .line 1810
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 8 /* bytes2 */
        start local 8 // sun.security.util.DerOutputStream bytes2
        22: .line 1811
            aload 8 /* bytes2 */
            getstatic sun.security.pkcs.ContentInfo.DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        23: .line 1812
            aload 8 /* bytes2 */
            aload 7 /* encodedAlgId */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        24: .line 1815
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* tmpout2 */
        start local 9 // sun.security.util.DerOutputStream tmpout2
        25: .line 1816
            aload 9 /* tmpout2 */
            aload 3 /* encryptedData */
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        26: .line 1817
            aload 8 /* bytes2 */
            bipush -128
        27: .line 1818
            iconst_0
            iconst_0
        28: .line 1817
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        29: .line 1818
            aload 9 /* tmpout2 */
        30: .line 1817
            invokevirtual sun.security.util.DerOutputStream.writeImplicit:(BLsun/security/util/DerOutputStream;)V
        31: .line 1821
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 10 /* out */
        start local 10 // sun.security.util.DerOutputStream out
        32: .line 1822
            aload 10 /* out */
            bipush 48
            aload 8 /* bytes2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        33: .line 1823
            aload 10 /* out */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 10 // sun.security.util.DerOutputStream out
        end local 9 // sun.security.util.DerOutputStream tmpout2
        end local 8 // sun.security.util.DerOutputStream bytes2
        end local 7 // byte[] encodedAlgId
        end local 6 // sun.security.x509.AlgorithmId algId
        end local 5 // sun.security.util.DerOutputStream bytes
        end local 4 // java.security.AlgorithmParameters algParams
        end local 3 // byte[] encryptedData
        end local 2 // char[] password
        end local 1 // byte[] data
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   34     0           this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   34     1           data  [B
            0   34     2       password  [C
            1   34     3  encryptedData  [B
            3   34     4      algParams  Ljava/security/AlgorithmParameters;
            4   34     5          bytes  Lsun/security/util/DerOutputStream;
            6   34     6          algId  Lsun/security/x509/AlgorithmId;
            8   34     7   encodedAlgId  [B
            9   16     8           skey  Ljavax/crypto/SecretKey;
           10   16     9         cipher  Ljavax/crypto/Cipher;
           18   21     8              e  Ljava/lang/Exception;
           22   34     8         bytes2  Lsun/security/util/DerOutputStream;
           25   34     9        tmpout2  Lsun/security/util/DerOutputStream;
           32   34    10            out  Lsun/security/util/DerOutputStream;
      Exception table:
        from    to  target  type
           8    16      17  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
          Name  Flags
      data      
      password  

  public synchronized void engineLoad(java.io.InputStream, char[]);
    descriptor: (Ljava/io/InputStream;[C)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=8, locals=26, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.io.InputStream stream
        start local 2 // char[] password
         0: .line 1851
            aload 1 /* stream */
            ifnonnull 2
         1: .line 1852
            return
         2: .line 1855
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         3: .line 1857
            new sun.security.util.DerValue
            dup
            aload 1 /* stream */
            invokespecial sun.security.util.DerValue.<init>:(Ljava/io/InputStream;)V
            astore 3 /* val */
        start local 3 // sun.security.util.DerValue val
         4: .line 1858
            aload 3 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 4 /* s */
        start local 4 // sun.security.util.DerInputStream s
         5: .line 1859
            aload 4 /* s */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            istore 5 /* version */
        start local 5 // int version
         6: .line 1861
            iload 5 /* version */
            iconst_3
            if_icmpeq 8
         7: .line 1862
            new java.io.IOException
            dup
            ldc "PKCS12 keystore not in version 3 format"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 1865
      StackMap locals: sun.security.util.DerValue sun.security.util.DerInputStream int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         9: .line 1871
            new sun.security.pkcs.ContentInfo
            dup
            aload 4 /* s */
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/DerInputStream;)V
            astore 7 /* authSafe */
        start local 7 // sun.security.pkcs.ContentInfo authSafe
        10: .line 1872
            aload 7 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* contentType */
        start local 8 // sun.security.util.ObjectIdentifier contentType
        11: .line 1874
            aload 8 /* contentType */
            getstatic sun.security.pkcs.ContentInfo.DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 16
        12: .line 1876
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 14
        13: .line 1877
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ldc "Loading PKCS#7 data"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 1880
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int top sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier
      StackMap stack:
            aload 7 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            astore 6 /* authSafeData */
        start local 6 // byte[] authSafeData
        15: .line 1881
            goto 17
        end local 6 // byte[] authSafeData
        16: .line 1882
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            ldc "public key protected PKCS12 not supported"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 6 // byte[] authSafeData
        17: .line 1885
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 6 /* authSafeData */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 9 /* as */
        start local 9 // sun.security.util.DerInputStream as
        18: .line 1886
            aload 9 /* as */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 10 /* safeContentsArray */
        start local 10 // sun.security.util.DerValue[] safeContentsArray
        19: .line 1887
            aload 10 /* safeContentsArray */
            arraylength
            istore 11 /* count */
        start local 11 // int count
        20: .line 1890
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        21: .line 1891
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        22: .line 1892
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        23: .line 1897
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        24: goto 92
        25: .line 1903
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int int
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 10 /* safeContentsArray */
            iload 12 /* i */
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 15 /* sci */
        start local 15 // sun.security.util.DerInputStream sci
        26: .line 1904
            new sun.security.pkcs.ContentInfo
            dup
            aload 15 /* sci */
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/DerInputStream;)V
            astore 14 /* safeContents */
        start local 14 // sun.security.pkcs.ContentInfo safeContents
        27: .line 1905
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* contentType */
        28: .line 1906
            aconst_null
            astore 13 /* safeContentsData */
        start local 13 // byte[] safeContentsData
        29: .line 1907
            aload 8 /* contentType */
            getstatic sun.security.pkcs.ContentInfo.DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 32
        30: .line 1908
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            astore 13 /* safeContentsData */
        31: .line 1909
            goto 89
      StackMap locals: byte[] sun.security.pkcs.ContentInfo sun.security.util.DerInputStream
      StackMap stack:
        32: aload 8 /* contentType */
            getstatic sun.security.pkcs.ContentInfo.ENCRYPTED_DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 88
        33: .line 1910
            aload 2 /* password */
            ifnonnull 37
        34: .line 1912
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 91
        35: .line 1913
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ldc "Warning: skipping PKCS#7 encryptedData - no password was supplied"
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        36: .line 1916
            goto 91
        37: .line 1919
      StackMap locals:
      StackMap stack:
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getContent:()Lsun/security/util/DerValue;
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
        38: .line 1918
            astore 16 /* edi */
        start local 16 // sun.security.util.DerInputStream edi
        39: .line 1920
            aload 16 /* edi */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
        40: .line 1921
            aload 16 /* edi */
            iconst_3
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 17 /* seq */
        start local 17 // sun.security.util.DerValue[] seq
        41: .line 1922
            aload 17 /* seq */
            arraylength
            iconst_3
            if_icmpeq 43
        42: .line 1925
            new java.io.IOException
            dup
            ldc "Invalid length for EncryptedContentInfo"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        43: .line 1927
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 17 /* seq */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        44: .line 1928
            aload 17 /* seq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            pop
        45: .line 1929
            aload 17 /* seq */
            iconst_2
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 49
        46: .line 1930
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unsupported encrypted content type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        47: .line 1931
            aload 17 /* seq */
            iconst_2
            aaload
            getfield sun.security.util.DerValue.tag:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        48: .line 1930
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        49: .line 1933
      StackMap locals:
      StackMap stack:
            iconst_4
            istore 18 /* newTag */
        start local 18 // byte newTag
        50: .line 1934
            aload 17 /* seq */
            iconst_2
            aaload
            invokevirtual sun.security.util.DerValue.isConstructed:()Z
            ifeq 52
        51: .line 1935
            iload 18 /* newTag */
            bipush 32
            ior
            i2b
            istore 18 /* newTag */
        52: .line 1936
      StackMap locals: int
      StackMap stack:
            aload 17 /* seq */
            iconst_2
            aaload
            iload 18 /* newTag */
            invokevirtual sun.security.util.DerValue.resetTag:(B)V
        53: .line 1937
            aload 17 /* seq */
            iconst_2
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            astore 13 /* safeContentsData */
        54: .line 1940
            aload 17 /* seq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 19 /* in */
        start local 19 // sun.security.util.DerInputStream in
        55: .line 1941
            aload 19 /* in */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 20 /* algOid */
        start local 20 // sun.security.util.ObjectIdentifier algOid
        56: .line 1942
            aload 0 /* this */
            aload 19 /* in */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.parseAlgParameters:(Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
            astore 21 /* algParams */
        start local 21 // java.security.AlgorithmParameters algParams
        57: .line 1945
            iconst_0
            istore 23 /* ic */
        start local 23 // int ic
        58: .line 1947
            aload 21 /* algParams */
            ifnull 69
        59: .line 1950
            aload 21 /* algParams */
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            checkcast javax.crypto.spec.PBEParameterSpec
        60: .line 1949
            astore 22 /* pbeSpec */
        start local 22 // javax.crypto.spec.PBEParameterSpec pbeSpec
        61: .line 1951
            goto 66
        end local 22 // javax.crypto.spec.PBEParameterSpec pbeSpec
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int int byte[] sun.security.pkcs.ContentInfo sun.security.util.DerInputStream sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.util.DerInputStream sun.security.util.ObjectIdentifier java.security.AlgorithmParameters top int
      StackMap stack: java.security.spec.InvalidParameterSpecException
        62: pop
        63: .line 1952
            new java.io.IOException
            dup
        64: .line 1953
            ldc "Invalid PBE algorithm parameters"
        65: .line 1952
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 22 // javax.crypto.spec.PBEParameterSpec pbeSpec
        66: .line 1955
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int int byte[] sun.security.pkcs.ContentInfo sun.security.util.DerInputStream sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.util.DerInputStream sun.security.util.ObjectIdentifier java.security.AlgorithmParameters javax.crypto.spec.PBEParameterSpec int
      StackMap stack:
            aload 22 /* pbeSpec */
            invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
            istore 23 /* ic */
        67: .line 1957
            iload 23 /* ic */
            ldc 5000000
            if_icmple 69
        68: .line 1958
            new java.io.IOException
            dup
            ldc "PBE iteration count too large"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 22 // javax.crypto.spec.PBEParameterSpec pbeSpec
        69: .line 1962
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int int byte[] sun.security.pkcs.ContentInfo sun.security.util.DerInputStream sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.util.DerInputStream sun.security.util.ObjectIdentifier java.security.AlgorithmParameters top int
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 74
        70: .line 1963
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Loading PKCS#7 encryptedData ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        71: .line 1964
            new sun.security.x509.AlgorithmId
            dup
            aload 20 /* algOid */
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;)V
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        72: .line 1965
            ldc " iterations: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 23 /* ic */
            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;
        73: .line 1963
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        74: .line 1971
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 24 /* skey */
        start local 24 // javax.crypto.SecretKey skey
        75: .line 1972
            aload 20 /* algOid */
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 25 /* cipher */
        start local 25 // javax.crypto.Cipher cipher
        76: .line 1973
            aload 25 /* cipher */
            iconst_2
            aload 24 /* skey */
            aload 21 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        77: .line 1974
            aload 25 /* cipher */
            aload 13 /* safeContentsData */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 13 /* safeContentsData */
        78: .line 1975
            goto 89
        end local 25 // javax.crypto.Cipher cipher
        end local 24 // javax.crypto.SecretKey skey
        79: .line 1976
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 24 /* e */
        start local 24 // java.lang.Exception e
        80: .line 1977
            aload 2 /* password */
            arraylength
            ifne 83
        81: .line 1980
            iconst_1
            newarray 5
            astore 2 /* password */
        82: .line 1981
            goto 74
        83: .line 1983
      StackMap locals: java.lang.Exception
      StackMap stack:
            new java.io.IOException
            dup
            ldc "keystore password was incorrect"
        84: .line 1984
            new java.security.UnrecoverableKeyException
            dup
        85: .line 1985
            new java.lang.StringBuilder
            dup
            ldc "failed to decrypt safe contents entry: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 24 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        86: .line 1984
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        87: .line 1983
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 24 // java.lang.Exception e
        end local 23 // int ic
        end local 21 // java.security.AlgorithmParameters algParams
        end local 20 // sun.security.util.ObjectIdentifier algOid
        end local 19 // sun.security.util.DerInputStream in
        end local 18 // byte newTag
        end local 17 // sun.security.util.DerValue[] seq
        end local 16 // sun.security.util.DerInputStream edi
        88: .line 1989
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int int byte[] sun.security.pkcs.ContentInfo sun.security.util.DerInputStream
      StackMap stack:
            new java.io.IOException
            dup
            ldc "public key protected PKCS12 not supported"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        89: .line 1992
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 13 /* safeContentsData */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 16 /* sc */
        start local 16 // sun.security.util.DerInputStream sc
        90: .line 1993
            aload 0 /* this */
            aload 16 /* sc */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.loadSafeContents:(Lsun/security/util/DerInputStream;[C)V
        end local 16 // sun.security.util.DerInputStream sc
        end local 15 // sun.security.util.DerInputStream sci
        end local 14 // sun.security.pkcs.ContentInfo safeContents
        end local 13 // byte[] safeContentsData
        91: .line 1897
      StackMap locals:
      StackMap stack:
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        92: iload 12 /* i */
            iload 11 /* count */
            if_icmplt 25
        end local 12 // int i
        93: .line 1997
            aload 2 /* password */
            ifnull 118
            aload 4 /* s */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifle 118
        94: .line 1998
            new sun.security.pkcs12.MacData
            dup
            aload 4 /* s */
            invokespecial sun.security.pkcs12.MacData.<init>:(Lsun/security/util/DerInputStream;)V
            astore 12 /* macData */
        start local 12 // sun.security.pkcs12.MacData macData
        95: .line 1999
            aload 12 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getIterations:()I
            istore 13 /* ic */
        start local 13 // int ic
        96: .line 2002
            iload 13 /* ic */
            ldc 5000000
            if_icmple 100
        97: .line 2003
            new java.security.InvalidAlgorithmParameterException
            dup
        98: .line 2004
            new java.lang.StringBuilder
            dup
            ldc "MAC iteration count too large: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 13 /* ic */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        99: .line 2003
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
       100: .line 2008
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.pkcs12.MacData int
      StackMap stack:
            aload 12 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getDigestAlgName:()Ljava/lang/String;
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toUpperCase:(Ljava/util/Locale;)Ljava/lang/String;
       101: .line 2007
            astore 14 /* algName */
        start local 14 // java.lang.String algName
       102: .line 2011
            aload 14 /* algName */
            ldc "-"
            ldc ""
            invokevirtual java.lang.String.replace:(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
            astore 14 /* algName */
       103: .line 2014
            new java.lang.StringBuilder
            dup
            ldc "HmacPBE"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 14 /* algName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;)Ljavax/crypto/Mac;
            astore 15 /* m */
        start local 15 // javax.crypto.Mac m
       104: .line 2016
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 12 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getSalt:()[B
            iload 13 /* ic */
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
       105: .line 2015
            astore 16 /* params */
        start local 16 // javax.crypto.spec.PBEParameterSpec params
       106: .line 2017
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 17 /* key */
        start local 17 // javax.crypto.SecretKey key
       107: .line 2018
            aload 15 /* m */
            aload 17 /* key */
            aload 16 /* params */
            invokevirtual javax.crypto.Mac.init:(Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
       108: .line 2019
            aload 15 /* m */
            aload 6 /* authSafeData */
            invokevirtual javax.crypto.Mac.update:([B)V
       109: .line 2020
            aload 15 /* m */
            invokevirtual javax.crypto.Mac.doFinal:()[B
            astore 18 /* macResult */
        start local 18 // byte[] macResult
       110: .line 2022
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 114
       111: .line 2023
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Checking keystore integrity ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
       112: .line 2024
            aload 15 /* m */
            invokevirtual javax.crypto.Mac.getAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " iterations: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 13 /* ic */
            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;
       113: .line 2023
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       114: .line 2027
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.pkcs12.MacData int java.lang.String javax.crypto.Mac javax.crypto.spec.PBEParameterSpec javax.crypto.SecretKey byte[]
      StackMap stack:
            aload 12 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getDigest:()[B
            aload 18 /* macResult */
            invokestatic java.security.MessageDigest.isEqual:([B[B)Z
            ifne 118
       115: .line 2028
            new java.security.UnrecoverableKeyException
            dup
            ldc "Failed PKCS12 integrity checking"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 18 // byte[] macResult
        end local 17 // javax.crypto.SecretKey key
        end local 16 // javax.crypto.spec.PBEParameterSpec params
        end local 15 // javax.crypto.Mac m
        end local 14 // java.lang.String algName
       116: .line 2031
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.pkcs12.MacData int
      StackMap stack: java.lang.Exception
            astore 14 /* e */
        start local 14 // java.lang.Exception e
       117: .line 2032
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Integrity check failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 14 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 14 /* e */
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 14 // java.lang.Exception e
        end local 13 // int ic
        end local 12 // sun.security.pkcs12.MacData macData
       118: .line 2040
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.size:()I
            anewarray sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[]
       119: .line 2039
            astore 12 /* list */
        start local 12 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] list
       120: .line 2041
            iconst_0
            istore 13 /* m */
        start local 13 // int m
       121: goto 149
       122: .line 2042
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] int
      StackMap stack:
            aload 12 /* list */
            iload 13 /* m */
            aaload
            astore 14 /* entry */
        start local 14 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
       123: .line 2043
            aload 14 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.keyId:[B
            ifnull 148
       124: .line 2045
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
       125: .line 2044
            astore 15 /* chain */
        start local 15 // java.util.ArrayList chain
       126: .line 2046
            aload 0 /* this */
            aload 14 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.findMatchedCertificate:(Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;)Ljava/security/cert/X509Certificate;
            astore 16 /* cert */
        start local 16 // java.security.cert.X509Certificate cert
       127: .line 2049
            goto 145
       128: .line 2051
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry java.util.ArrayList java.security.cert.X509Certificate
      StackMap stack:
            aload 15 /* chain */
            invokevirtual java.util.ArrayList.isEmpty:()Z
            ifne 140
       129: .line 2052
            aload 15 /* chain */
            invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
            astore 18
            goto 139
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] int sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry java.util.ArrayList java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
       130: aload 18
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 17 /* chainCert */
        start local 17 // java.security.cert.X509Certificate chainCert
       131: .line 2053
            aload 16 /* cert */
            aload 17 /* chainCert */
            invokevirtual java.security.cert.X509Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 139
       132: .line 2054
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 146
       133: .line 2055
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Loop detected in certificate chain. Skip adding repeated cert to chain. Subject: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
       134: .line 2058
            aload 16 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
       135: .line 2059
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
       136: .line 2058
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       137: .line 2055
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       138: .line 2061
            goto 146
        end local 17 // java.security.cert.X509Certificate chainCert
       139: .line 2052
      StackMap locals:
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 130
       140: .line 2065
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream char[] sun.security.util.DerValue sun.security.util.DerInputStream int byte[] sun.security.pkcs.ContentInfo sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue[] int sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] int sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry java.util.ArrayList java.security.cert.X509Certificate
      StackMap stack:
            aload 15 /* chain */
            aload 16 /* cert */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
       141: .line 2066
            aload 16 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 17 /* issuerDN */
        start local 17 // javax.security.auth.x500.X500Principal issuerDN
       142: .line 2067
            aload 17 /* issuerDN */
            aload 16 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifeq 144
       143: .line 2068
            goto 146
       144: .line 2070
      StackMap locals: javax.security.auth.x500.X500Principal
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            aload 17 /* issuerDN */
            invokevirtual java.util.LinkedHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 16 /* cert */
        end local 17 // javax.security.auth.x500.X500Principal issuerDN
       145: .line 2049
      StackMap locals:
      StackMap stack:
            aload 16 /* cert */
            ifnonnull 128
       146: .line 2073
      StackMap locals:
      StackMap stack:
            aload 15 /* chain */
            invokevirtual java.util.ArrayList.size:()I
            ifle 148
       147: .line 2074
            aload 14 /* entry */
            aload 15 /* chain */
            aload 15 /* chain */
            invokevirtual java.util.ArrayList.size:()I
            anewarray java.security.cert.Certificate
            invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.security.cert.Certificate[]
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
        end local 16 // java.security.cert.X509Certificate cert
        end local 15 // java.util.ArrayList chain
        end local 14 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
       148: .line 2041
      StackMap locals:
      StackMap stack:
            iinc 13 /* m */ 1
      StackMap locals:
      StackMap stack:
       149: iload 13 /* m */
            aload 12 /* list */
            arraylength
            if_icmplt 122
        end local 13 // int m
       150: .line 2078
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 163
       151: .line 2079
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            ifle 155
       152: .line 2080
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Loaded "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
       153: .line 2081
            ldc " protected private key(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       154: .line 2080
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       155: .line 2083
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            ifle 159
       156: .line 2084
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Loaded "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
       157: .line 2085
            ldc " protected secret key(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       158: .line 2084
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       159: .line 2087
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            ifle 163
       160: .line 2088
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Loaded "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
       161: .line 2089
            ldc " certificate(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       162: .line 2088
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       163: .line 2093
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
       164: .line 2094
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.clear:()V
       165: .line 2095
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
       166: .line 2096
            return
        end local 12 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] list
        end local 11 // int count
        end local 10 // sun.security.util.DerValue[] safeContentsArray
        end local 9 // sun.security.util.DerInputStream as
        end local 8 // sun.security.util.ObjectIdentifier contentType
        end local 7 // sun.security.pkcs.ContentInfo authSafe
        end local 6 // byte[] authSafeData
        end local 5 // int version
        end local 4 // sun.security.util.DerInputStream s
        end local 3 // sun.security.util.DerValue val
        end local 2 // char[] password
        end local 1 // java.io.InputStream stream
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0  167     0               this  Lsun/security/pkcs12/PKCS12KeyStore;
            0  167     1             stream  Ljava/io/InputStream;
            0  167     2           password  [C
            4  167     3                val  Lsun/security/util/DerValue;
            5  167     4                  s  Lsun/security/util/DerInputStream;
            6  167     5            version  I
           15   16     6       authSafeData  [B
           17  167     6       authSafeData  [B
           10  167     7           authSafe  Lsun/security/pkcs/ContentInfo;
           11  167     8        contentType  Lsun/security/util/ObjectIdentifier;
           18  167     9                 as  Lsun/security/util/DerInputStream;
           19  167    10  safeContentsArray  [Lsun/security/util/DerValue;
           20  167    11              count  I
           24   93    12                  i  I
           29   91    13   safeContentsData  [B
           27   91    14       safeContents  Lsun/security/pkcs/ContentInfo;
           26   91    15                sci  Lsun/security/util/DerInputStream;
           39   88    16                edi  Lsun/security/util/DerInputStream;
           41   88    17                seq  [Lsun/security/util/DerValue;
           50   88    18             newTag  B
           55   88    19                 in  Lsun/security/util/DerInputStream;
           56   88    20             algOid  Lsun/security/util/ObjectIdentifier;
           57   88    21          algParams  Ljava/security/AlgorithmParameters;
           61   62    22            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           66   69    22            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           58   88    23                 ic  I
           75   79    24               skey  Ljavax/crypto/SecretKey;
           76   79    25             cipher  Ljavax/crypto/Cipher;
           80   88    24                  e  Ljava/lang/Exception;
           90   91    16                 sc  Lsun/security/util/DerInputStream;
           95  118    12            macData  Lsun/security/pkcs12/MacData;
           96  118    13                 ic  I
          102  116    14            algName  Ljava/lang/String;
          104  116    15                  m  Ljavax/crypto/Mac;
          106  116    16             params  Ljavax/crypto/spec/PBEParameterSpec;
          107  116    17                key  Ljavax/crypto/SecretKey;
          110  116    18          macResult  [B
          117  118    14                  e  Ljava/lang/Exception;
          120  167    12               list  [Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
          121  150    13                  m  I
          123  148    14              entry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
          126  148    15              chain  Ljava/util/ArrayList<Ljava/security/cert/X509Certificate;>;
          127  148    16               cert  Ljava/security/cert/X509Certificate;
          131  139    17          chainCert  Ljava/security/cert/X509Certificate;
          142  145    17           issuerDN  Ljavax/security/auth/x500/X500Principal;
      Exception table:
        from    to  target  type
          59    61      62  Class java.security.spec.InvalidParameterSpecException
          74    78      79  Class java.lang.Exception
          96   116     116  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  private java.security.cert.X509Certificate findMatchedCertificate(sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry);
    descriptor: (Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;)Ljava/security/cert/X509Certificate;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=6, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
         0: .line 2104
            aconst_null
            astore 2 /* keyIdMatch */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$CertEntry keyIdMatch
         1: .line 2105
            aconst_null
            astore 3 /* aliasMatch */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$CertEntry aliasMatch
         2: .line 2106
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
            astore 5
            goto 10
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry top java.util.Iterator
      StackMap stack:
         3: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            astore 4 /* ce */
        start local 4 // sun.security.pkcs12.PKCS12KeyStore$CertEntry ce
         4: .line 2107
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.keyId:[B
            aload 4 /* ce */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.keyId:[B
            invokestatic java.util.Arrays.equals:([B[B)Z
            ifeq 8
         5: .line 2108
            aload 4 /* ce */
            astore 2 /* keyIdMatch */
         6: .line 2109
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.alias:Ljava/lang/String;
            aload 4 /* ce */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.alias:Ljava/lang/String;
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 10
         7: .line 2111
            aload 4 /* ce */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
         8: .line 2113
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry java.util.Iterator
      StackMap stack:
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.alias:Ljava/lang/String;
            aload 4 /* ce */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.alias:Ljava/lang/String;
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 10
         9: .line 2114
            aload 4 /* ce */
            astore 3 /* aliasMatch */
        end local 4 // sun.security.pkcs12.PKCS12KeyStore$CertEntry ce
        10: .line 2106
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry top java.util.Iterator
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        11: .line 2118
            aload 2 /* keyIdMatch */
            ifnull 12
            aload 2 /* keyIdMatch */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
        12: .line 2119
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry sun.security.pkcs12.PKCS12KeyStore$CertEntry
      StackMap stack:
            aload 3 /* aliasMatch */
            ifnull 13
            aload 3 /* aliasMatch */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
        13: .line 2120
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 3 // sun.security.pkcs12.PKCS12KeyStore$CertEntry aliasMatch
        end local 2 // sun.security.pkcs12.PKCS12KeyStore$CertEntry keyIdMatch
        end local 1 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0        this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   14     1       entry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
            1   14     2  keyIdMatch  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
            2   14     3  aliasMatch  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
            4   10     4          ce  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
    MethodParameters:
       Name  Flags
      entry  

  private void loadSafeContents(sun.security.util.DerInputStream, char[]);
    descriptor: (Lsun/security/util/DerInputStream;[C)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=23, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // sun.security.util.DerInputStream stream
        start local 2 // char[] password
         0: .line 2126
            aload 1 /* stream */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 3 /* safeBags */
        start local 3 // sun.security.util.DerValue[] safeBags
         1: .line 2127
            aload 3 /* safeBags */
            arraylength
            istore 4 /* count */
        start local 4 // int count
         2: .line 2132
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         3: goto 148
         4: .line 2136
      StackMap locals: sun.security.util.DerValue[] int int
      StackMap stack:
            aconst_null
            astore 9 /* bagItem */
        start local 9 // java.lang.Object bagItem
         5: .line 2138
            aload 3 /* safeBags */
            iload 5 /* i */
            aaload
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 7 /* sbi */
        start local 7 // sun.security.util.DerInputStream sbi
         6: .line 2139
            aload 7 /* sbi */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 6 /* bagId */
        start local 6 // sun.security.util.ObjectIdentifier bagId
         7: .line 2140
            aload 7 /* sbi */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 8 /* bagValue */
        start local 8 // sun.security.util.DerValue bagValue
         8: .line 2141
            aload 8 /* bagValue */
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 12
         9: .line 2142
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unsupported PKCS12 bag value type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        10: .line 2143
            aload 8 /* bagValue */
            getfield sun.security.util.DerValue.tag:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 2142
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 2145
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream char[] sun.security.util.DerValue[] int int sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue java.lang.Object
      StackMap stack:
            aload 8 /* bagValue */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 8 /* bagValue */
        13: .line 2146
            aload 6 /* bagId */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS8ShroudedKeyBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 19
        14: .line 2147
            new sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.<init>:()V
            astore 10 /* kEntry */
        start local 10 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry kEntry
        15: .line 2148
            aload 10 /* kEntry */
            aload 8 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        16: .line 2149
            aload 10 /* kEntry */
            astore 9 /* bagItem */
        17: .line 2150
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        end local 10 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry kEntry
        18: .line 2151
            goto 57
      StackMap locals:
      StackMap stack:
        19: aload 6 /* bagId */
            getstatic sun.security.pkcs12.PKCS12KeyStore.CertBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 37
        20: .line 2152
            new sun.security.util.DerInputStream
            dup
            aload 8 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 10 /* cs */
        start local 10 // sun.security.util.DerInputStream cs
        21: .line 2153
            aload 10 /* cs */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 11 /* certValues */
        start local 11 // sun.security.util.DerValue[] certValues
        22: .line 2154
            aload 11 /* certValues */
            arraylength
            iconst_2
            if_icmpeq 24
        23: .line 2155
            new java.io.IOException
            dup
            ldc "Invalid length for CertBag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        24: .line 2157
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 11 /* certValues */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        25: .line 2158
            aload 11 /* certValues */
            iconst_1
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 29
        26: .line 2159
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unsupported PKCS12 cert value type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        27: .line 2160
            aload 11 /* certValues */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.tag:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        28: .line 2159
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        29: .line 2162
      StackMap locals:
      StackMap stack:
            aload 11 /* certValues */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 12 /* certValue */
        start local 12 // sun.security.util.DerValue certValue
        30: .line 2163
            ldc "X509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 13 /* cf */
        start local 13 // java.security.cert.CertificateFactory cf
        31: .line 2165
            aload 13 /* cf */
        32: .line 2166
            new java.io.ByteArrayInputStream
            dup
            aload 12 /* certValue */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
        33: .line 2165
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
            astore 14 /* cert */
        start local 14 // java.security.cert.X509Certificate cert
        34: .line 2167
            aload 14 /* cert */
            astore 9 /* bagItem */
        35: .line 2168
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        end local 14 // java.security.cert.X509Certificate cert
        end local 13 // java.security.cert.CertificateFactory cf
        end local 12 // sun.security.util.DerValue certValue
        end local 11 // sun.security.util.DerValue[] certValues
        end local 10 // sun.security.util.DerInputStream cs
        36: .line 2169
            goto 57
      StackMap locals:
      StackMap stack:
        37: aload 6 /* bagId */
            getstatic sun.security.pkcs12.PKCS12KeyStore.SecretBag_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 55
        38: .line 2170
            new sun.security.util.DerInputStream
            dup
            aload 8 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 10 /* ss */
        start local 10 // sun.security.util.DerInputStream ss
        39: .line 2171
            aload 10 /* ss */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 11 /* secretValues */
        start local 11 // sun.security.util.DerValue[] secretValues
        40: .line 2172
            aload 11 /* secretValues */
            arraylength
            iconst_2
            if_icmpeq 42
        41: .line 2173
            new java.io.IOException
            dup
            ldc "Invalid length for SecretBag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        42: .line 2175
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 11 /* secretValues */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        43: .line 2176
            aload 11 /* secretValues */
            iconst_1
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 49
        44: .line 2177
            new java.io.IOException
            dup
        45: .line 2178
            new java.lang.StringBuilder
            dup
            ldc "unsupported PKCS12 secret value type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        46: .line 2179
            aload 11 /* secretValues */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.tag:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        47: .line 2178
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        48: .line 2177
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        49: .line 2181
      StackMap locals:
      StackMap stack:
            aload 11 /* secretValues */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 12 /* secretValue */
        start local 12 // sun.security.util.DerValue secretValue
        50: .line 2182
            new sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.<init>:()V
            astore 13 /* kEntry */
        start local 13 // sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry kEntry
        51: .line 2183
            aload 13 /* kEntry */
            aload 12 /* secretValue */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        52: .line 2184
            aload 13 /* kEntry */
            astore 9 /* bagItem */
        53: .line 2185
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        end local 13 // sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry kEntry
        end local 12 // sun.security.util.DerValue secretValue
        end local 11 // sun.security.util.DerValue[] secretValues
        end local 10 // sun.security.util.DerInputStream ss
        54: .line 2186
            goto 57
        55: .line 2188
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 57
        56: .line 2189
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Unsupported PKCS12 bag type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* bagId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        57: .line 2195
      StackMap locals:
      StackMap stack:
            aload 7 /* sbi */
            iconst_3
            invokevirtual sun.security.util.DerInputStream.getSet:(I)[Lsun/security/util/DerValue;
            astore 10 /* attrSet */
        start local 10 // sun.security.util.DerValue[] attrSet
        58: .line 2196
            goto 61
        end local 10 // sun.security.util.DerValue[] attrSet
      StackMap locals:
      StackMap stack: java.io.IOException
        59: pop
        60: .line 2200
            aconst_null
            astore 10 /* attrSet */
        start local 10 // sun.security.util.DerValue[] attrSet
        61: .line 2203
      StackMap locals: sun.security.util.DerValue[]
      StackMap stack:
            aconst_null
            astore 11 /* alias */
        start local 11 // java.lang.String alias
        62: .line 2204
            aconst_null
            astore 12 /* keyId */
        start local 12 // byte[] keyId
        63: .line 2205
            aconst_null
            astore 13 /* trustedKeyUsage */
        start local 13 // sun.security.util.ObjectIdentifier[] trustedKeyUsage
        64: .line 2206
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 14 /* attributes */
        start local 14 // java.util.Set attributes
        65: .line 2208
            aload 10 /* attrSet */
            ifnull 99
        66: .line 2209
            iconst_0
            istore 15 /* j */
        start local 15 // int j
        67: goto 98
        68: .line 2210
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream char[] sun.security.util.DerValue[] int int sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue java.lang.Object sun.security.util.DerValue[] java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set int
      StackMap stack:
            aload 10 /* attrSet */
            iload 15 /* j */
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            astore 16 /* encoded */
        start local 16 // byte[] encoded
        69: .line 2211
            new sun.security.util.DerInputStream
            dup
            aload 16 /* encoded */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 17 /* as */
        start local 17 // sun.security.util.DerInputStream as
        70: .line 2212
            aload 17 /* as */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 18 /* attrSeq */
        start local 18 // sun.security.util.DerValue[] attrSeq
        71: .line 2213
            aload 18 /* attrSeq */
            arraylength
            iconst_2
            if_icmpeq 73
        72: .line 2214
            new java.io.IOException
            dup
            ldc "Invalid length for Attribute"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        73: .line 2216
      StackMap locals: byte[] sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 18 /* attrSeq */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 19 /* attrId */
        start local 19 // sun.security.util.ObjectIdentifier attrId
        74: .line 2218
            new sun.security.util.DerInputStream
            dup
            aload 18 /* attrSeq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
        75: .line 2217
            astore 20 /* vs */
        start local 20 // sun.security.util.DerInputStream vs
        76: .line 2221
            aload 20 /* vs */
            iconst_1
            invokevirtual sun.security.util.DerInputStream.getSet:(I)[Lsun/security/util/DerValue;
            astore 21 /* valSet */
        start local 21 // sun.security.util.DerValue[] valSet
        77: .line 2222
            goto 82
        end local 21 // sun.security.util.DerValue[] valSet
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream char[] sun.security.util.DerValue[] int int sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue java.lang.Object sun.security.util.DerValue[] java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set int byte[] sun.security.util.DerInputStream sun.security.util.DerValue[] sun.security.util.ObjectIdentifier sun.security.util.DerInputStream
      StackMap stack: java.io.IOException
        78: astore 22 /* e */
        start local 22 // java.io.IOException e
        79: .line 2223
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Attribute "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 19 /* attrId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        80: .line 2224
            ldc " should have a value "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 22 /* e */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        81: .line 2223
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 22 // java.io.IOException e
        start local 21 // sun.security.util.DerValue[] valSet
        82: .line 2226
      StackMap locals: sun.security.util.DerValue[]
      StackMap stack:
            aload 19 /* attrId */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9FriendlyName_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 85
        83: .line 2227
            aload 21 /* valSet */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getBMPString:()Ljava/lang/String;
            astore 11 /* alias */
        84: .line 2228
            goto 97
      StackMap locals:
      StackMap stack:
        85: aload 19 /* attrId */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS9LocalKeyId_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 88
        86: .line 2229
            aload 21 /* valSet */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            astore 12 /* keyId */
        87: .line 2230
            goto 97
        88: .line 2231
      StackMap locals:
      StackMap stack:
            aload 19 /* attrId */
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 96
        89: .line 2232
            aload 21 /* valSet */
            arraylength
            anewarray sun.security.util.ObjectIdentifier
            astore 13 /* trustedKeyUsage */
        90: .line 2233
            iconst_0
            istore 22 /* k */
        start local 22 // int k
        91: goto 94
        92: .line 2234
      StackMap locals: int
      StackMap stack:
            aload 13 /* trustedKeyUsage */
            iload 22 /* k */
            aload 21 /* valSet */
            iload 22 /* k */
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            aastore
        93: .line 2233
            iinc 22 /* k */ 1
      StackMap locals:
      StackMap stack:
        94: iload 22 /* k */
            aload 21 /* valSet */
            arraylength
            if_icmplt 92
        end local 22 // int k
        95: .line 2236
            goto 97
        96: .line 2238
      StackMap locals:
      StackMap stack:
            aload 14 /* attributes */
            new sun.security.pkcs12.PKCS12Attribute
            dup
            aload 16 /* encoded */
            invokespecial sun.security.pkcs12.PKCS12Attribute.<init>:([B)V
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 21 // sun.security.util.DerValue[] valSet
        end local 20 // sun.security.util.DerInputStream vs
        end local 19 // sun.security.util.ObjectIdentifier attrId
        end local 18 // sun.security.util.DerValue[] attrSeq
        end local 17 // sun.security.util.DerInputStream as
        end local 16 // byte[] encoded
        97: .line 2209
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream char[] sun.security.util.DerValue[] int int sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue java.lang.Object sun.security.util.DerValue[] java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set int
      StackMap stack:
            iinc 15 /* j */ 1
      StackMap locals:
      StackMap stack:
        98: iload 15 /* j */
            aload 10 /* attrSet */
            arraylength
            if_icmplt 68
        end local 15 // int j
        99: .line 2252
      StackMap locals:
      StackMap stack:
            aload 9 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 128
       100: .line 2253
            aload 9 /* bagItem */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 15 /* entry */
        start local 15 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry entry
       101: .line 2255
            aload 9 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 105
       102: .line 2256
            aload 12 /* keyId */
            ifnonnull 105
       103: .line 2261
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            if_icmpne 147
       104: .line 2262
            ldc "01"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 12 /* keyId */
       105: .line 2268
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$KeyEntry
      StackMap stack:
            aload 15 /* entry */
            aload 12 /* keyId */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.keyId:[B
       106: .line 2270
            new java.lang.String
            dup
            aload 12 /* keyId */
            ldc "UTF8"
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            astore 16 /* keyIdStr */
        start local 16 // java.lang.String keyIdStr
       107: .line 2271
            aconst_null
            astore 17 /* date */
        start local 17 // java.util.Date date
       108: .line 2272
            aload 16 /* keyIdStr */
            ldc "Time "
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 115
       109: .line 2274
            new java.util.Date
            dup
       110: .line 2275
            aload 16 /* keyIdStr */
            iconst_5
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic java.lang.Long.parseLong:(Ljava/lang/String;)J
       111: .line 2274
            invokespecial java.util.Date.<init>:(J)V
            astore 17 /* date */
       112: .line 2276
            goto 115
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream char[] sun.security.util.DerValue[] int int sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue java.lang.Object sun.security.util.DerValue[] java.lang.String byte[] sun.security.util.ObjectIdentifier[] java.util.Set sun.security.pkcs12.PKCS12KeyStore$KeyEntry java.lang.String java.util.Date
      StackMap stack: java.lang.Exception
       113: pop
       114: .line 2277
            aconst_null
            astore 17 /* date */
       115: .line 2280
      StackMap locals:
      StackMap stack:
            aload 17 /* date */
            ifnonnull 117
       116: .line 2281
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 17 /* date */
       117: .line 2283
      StackMap locals:
      StackMap stack:
            aload 15 /* entry */
            aload 17 /* date */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.date:Ljava/util/Date;
       118: .line 2285
            aload 9 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 120
       119: .line 2286
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
            aload 15 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
       120: .line 2288
      StackMap locals:
      StackMap stack:
            aload 15 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
            ifnonnull 122
       121: .line 2289
            aload 15 /* entry */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
       122: .line 2291
      StackMap locals:
      StackMap stack:
            aload 15 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
            aload 14 /* attributes */
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
       123: .line 2292
            aload 11 /* alias */
            ifnonnull 125
       124: .line 2293
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getUnfriendlyName:()Ljava/lang/String;
            astore 11 /* alias */
       125: .line 2295
      StackMap locals:
      StackMap stack:
            aload 15 /* entry */
            aload 11 /* alias */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.alias:Ljava/lang/String;
       126: .line 2296
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 11 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            aload 15 /* entry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 17 // java.util.Date date
        end local 16 // java.lang.String keyIdStr
        end local 15 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry entry
       127: .line 2298
            goto 147
      StackMap locals:
      StackMap stack:
       128: aload 9 /* bagItem */
            instanceof java.security.cert.X509Certificate
            ifeq 147
       129: .line 2299
            aload 9 /* bagItem */
            checkcast java.security.cert.X509Certificate
            astore 15 /* cert */
        start local 15 // java.security.cert.X509Certificate cert
       130: .line 2304
            aload 12 /* keyId */
            ifnonnull 133
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            if_icmpne 133
       131: .line 2306
            iload 5 /* i */
            ifne 133
       132: .line 2307
            ldc "01"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 12 /* keyId */
       133: .line 2311
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 13 /* trustedKeyUsage */
            ifnull 142
       134: .line 2312
            aload 11 /* alias */
            ifnonnull 136
       135: .line 2313
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getUnfriendlyName:()Ljava/lang/String;
            astore 11 /* alias */
       136: .line 2316
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs12.PKCS12KeyStore$CertEntry
            dup
            aload 15 /* cert */
            aload 12 /* keyId */
            aload 11 /* alias */
            aload 13 /* trustedKeyUsage */
       137: .line 2317
            aload 14 /* attributes */
       138: .line 2316
            invokespecial sun.security.pkcs12.PKCS12KeyStore$CertEntry.<init>:(Ljava/security/cert/X509Certificate;[BLjava/lang/String;[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)V
       139: .line 2315
            astore 16 /* certEntry */
        start local 16 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
       140: .line 2318
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 11 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            aload 16 /* certEntry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 16 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
       141: .line 2319
            goto 143
       142: .line 2320
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
            new sun.security.pkcs12.PKCS12KeyStore$CertEntry
            dup
            aload 15 /* cert */
            aload 12 /* keyId */
            aload 11 /* alias */
            invokespecial sun.security.pkcs12.PKCS12KeyStore$CertEntry.<init>:(Ljava/security/cert/X509Certificate;[BLjava/lang/String;)V
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
       143: .line 2322
      StackMap locals:
      StackMap stack:
            aload 15 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 16 /* subjectDN */
        start local 16 // javax.security.auth.x500.X500Principal subjectDN
       144: .line 2323
            aload 16 /* subjectDN */
            ifnull 147
       145: .line 2324
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            aload 16 /* subjectDN */
            invokevirtual java.util.LinkedHashMap.containsKey:(Ljava/lang/Object;)Z
            ifne 147
       146: .line 2325
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            aload 16 /* subjectDN */
            aload 15 /* cert */
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 16 // javax.security.auth.x500.X500Principal subjectDN
        end local 15 // java.security.cert.X509Certificate cert
        end local 14 // java.util.Set attributes
        end local 13 // sun.security.util.ObjectIdentifier[] trustedKeyUsage
        end local 12 // byte[] keyId
        end local 11 // java.lang.String alias
        end local 10 // sun.security.util.DerValue[] attrSet
        end local 9 // java.lang.Object bagItem
        end local 8 // sun.security.util.DerValue bagValue
        end local 7 // sun.security.util.DerInputStream sbi
        end local 6 // sun.security.util.ObjectIdentifier bagId
       147: .line 2132
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream char[] sun.security.util.DerValue[] int int
      StackMap stack:
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
       148: iload 5 /* i */
            iload 4 /* count */
            if_icmplt 4
        end local 5 // int i
       149: .line 2330
            return
        end local 4 // int count
        end local 3 // sun.security.util.DerValue[] safeBags
        end local 2 // char[] password
        end local 1 // sun.security.util.DerInputStream stream
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0  150     0             this  Lsun/security/pkcs12/PKCS12KeyStore;
            0  150     1           stream  Lsun/security/util/DerInputStream;
            0  150     2         password  [C
            1  150     3         safeBags  [Lsun/security/util/DerValue;
            2  150     4            count  I
            3  149     5                i  I
            7  147     6            bagId  Lsun/security/util/ObjectIdentifier;
            6  147     7              sbi  Lsun/security/util/DerInputStream;
            8  147     8         bagValue  Lsun/security/util/DerValue;
            5  147     9          bagItem  Ljava/lang/Object;
           15   18    10           kEntry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
           21   36    10               cs  Lsun/security/util/DerInputStream;
           22   36    11       certValues  [Lsun/security/util/DerValue;
           30   36    12        certValue  Lsun/security/util/DerValue;
           31   36    13               cf  Ljava/security/cert/CertificateFactory;
           34   36    14             cert  Ljava/security/cert/X509Certificate;
           39   54    10               ss  Lsun/security/util/DerInputStream;
           40   54    11     secretValues  [Lsun/security/util/DerValue;
           50   54    12      secretValue  Lsun/security/util/DerValue;
           51   54    13           kEntry  Lsun/security/pkcs12/PKCS12KeyStore$SecretKeyEntry;
           58   59    10          attrSet  [Lsun/security/util/DerValue;
           61  147    10          attrSet  [Lsun/security/util/DerValue;
           62  147    11            alias  Ljava/lang/String;
           63  147    12            keyId  [B
           64  147    13  trustedKeyUsage  [Lsun/security/util/ObjectIdentifier;
           65  147    14       attributes  Ljava/util/Set<Lsun/security/pkcs12/PKCS12Attribute;>;
           67   99    15                j  I
           69   97    16          encoded  [B
           70   97    17               as  Lsun/security/util/DerInputStream;
           71   97    18          attrSeq  [Lsun/security/util/DerValue;
           74   97    19           attrId  Lsun/security/util/ObjectIdentifier;
           76   97    20               vs  Lsun/security/util/DerInputStream;
           77   78    21           valSet  [Lsun/security/util/DerValue;
           82   97    21           valSet  [Lsun/security/util/DerValue;
           79   82    22                e  Ljava/io/IOException;
           91   95    22                k  I
          101  127    15            entry  Lsun/security/pkcs12/PKCS12KeyStore$KeyEntry;
          107  127    16         keyIdStr  Ljava/lang/String;
          108  127    17             date  Ljava/util/Date;
          130  147    15             cert  Ljava/security/cert/X509Certificate;
          140  141    16        certEntry  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
          144  147    16        subjectDN  Ljavax/security/auth/x500/X500Principal;
      Exception table:
        from    to  target  type
          57    58      59  Class java.io.IOException
          76    77      78  Class java.io.IOException
         109   112     113  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  private java.lang.String getUnfriendlyName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
         0: .line 2333
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.counter:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         1: .line 2334
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.counter:I
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            areturn
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/pkcs12/PKCS12KeyStore;
}
SourceFile: "PKCS12KeyStore.java"
NestMembers:
  sun.security.pkcs12.PKCS12KeyStore$CertEntry  sun.security.pkcs12.PKCS12KeyStore$Entry  sun.security.pkcs12.PKCS12KeyStore$KeyEntry  sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry  sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
InnerClasses:
  public abstract Entry = java.security.KeyStore$Entry of java.security.KeyStore
  public PasswordProtection = java.security.KeyStore$PasswordProtection of java.security.KeyStore
  public final PrivateKeyEntry = java.security.KeyStore$PrivateKeyEntry of java.security.KeyStore
  public abstract ProtectionParameter = java.security.KeyStore$ProtectionParameter of java.security.KeyStore
  public final SecretKeyEntry = java.security.KeyStore$SecretKeyEntry of java.security.KeyStore
  public final TrustedCertificateEntry = java.security.KeyStore$TrustedCertificateEntry of java.security.KeyStore
  private CertEntry = sun.security.pkcs12.PKCS12KeyStore$CertEntry of sun.security.pkcs12.PKCS12KeyStore
  private Entry = sun.security.pkcs12.PKCS12KeyStore$Entry of sun.security.pkcs12.PKCS12KeyStore
  private KeyEntry = sun.security.pkcs12.PKCS12KeyStore$KeyEntry of sun.security.pkcs12.PKCS12KeyStore
  private PrivateKeyEntry = sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry of sun.security.pkcs12.PKCS12KeyStore
  private SecretKeyEntry = sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry of sun.security.pkcs12.PKCS12KeyStore