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 java.lang.String[] KEY_PROTECTION_ALGORITHM;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  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[] pbes2;
    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 pbes2_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;>;

  private static final long[][] PKCS12_HEADER_PATTERNS;
    descriptor: [[J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final long[][] PKCS12_HEADER_MASKS;
    descriptor: [[J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=8, locals=0, args_size=0
         0: .line 146
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
         1: .line 147
            ldc "keystore.pkcs12.keyProtectionAlgorithm"
            aastore
            dup
            iconst_1
         2: .line 148
            ldc "keystore.PKCS12.keyProtectionAlgorithm"
            aastore
         3: .line 146
            putstatic sun.security.pkcs12.PKCS12KeyStore.KEY_PROTECTION_ALGORITHM:[Ljava/lang/String;
         4: .line 157
            iconst_3
            anewarray java.lang.String
            dup
            iconst_0
         5: .line 158
            ldc "1.2.840.113549.1.9.20"
            aastore
            dup
            iconst_1
         6: .line 159
            ldc "1.2.840.113549.1.9.21"
            aastore
            dup
            iconst_2
         7: .line 160
            ldc "2.16.840.1.113894.746875.1.1"
            aastore
         8: .line 157
            putstatic sun.security.pkcs12.PKCS12KeyStore.CORE_ATTRIBUTES:[Ljava/lang/String;
         9: .line 163
            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;
        10: .line 165
            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
        11: .line 166
            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
        12: .line 167
            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
        13: .line 169
            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
        14: .line 170
            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
        15: .line 172
            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
        16: .line 175
            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
        17: .line 174
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd40BitRC2CBC:[I
        18: .line 177
            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
        19: .line 176
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd3KeyTripleDESCBC:[I
        20: .line 178
            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
            iconst_5
            iastore
            dup
            bipush 6
            bipush 13
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbes2:[I
        21: .line 185
            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
        22: .line 184
            putstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage:[I
        23: .line 186
            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
        24: .line 218
            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;
        25: .line 219
            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;
        26: .line 220
            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;
        27: .line 221
            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;
        28: .line 222
            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;
        29: .line 223
            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;
        30: .line 225
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd40BitRC2CBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
        31: .line 224
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd40BitRC2CBC_OID:Lsun/security/util/ObjectIdentifier;
        32: .line 227
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd3KeyTripleDESCBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
        33: .line 226
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbeWithSHAAnd3KeyTripleDESCBC_OID:Lsun/security/util/ObjectIdentifier;
        34: .line 228
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbes2:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic sun.security.pkcs12.PKCS12KeyStore.pbes2_OID:Lsun/security/util/ObjectIdentifier;
        35: .line 229
            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;
        36: .line 230
            iconst_1
            anewarray sun.security.util.ObjectIdentifier
            dup
            iconst_0
        37: .line 231
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.AnyExtendedKeyUsage:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            aastore
        38: .line 230
            putstatic sun.security.pkcs12.PKCS12KeyStore.AnyUsage:[Lsun/security/util/ObjectIdentifier;
        39: .line 232
            goto 41
      StackMap locals:
      StackMap stack: java.io.IOException
        40: pop
        41: .line 2454
      StackMap locals:
      StackMap stack:
            bipush 8
            anewarray long[]
            dup
            iconst_0
        42: .line 2455
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495356260826546992
            lastore
            dup
            iconst_1
            ldc -9079256822855334328
            lastore
            dup
            iconst_2
            ldc -8721487855316000640
            lastore
            aastore
            dup
            iconst_1
        43: .line 2456
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3458766717192241158
            lastore
            dup
            iconst_1
            ldc 660487941423303937
            lastore
            dup
            iconst_2
            ldc 504860555169759232
            lastore
            aastore
            dup
            iconst_2
        44: .line 2457
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495074794423136385
            lastore
            dup
            iconst_1
            ldc 1698928106440439
            lastore
            dup
            iconst_2
            ldc 937037901038944260
            lastore
            aastore
            dup
            iconst_3
        45: .line 2458
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495356260826546992
            lastore
            dup
            iconst_1
            ldc -9151307806378932090
            lastore
            dup
            iconst_2
            ldc -644858042040418048
            lastore
            aastore
            dup
            iconst_4
        46: .line 2459
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495637735769768195
            lastore
            dup
            iconst_1
            ldc 3495356260894190214
            lastore
            dup
            iconst_2
            ldc 5226136052833911200
            lastore
            aastore
            dup
            iconst_5
        47: .line 2460
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495637735769768195
            lastore
            dup
            iconst_1
            ldc 3495637735770032426
            lastore
            dup
            iconst_2
            ldc -8770611878670825727
            lastore
            aastore
            dup
            bipush 6
        48: .line 2461
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495919210746348033
            lastore
            dup
            iconst_1
            ldc 229827617019135497
            lastore
            dup
            iconst_2
            ldc 3064216340979843335
            lastore
            aastore
            dup
            bipush 7
        49: .line 2462
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495919210746348033
            lastore
            dup
            iconst_1
            ldc 229828716530761734
            lastore
            dup
            iconst_2
            ldc 660487941423303937
            lastore
            aastore
        50: .line 2454
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
        51: .line 2465
            bipush 8
            anewarray long[]
            dup
            iconst_0
        52: .line 2466
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -281470681743361
            lastore
            dup
            iconst_1
            ldc -72056494526300161
            lastore
            dup
            iconst_2
            ldc -16
            lastore
            aastore
            dup
            iconst_1
        53: .line 2467
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -71776119061282561
            lastore
            dup
            iconst_1
            ldc -1
            lastore
            dup
            iconst_2
            ldc -1095233437696
            lastore
            aastore
            dup
            iconst_2
        54: .line 2468
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -280375465082881
            lastore
            dup
            iconst_1
            ldc 72057594037927935
            lastore
            dup
            iconst_2
            ldc -65281
            lastore
            aastore
            dup
            iconst_3
        55: .line 2469
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -281470681743361
            lastore
            dup
            iconst_1
            ldc -71776119061217281
            lastore
            dup
            iconst_2
            ldc -256
            lastore
            aastore
            dup
            iconst_4
        56: .line 2470
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -281474959933441
            lastore
            dup
            iconst_1
            ldc -281470681743361
            lastore
            dup
            iconst_2
            ldc -1
            lastore
            aastore
            dup
            iconst_5
        57: .line 2471
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -281474959933441
            lastore
            dup
            iconst_1
            ldc -281474959933441
            lastore
            dup
            iconst_2
            ldc -1
            lastore
            aastore
            dup
            bipush 6
        58: .line 2472
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -281474976645121
            lastore
            dup
            iconst_1
            ldc -1099511562241
            lastore
            dup
            iconst_2
            ldc -1
            lastore
            aastore
            dup
            bipush 7
        59: .line 2473
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -281474976645121
            lastore
            dup
            iconst_1
            ldc -1099511627521
            lastore
            dup
            iconst_2
            ldc -1
            lastore
            aastore
        60: .line 2465
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
        61: .line 2474
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
          24    39      40  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 135
            aload 0 /* this */
            invokespecial java.security.KeyStoreSpi.<init>:()V
         1: .line 200
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         2: .line 205
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
         3: .line 208
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
         4: .line 211
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
         5: .line 288
            aload 0 /* this */
         6: .line 289
            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 291
            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 292
            aload 0 /* this */
         9: .line 293
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
        10: .line 294
            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 135
            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 314
            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 315
            aconst_null
            astore 4 /* key */
        start local 4 // java.security.Key key
         2: .line 317
            aload 3 /* entry */
            ifnull 3
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifne 4
         3: .line 318
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key
      StackMap stack:
            aconst_null
            areturn
         4: .line 322
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 5 /* encrBytes */
        start local 5 // byte[] encrBytes
         5: .line 323
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 8
         6: .line 324
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
            astore 5 /* encrBytes */
         7: .line 325
            goto 12
      StackMap locals: byte[]
      StackMap stack:
         8: aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 11
         9: .line 326
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
            astore 5 /* encrBytes */
        10: .line 327
            goto 12
        11: .line 328
      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 338
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 5 /* encrBytes */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
        13: .line 337
            astore 9 /* encrInfo */
        start local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        14: .line 339
            aload 9 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncryptedData:()[B
            astore 6 /* encryptedKey */
        start local 6 // byte[] encryptedKey
        15: .line 342
            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 343
            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 344
            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 345
            aload 0 /* this */
            aload 8 /* algOid */
            aload 11 /* in */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.parseAlgParameters:(Lsun/security/util/ObjectIdentifier;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 347
            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 349
            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 350
            aload 9 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        23: .line 349
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        24: .line 348
            astore 10 /* uke */
        start local 10 // java.security.UnrecoverableKeyException uke
        25: .line 351
            aload 10 /* uke */
            aload 9 /* ioe */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        26: .line 352
            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 357
      StackMap locals: byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier
      StackMap stack:
            iconst_0
            istore 10 /* ic */
        start local 10 // int ic
        28: .line 359
            aload 7 /* algParams */
            ifnull 37
        29: .line 362
            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 361
            astore 9 /* pbeSpec */
        start local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
        31: .line 363
            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 364
            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 366
      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 368
            iload 10 /* ic */
            ldc 5000000
            if_icmple 37
        36: .line 369
            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 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
      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 379
            aload 8 /* algOid */
            aload 7 /* algParams */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEParamsToAlgorithm:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
        39: .line 378
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 13 /* cipher */
        start local 13 // javax.crypto.Cipher cipher
        40: .line 380
            aload 13 /* cipher */
            iconst_2
            aload 12 /* skey */
            aload 7 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        41: .line 381
            aload 13 /* cipher */
            aload 6 /* encryptedKey */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 11 /* keyInfo */
        start local 11 // byte[] keyInfo
        42: .line 382
            goto 48
        end local 13 // javax.crypto.Cipher cipher
        end local 12 // javax.crypto.SecretKey skey
        end local 11 // byte[] keyInfo
        43: .line 383
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 12 /* e */
        start local 12 // java.lang.Exception e
        44: .line 384
            aload 2 /* password */
            arraylength
            ifne 47
        45: .line 387
            iconst_1
            newarray 5
            astore 2 /* password */
        46: .line 388
            goto 37
        47: .line 390
      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
        48: .line 398
      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
        49: .line 399
            aload 12 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 13 /* in */
        start local 13 // sun.security.util.DerInputStream in
        50: .line 400
            aload 13 /* in */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
        51: .line 401
            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
        52: .line 402
            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
        53: .line 403
            aload 15 /* algId */
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            astore 16 /* keyAlgo */
        start local 16 // java.lang.String keyAlgo
        54: .line 406
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 65
        55: .line 407
            aload 16 /* keyAlgo */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 17 /* kfac */
        start local 17 // java.security.KeyFactory kfac
        56: .line 408
            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
        57: .line 409
            aload 17 /* kfac */
            aload 18 /* kspec */
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
            astore 4 /* key */
        58: .line 411
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 90
        59: .line 412
            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
        60: .line 413
            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;
        61: .line 414
            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;
        62: .line 415
            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;
        63: .line 412
            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
        64: .line 419
            goto 90
        65: .line 420
      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[] sun.security.util.DerValue sun.security.util.DerInputStream sun.security.util.DerValue[] 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
        66: .line 422
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 17 /* keyBytes */
            aload 16 /* keyAlgo */
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
        67: .line 421
            astore 18 /* secretKeySpec */
        start local 18 // javax.crypto.spec.SecretKeySpec secretKeySpec
        68: .line 425
            aload 16 /* keyAlgo */
            ldc "PBE"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 75
        69: .line 427
            aload 16 /* keyAlgo */
            invokestatic javax.crypto.SecretKeyFactory.getInstance:(Ljava/lang/String;)Ljavax/crypto/SecretKeyFactory;
        70: .line 426
            astore 19 /* sKeyFactory */
        start local 19 // javax.crypto.SecretKeyFactory sKeyFactory
        71: .line 429
            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;
        72: .line 428
            astore 20 /* pbeKeySpec */
        start local 20 // java.security.spec.KeySpec pbeKeySpec
        73: .line 430
            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
        74: .line 431
            goto 76
        75: .line 432
      StackMap locals: byte[] javax.crypto.spec.SecretKeySpec
      StackMap stack:
            aload 18 /* secretKeySpec */
            astore 4 /* key */
        76: .line 435
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 90
        77: .line 436
            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
        78: .line 437
            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;
        79: .line 438
            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;
        80: .line 439
            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;
        81: .line 436
            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
        82: .line 442
            goto 90
      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
        83: astore 9 /* e */
        start local 9 // java.lang.Exception e
        84: .line 444
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Get Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        85: .line 445
            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;
        86: .line 444
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        87: .line 443
            astore 10 /* uke */
        start local 10 // java.security.UnrecoverableKeyException uke
        88: .line 446
            aload 10 /* uke */
            aload 9 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        89: .line 447
            aload 10 /* uke */
            athrow
        end local 10 // java.security.UnrecoverableKeyException uke
        end local 9 // java.lang.Exception e
        90: .line 449
      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   91     0           this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   91     1          alias  Ljava/lang/String;
            0   91     2       password  [C
            1   91     3          entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            2   91     4            key  Ljava/security/Key;
            5   91     5      encrBytes  [B
           15   20     6   encryptedKey  [B
           27   91     6   encryptedKey  [B
           19   20     7      algParams  Ljava/security/AlgorithmParameters;
           27   91     7      algParams  Ljava/security/AlgorithmParameters;
           18   20     8         algOid  Lsun/security/util/ObjectIdentifier;
           27   91     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   82    10             ic  I
           42   43    11        keyInfo  [B
           48   82    11        keyInfo  [B
           38   43    12           skey  Ljavax/crypto/SecretKey;
           40   43    13         cipher  Ljavax/crypto/Cipher;
           44   48    12              e  Ljava/lang/Exception;
           49   82    12            val  Lsun/security/util/DerValue;
           50   82    13             in  Lsun/security/util/DerInputStream;
           52   82    14          value  [Lsun/security/util/DerValue;
           53   82    15          algId  Lsun/security/x509/AlgorithmId;
           54   82    16        keyAlgo  Ljava/lang/String;
           56   64    17           kfac  Ljava/security/KeyFactory;
           57   64    18          kspec  Ljava/security/spec/PKCS8EncodedKeySpec;
           66   82    17       keyBytes  [B
           68   82    18  secretKeySpec  Ljavax/crypto/spec/SecretKeySpec;
           71   74    19    sKeyFactory  Ljavax/crypto/SecretKeyFactory;
           73   74    20     pbeKeySpec  Ljava/security/spec/KeySpec;
           84   90     9              e  Ljava/lang/Exception;
           88   90    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    42      43  Class java.lang.Exception
          27    82      83  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 464
            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 465
            aload 2 /* entry */
            ifnull 10
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 10
         2: .line 466
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 4
         3: .line 467
            aconst_null
            areturn
         4: .line 470
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 9
         5: .line 471
            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 472
            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 473
            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 471
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         9: .line 476
      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 479
      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 499
            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 500
            aload 2 /* entry */
            ifnonnull 3
         2: .line 501
            aconst_null
            areturn
         3: .line 503
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 18
         4: .line 504
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 18
         5: .line 506
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 17
         6: .line 507
            getstatic sun.security.pkcs12.PKCS12KeyStore.AnyUsage:[Lsun/security/util/ObjectIdentifier;
         7: .line 508
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
         8: .line 507
            invokestatic java.util.Arrays.equals:([Ljava/lang/Object;[Ljava/lang/Object;)Z
         9: .line 508
            ifeq 14
        10: .line 509
            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 510
            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 509
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 511
            goto 17
        14: .line 512
      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 513
            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 512
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        17: .line 517
      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 519
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 26
        19: .line 520
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 21
        20: .line 521
            aconst_null
            areturn
        21: .line 524
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 25
        22: .line 525
            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 526
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        24: .line 525
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        25: .line 529
      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 533
      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 546
            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 547
            aload 2 /* entry */
            ifnull 3
         2: .line 548
            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 550
      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=7, 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 581
            new java.security.KeyStore$PasswordProtection
            dup
            aload 3 /* password */
            invokespecial java.security.KeyStore$PasswordProtection.<init>:([C)V
         1: .line 580
            astore 5 /* passwordProtection */
        start local 5 // java.security.KeyStore$PasswordProtection passwordProtection
         2: .line 584
            aload 0 /* this */
            aload 1 /* alias */
            aload 2 /* key */
            aload 5 /* passwordProtection */
            aload 4 /* chain */
            aconst_null
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setKeyEntry:(Ljava/lang/String;Ljava/security/Key;Ljava/security/KeyStore$PasswordProtection;[Ljava/security/cert/Certificate;Ljava/util/Set;)V
         3: .line 586
            goto 9
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.security.KeyStore$PasswordProtection
      StackMap stack: java.lang.Throwable
         4: astore 6
         5: .line 588
            aload 5 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.destroy:()V
         6: .line 589
            goto 8
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key char[] java.security.cert.Certificate[] java.security.KeyStore$PasswordProtection java.lang.Throwable
      StackMap stack: javax.security.auth.DestroyFailedException
         7: pop
         8: .line 592
      StackMap locals:
      StackMap stack:
            aload 6
            athrow
         9: .line 588
      StackMap locals:
      StackMap stack:
            aload 5 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.destroy:()V
        10: .line 589
            goto 12
      StackMap locals:
      StackMap stack: javax.security.auth.DestroyFailedException
        11: pop
        12: .line 593
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.security.KeyStore$PasswordProtection passwordProtection
        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   13     0                this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   13     1               alias  Ljava/lang/String;
            0   13     2                 key  Ljava/security/Key;
            0   13     3            password  [C
            0   13     4               chain  [Ljava/security/cert/Certificate;
            2   13     5  passwordProtection  Ljava/security/KeyStore$PasswordProtection;
      Exception table:
        from    to  target  type
           2     4       4  any
           5     6       7  Class javax.security.auth.DestroyFailedException
           9    10      11  Class javax.security.auth.DestroyFailedException
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
          Name  Flags
      alias     
      key       
      password  
      chain     

  private void setKeyEntry(java.lang.String, java.security.Key, java.security.KeyStore$PasswordProtection, java.security.cert.Certificate[], java.util.Set<java.security.KeyStore$Entry$Attribute>);
    descriptor: (Ljava/lang/String;Ljava/security/Key;Ljava/security/KeyStore$PasswordProtection;[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 // java.security.KeyStore$PasswordProtection passwordProtection
        start local 4 // java.security.cert.Certificate[] chain
        start local 5 // java.util.Set attributes
         0: .line 606
            aload 2 /* key */
            instanceof java.security.PrivateKey
            ifeq 29
         1: .line 608
            aload 4 /* chain */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.checkX509Certs:([Ljava/security/cert/Certificate;)V
         2: .line 610
            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
         3: .line 611
            aload 7 /* keyEntry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.date:Ljava/util/Date;
         4: .line 613
            aload 2 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            ldc "PKCS#8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
         5: .line 614
            aload 2 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            ldc "PKCS8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 16
         6: .line 616
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key java.security.KeyStore$PasswordProtection 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 12
         7: .line 617
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
         8: .line 618
            new java.lang.StringBuilder
            dup
            ldc "Setting a protected private key at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         9: .line 619
            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;
        10: .line 618
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 617
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 623
      StackMap locals:
      StackMap stack:
            aload 7 /* keyEntry */
        13: .line 624
            aload 0 /* this */
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            aload 3 /* passwordProtection */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.encryptPrivateKey:([BLjava/security/KeyStore$PasswordProtection;)[B
        14: .line 623
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        15: .line 625
            goto 17
        16: .line 626
      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
        17: .line 631
      StackMap locals:
      StackMap stack:
            aload 4 /* chain */
            ifnull 26
        18: .line 633
            aload 4 /* chain */
            arraylength
            iconst_1
            if_icmple 20
            aload 0 /* this */
            aload 4 /* chain */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.validateChain:([Ljava/security/cert/Certificate;)Z
            ifne 20
        19: .line 634
            new java.security.KeyStoreException
            dup
            ldc "Certificate chain is not valid"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 636
      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;
        21: .line 637
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            aload 4 /* chain */
            arraylength
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        22: .line 639
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 26
        23: .line 640
            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;
        24: .line 641
            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 640
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        26: .line 644
      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 645
            aload 7 /* keyEntry */
            astore 6 /* entry */
        end local 7 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
        start local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        28: .line 647
            goto 50
        end local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key java.security.KeyStore$PasswordProtection java.security.cert.Certificate[] java.util.Set
      StackMap stack:
        29: aload 2 /* key */
            instanceof javax.crypto.SecretKey
            ifeq 49
        30: .line 648
            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
        31: .line 649
            aload 7 /* keyEntry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.date:Ljava/util/Date;
        32: .line 652
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 8 /* pkcs8 */
        start local 8 // sun.security.util.DerOutputStream pkcs8
        33: .line 653
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 9 /* secretKeyInfo */
        start local 9 // sun.security.util.DerOutputStream secretKeyInfo
        34: .line 654
            aload 9 /* secretKeyInfo */
            iconst_0
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        35: .line 655
            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
        36: .line 656
            aload 10 /* algId */
            aload 9 /* secretKeyInfo */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
        37: .line 657
            aload 9 /* secretKeyInfo */
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        38: .line 658
            aload 8 /* pkcs8 */
            bipush 48
            aload 9 /* secretKeyInfo */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        39: .line 661
            aload 7 /* keyEntry */
        40: .line 662
            aload 0 /* this */
            aload 8 /* pkcs8 */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            aload 3 /* passwordProtection */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.encryptPrivateKey:([BLjava/security/KeyStore$PasswordProtection;)[B
        41: .line 661
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        42: .line 664
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 46
        43: .line 665
            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
        44: .line 666
            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;
        45: .line 665
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        46: .line 668
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key java.security.KeyStore$PasswordProtection 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
        47: .line 669
            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
        48: .line 671
            goto 50
        end local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        49: .line 672
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key java.security.KeyStore$PasswordProtection 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
        50: .line 675
      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;
        51: .line 676
            aload 5 /* attributes */
            ifnull 53
        52: .line 677
            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
        53: .line 680
      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
        54: .line 682
            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;
        55: .line 684
            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
        56: .line 686
            goto 61
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String java.security.Key java.security.KeyStore$PasswordProtection java.security.cert.Certificate[] java.util.Set
      StackMap stack: java.lang.Exception
        57: astore 6 /* nsae */
        start local 6 // java.lang.Exception nsae
        58: .line 687
            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
        59: .line 688
            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 */
        60: .line 687
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.lang.Exception nsae
        61: .line 690
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.util.Set attributes
        end local 4 // java.security.cert.Certificate[] chain
        end local 3 // java.security.KeyStore$PasswordProtection passwordProtection
        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   62     0                this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   62     1               alias  Ljava/lang/String;
            0   62     2                 key  Ljava/security/Key;
            0   62     3  passwordProtection  Ljava/security/KeyStore$PasswordProtection;
            0   62     4               chain  [Ljava/security/cert/Certificate;
            0   62     5          attributes  Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;
           28   29     6               entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
           48   49     6               entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
           50   56     6               entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            3   28     7            keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
           31   48     7            keyEntry  Lsun/security/pkcs12/PKCS12KeyStore$SecretKeyEntry;
           33   48     8               pkcs8  Lsun/security/util/DerOutputStream;
           34   48     9       secretKeyInfo  Lsun/security/util/DerOutputStream;
           36   48    10               algId  Lsun/security/x509/AlgorithmId;
           58   61     6                nsae  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0    56      57  Class java.lang.Exception
    Exceptions:
      throws java.security.KeyStoreException
    Signature: (Ljava/lang/String;Ljava/security/Key;Ljava/security/KeyStore$PasswordProtection;[Ljava/security/cert/Certificate;Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;)V
    MethodParameters:
                    Name  Flags
      alias               
      key                 
      passwordProtection  
      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 720
            aload 3 /* chain */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.checkX509Certs:([Ljava/security/cert/Certificate;)V
         1: .line 725
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            aload 2 /* key */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
         2: .line 726
            goto 7
      StackMap locals:
      StackMap stack: java.io.IOException
         3: astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
         4: .line 727
            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
         5: .line 728
            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 */
         6: .line 727
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.io.IOException ioe
         7: .line 731
      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
         8: .line 732
            aload 4 /* entry */
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.date:Ljava/util/Date;
         9: .line 734
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 13
        10: .line 735
            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
        11: .line 736
            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;
        12: .line 735
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 741
      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
        14: .line 742
            goto 16
      StackMap locals:
      StackMap stack: java.io.UnsupportedEncodingException
        15: pop
        16: .line 746
      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;
        17: .line 748
            aload 4 /* entry */
            aload 2 /* key */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        18: .line 749
            aload 3 /* chain */
            ifnull 27
        19: .line 751
            aload 3 /* chain */
            arraylength
            iconst_1
            if_icmple 21
            aload 0 /* this */
            aload 3 /* chain */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.validateChain:([Ljava/security/cert/Certificate;)Z
            ifne 21
        20: .line 752
            new java.security.KeyStoreException
            dup
            ldc "Certificate chain is not valid"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 755
      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;
        22: .line 756
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            aload 3 /* chain */
            arraylength
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        23: .line 758
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 27
        24: .line 759
            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;
        25: .line 760
            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;
        26: .line 759
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        27: .line 765
      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
        28: .line 766
            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
        29: .line 767
            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   30     0   this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   30     1  alias  Ljava/lang/String;
            0   30     2    key  [B
            0   30     3  chain  [Ljava/security/cert/Certificate;
            4    7     4    ioe  Ljava/io/IOException;
            8   30     4  entry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
      Exception table:
        from    to  target  type
           1     2       3  Class java.io.IOException
          13    14      15  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 776
            bipush 20
            newarray 8
            astore 1 /* salt */
        start local 1 // byte[] salt
         1: .line 777
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.random:Ljava/security/SecureRandom;
            ifnonnull 3
         2: .line 778
            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 780
      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 781
            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 790
            aconst_null
            astore 2 /* algParams */
        start local 2 // java.security.AlgorithmParameters algParams
         1: .line 794
            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 793
            astore 3 /* paramSpec */
        start local 3 // javax.crypto.spec.PBEParameterSpec paramSpec
         3: .line 796
            aload 1 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 2 /* algParams */
         4: .line 797
            aload 2 /* algParams */
            aload 3 /* paramSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         5: .line 798
            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 799
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getPBEAlgorithmParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 800
            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 799
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Exception e
        10: .line 802
      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.ObjectIdentifier, sun.security.util.DerInputStream);
    descriptor: (Lsun/security/util/ObjectIdentifier;Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // sun.security.util.ObjectIdentifier algorithm
        start local 2 // sun.security.util.DerInputStream in
         0: .line 811
            aconst_null
            astore 3 /* algParams */
        start local 3 // java.security.AlgorithmParameters algParams
         1: .line 814
            aload 2 /* in */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifne 4
         2: .line 815
            aconst_null
            astore 4 /* params */
        start local 4 // sun.security.util.DerValue params
         3: .line 816
            goto 7
        end local 4 // sun.security.util.DerValue params
         4: .line 817
      StackMap locals: java.security.AlgorithmParameters
      StackMap stack:
            aload 2 /* in */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 4 /* params */
        start local 4 // sun.security.util.DerValue params
         5: .line 818
            aload 4 /* params */
            getfield sun.security.util.DerValue.tag:B
            iconst_5
            if_icmpne 7
         6: .line 819
            aconst_null
            astore 4 /* params */
         7: .line 822
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 4 /* params */
            ifnull 18
         8: .line 823
            aload 1 /* algorithm */
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbes2_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 11
         9: .line 824
            ldc "PBES2"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 3 /* algParams */
        10: .line 825
            goto 12
        11: .line 826
      StackMap locals:
      StackMap stack:
            ldc "PBE"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 3 /* algParams */
        12: .line 828
      StackMap locals:
      StackMap stack:
            aload 3 /* algParams */
            aload 4 /* params */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokevirtual java.security.AlgorithmParameters.init:([B)V
        end local 4 // sun.security.util.DerValue params
        13: .line 830
            goto 18
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.ObjectIdentifier sun.security.util.DerInputStream java.security.AlgorithmParameters
      StackMap stack: java.lang.Exception
        14: astore 4 /* e */
        start local 4 // java.lang.Exception e
        15: .line 831
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "parseAlgParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        16: .line 832
            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 */
        17: .line 831
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Exception e
        18: .line 834
      StackMap locals:
      StackMap stack:
            aload 3 /* algParams */
            areturn
        end local 3 // java.security.AlgorithmParameters algParams
        end local 2 // sun.security.util.DerInputStream in
        end local 1 // sun.security.util.ObjectIdentifier algorithm
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   19     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   19     1  algorithm  Lsun/security/util/ObjectIdentifier;
            0   19     2         in  Lsun/security/util/DerInputStream;
            1   19     3  algParams  Ljava/security/AlgorithmParameters;
            3    4     4     params  Lsun/security/util/DerValue;
            5   13     4     params  Lsun/security/util/DerValue;
           15   18     4          e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    13      14  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
           Name  Flags
      algorithm  
      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 842
            aconst_null
            astore 2 /* skey */
        start local 2 // javax.crypto.SecretKey skey
         1: .line 845
            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 846
            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 847
            aload 4 /* skFac */
            aload 3 /* keySpec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            astore 2 /* skey */
         4: .line 848
            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 849
            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 850
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getSecretKey failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 851
            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 850
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        10: .line 853
      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[], java.security.KeyStore$PasswordProtection);
    descriptor: ([BLjava/security/KeyStore$PasswordProtection;)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=12, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // byte[] data
        start local 2 // java.security.KeyStore$PasswordProtection passwordProtection
         0: .line 869
            aconst_null
            astore 3 /* key */
        start local 3 // byte[] key
         1: .line 877
            aload 2 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.getProtectionAlgorithm:()Ljava/lang/String;
            astore 4 /* algorithm */
        start local 4 // java.lang.String algorithm
         2: .line 878
            aload 4 /* algorithm */
            ifnull 11
         3: .line 880
            aload 2 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.getProtectionParameters:()Ljava/security/spec/AlgorithmParameterSpec;
         4: .line 879
            astore 7 /* algParamSpec */
        start local 7 // java.security.spec.AlgorithmParameterSpec algParamSpec
         5: .line 881
            aload 7 /* algParamSpec */
            ifnull 9
         6: .line 882
            aload 4 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 5 /* algParams */
        start local 5 // java.security.AlgorithmParameters algParams
         7: .line 883
            aload 5 /* algParams */
            aload 7 /* algParamSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         8: .line 884
            goto 16
        end local 5 // java.security.AlgorithmParameters algParams
         9: .line 885
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] java.security.KeyStore$PasswordProtection byte[] java.lang.String top top java.security.spec.AlgorithmParameterSpec
      StackMap stack:
            aload 0 /* this */
            aload 4 /* algorithm */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 5 /* algParams */
        end local 7 // java.security.spec.AlgorithmParameterSpec algParamSpec
        start local 5 // java.security.AlgorithmParameters algParams
        10: .line 887
            goto 16
        end local 5 // java.security.AlgorithmParameters algParams
        11: .line 890
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] java.security.KeyStore$PasswordProtection byte[] java.lang.String
      StackMap stack:
            new sun.security.pkcs12.PKCS12KeyStore$1
            dup
            aload 0 /* this */
            invokespecial sun.security.pkcs12.PKCS12KeyStore$1.<init>:(Lsun/security/pkcs12/PKCS12KeyStore;)V
        12: .line 889
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* algorithm */
        13: .line 902
            aload 4 /* algorithm */
            ifnull 14
            aload 4 /* algorithm */
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 15
        14: .line 903
      StackMap locals:
      StackMap stack:
            ldc "PBEWithSHA1AndDESede"
            astore 4 /* algorithm */
        15: .line 905
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* algorithm */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 5 /* algParams */
        start local 5 // java.security.AlgorithmParameters algParams
        16: .line 908
      StackMap locals: java.security.AlgorithmParameters
      StackMap stack:
            aload 4 /* algorithm */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEAlgorithmToOID:(Ljava/lang/String;)Lsun/security/util/ObjectIdentifier;
            astore 7 /* pbeOID */
        start local 7 // sun.security.util.ObjectIdentifier pbeOID
        17: .line 909
            aload 7 /* pbeOID */
            ifnonnull 21
        18: .line 910
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "PBE algorithm '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        19: .line 911
            ldc " 'is not supported for key entry protection"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 910
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 915
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] java.security.KeyStore$PasswordProtection byte[] java.lang.String java.security.AlgorithmParameters top sun.security.util.ObjectIdentifier
      StackMap stack:
            aload 0 /* this */
            aload 2 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 8 /* skey */
        start local 8 // javax.crypto.SecretKey skey
        22: .line 916
            aload 4 /* algorithm */
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 9 /* cipher */
        start local 9 // javax.crypto.Cipher cipher
        23: .line 917
            aload 9 /* cipher */
            iconst_1
            aload 8 /* skey */
            aload 5 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        24: .line 918
            aload 9 /* cipher */
            aload 1 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 10 /* encryptedKey */
        start local 10 // byte[] encryptedKey
        25: .line 919
            new sun.security.x509.AlgorithmId
            dup
            aload 7 /* pbeOID */
            aload 9 /* cipher */
            invokevirtual javax.crypto.Cipher.getParameters:()Ljava/security/AlgorithmParameters;
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)V
            astore 6 /* algid */
        start local 6 // sun.security.x509.AlgorithmId algid
        26: .line 921
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 30
        27: .line 922
            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;
        28: .line 923
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        29: .line 922
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        30: .line 929
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] java.security.KeyStore$PasswordProtection byte[] java.lang.String java.security.AlgorithmParameters sun.security.x509.AlgorithmId sun.security.util.ObjectIdentifier javax.crypto.SecretKey javax.crypto.Cipher byte[]
      StackMap stack:
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 6 /* algid */
            aload 10 /* encryptedKey */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:(Lsun/security/x509/AlgorithmId;[B)V
        31: .line 928
            astore 11 /* encrInfo */
        start local 11 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        32: .line 930
            aload 11 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncoded:()[B
            astore 3 /* key */
        end local 11 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        end local 10 // byte[] encryptedKey
        end local 9 // javax.crypto.Cipher cipher
        end local 8 // javax.crypto.SecretKey skey
        end local 7 // sun.security.util.ObjectIdentifier pbeOID
        end local 6 // sun.security.x509.AlgorithmId algid
        end local 5 // java.security.AlgorithmParameters algParams
        end local 4 // java.lang.String algorithm
        33: .line 931
            goto 41
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] java.security.KeyStore$PasswordProtection byte[]
      StackMap stack: java.lang.Exception
        34: astore 4 /* e */
        start local 4 // java.lang.Exception e
        35: .line 933
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Encrypt Private Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        36: .line 934
            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;
        37: .line 933
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        38: .line 932
            astore 5 /* uke */
        start local 5 // java.security.UnrecoverableKeyException uke
        39: .line 935
            aload 5 /* uke */
            aload 4 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        40: .line 936
            aload 5 /* uke */
            athrow
        end local 5 // java.security.UnrecoverableKeyException uke
        end local 4 // java.lang.Exception e
        41: .line 939
      StackMap locals:
      StackMap stack:
            aload 3 /* key */
            areturn
        end local 3 // byte[] key
        end local 2 // java.security.KeyStore$PasswordProtection passwordProtection
        end local 1 // byte[] data
        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                data  [B
            0   42     2  passwordProtection  Ljava/security/KeyStore$PasswordProtection;
            1   42     3                 key  [B
            2   33     4           algorithm  Ljava/lang/String;
            7    9     5           algParams  Ljava/security/AlgorithmParameters;
           10   11     5           algParams  Ljava/security/AlgorithmParameters;
           16   33     5           algParams  Ljava/security/AlgorithmParameters;
           26   33     6               algid  Lsun/security/x509/AlgorithmId;
            5   10     7        algParamSpec  Ljava/security/spec/AlgorithmParameterSpec;
           17   33     7              pbeOID  Lsun/security/util/ObjectIdentifier;
           22   33     8                skey  Ljavax/crypto/SecretKey;
           23   33     9              cipher  Ljavax/crypto/Cipher;
           25   33    10        encryptedKey  [B
           32   33    11            encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           35   41     4                   e  Ljava/lang/Exception;
           39   41     5                 uke  Ljava/security/UnrecoverableKeyException;
      Exception table:
        from    to  target  type
           1    33      34  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
                    Name  Flags
      data                
      passwordProtection  

  private static sun.security.util.ObjectIdentifier mapPBEAlgorithmToOID(java.lang.String);
    descriptor: (Ljava/lang/String;)Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 948
            aload 0 /* algorithm */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            ldc "pbewithhmacsha"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 2
         1: .line 949
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbes2_OID:Lsun/security/util/ObjectIdentifier;
            areturn
         2: .line 951
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            invokestatic sun.security.x509.AlgorithmId.get:(Ljava/lang/String;)Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getOID:()Lsun/security/util/ObjectIdentifier;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  private static java.lang.String mapPBEParamsToAlgorithm(sun.security.util.ObjectIdentifier, java.security.AlgorithmParameters);
    descriptor: (Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.util.ObjectIdentifier algorithm
        start local 1 // java.security.AlgorithmParameters algParams
         0: .line 960
            aload 0 /* algorithm */
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbes2_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 2
            aload 1 /* algParams */
            ifnull 2
         1: .line 961
            aload 1 /* algParams */
            invokevirtual java.security.AlgorithmParameters.toString:()Ljava/lang/String;
            areturn
         2: .line 963
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.security.AlgorithmParameters algParams
        end local 0 // sun.security.util.ObjectIdentifier algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Lsun/security/util/ObjectIdentifier;
            0    3     1  algParams  Ljava/security/AlgorithmParameters;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  
      algParams  

  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 983
            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 984
            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<java.security.KeyStore$Entry$Attribute>);
    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 993
            aload 2 /* cert */
            ifnull 6
            aload 2 /* cert */
            instanceof java.security.cert.X509Certificate
            ifne 6
         1: .line 994
            new java.security.KeyStoreException
            dup
         2: .line 995
            new java.lang.StringBuilder
            dup
            ldc "Only X.509 certificates are supported - rejecting class: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         3: .line 996
            aload 2 /* cert */
            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;
         4: .line 995
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 994
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 999
      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 4 /* entry */
        start local 4 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
         7: .line 1000
            aload 4 /* entry */
            ifnull 9
            aload 4 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 9
         8: .line 1001
            new java.security.KeyStoreException
            dup
            ldc "Cannot overwrite own certificate"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 1005
      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;
        10: .line 1006
            aload 3 /* attributes */
        11: .line 1005
            invokespecial sun.security.pkcs12.PKCS12KeyStore$CertEntry.<init>:(Ljava/security/cert/X509Certificate;[BLjava/lang/String;[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)V
        12: .line 1004
            astore 5 /* certEntry */
        start local 5 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
        13: .line 1007
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        14: .line 1008
            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 5 /* certEntry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        15: .line 1010
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 19
        16: .line 1011
            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;
        17: .line 1012
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 1011
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        19: .line 1014
      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   20     0        this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   20     1       alias  Ljava/lang/String;
            0   20     2        cert  Ljava/security/cert/Certificate;
            0   20     3  attributes  Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;
            7   20     4       entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
           13   20     5   certEntry  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
    Exceptions:
      throws java.security.KeyStoreException
    Signature: (Ljava/lang/String;Ljava/security/cert/Certificate;Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;)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 1026
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 1027
            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 1030
      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 1031
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 9
         4: .line 1032
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            astore 3 /* keyEntry */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         5: .line 1033
            aload 3 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 7
         6: .line 1034
            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 1036
      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 1037
            goto 14
      StackMap locals:
      StackMap stack:
         9: aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 12
        10: .line 1038
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        11: .line 1039
            goto 14
      StackMap locals:
      StackMap stack:
        12: aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 14
        13: .line 1040
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            iconst_1
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        14: .line 1042
      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 1043
            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 1051
            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 1062
            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 1071
            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 1082
            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 1083
            aload 2 /* entry */
            ifnull 3
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 3
         2: .line 1084
            iconst_1
            ireturn
         3: .line 1086
      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 1098
            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 1099
            aload 2 /* entry */
            ifnull 4
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 4
         2: .line 1100
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 4
         3: .line 1101
            iconst_1
            ireturn
         4: .line 1103
      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 1126
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$TrustedCertificateEntry;
            if_acmpne 2
         1: .line 1127
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ireturn
         2: .line 1130
      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 1131
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$PrivateKeyEntry;
            if_acmpne 6
         4: .line 1132
            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 1134
      StackMap locals:
      StackMap stack:
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$SecretKeyEntry;
            if_acmpne 9
         7: .line 1135
            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 1137
      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 1157
            aconst_null
            astore 2 /* certElem */
        start local 2 // java.security.cert.Certificate certElem
         1: .line 1159
            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 1160
      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 1161
            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 1162
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 9
         6: .line 1163
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 12
         7: .line 1164
            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 1166
            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 1167
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 14
        11: .line 1168
            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 1172
      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 1173
            aload 4 /* alias */
            areturn
        end local 5 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 4 // java.lang.String alias
        14: .line 1159
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        end local 3 // java.util.Enumeration e
        15: .line 1176
            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 1196
            aload 2 /* password */
            ifnonnull 2
         1: .line 1197
            new java.lang.IllegalArgumentException
            dup
            ldc "password can't be null"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 1201
      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 1204
            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 1205
            aload 4 /* version */
            iconst_3
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
         5: .line 1206
            aload 4 /* version */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 5 /* pfxVersion */
        start local 5 // byte[] pfxVersion
         6: .line 1207
            aload 3 /* pfx */
            aload 5 /* pfxVersion */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
         7: .line 1210
            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 1213
            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 1216
            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 1218
      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 1219
            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 1220
            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 1219
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        14: .line 1223
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.createSafeContent:()[B
            astore 8 /* safeContentData */
        start local 8 // byte[] safeContentData
        15: .line 1224
            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 1225
            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 1229
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            ifle 28
        18: .line 1231
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 22
        19: .line 1232
            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 1233
            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 1232
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        22: .line 1236
      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 1238
            new sun.security.pkcs.ContentInfo
            dup
            getstatic sun.security.pkcs.ContentInfo.ENCRYPTED_DATA_OID:Lsun/security/util/ObjectIdentifier;
        24: .line 1239
            new sun.security.util.DerValue
            dup
            aload 8 /* encrData */
            invokespecial sun.security.util.DerValue.<init>:([B)V
        25: .line 1238
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/ObjectIdentifier;Lsun/security/util/DerValue;)V
        26: .line 1237
            astore 9 /* encrContentInfo */
        start local 9 // sun.security.pkcs.ContentInfo encrContentInfo
        27: .line 1240
            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 1244
      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 1245
            aload 8 /* cInfo */
            bipush 48
            aload 7 /* authSafeContentInfo */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        30: .line 1246
            aload 8 /* cInfo */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 9 /* authenticatedSafe */
        start local 9 // byte[] authenticatedSafe
        31: .line 1249
            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 1250
            aload 10 /* contentInfo */
            aload 6 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.encode:(Lsun/security/util/DerOutputStream;)V
        33: .line 1251
            aload 6 /* authSafe */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 11 /* authSafeData */
        start local 11 // byte[] authSafeData
        34: .line 1252
            aload 3 /* pfx */
            aload 11 /* authSafeData */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        35: .line 1255
            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 1256
            aload 3 /* pfx */
            aload 12 /* macData */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        37: .line 1259
            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 1260
            aload 13 /* pfxout */
            bipush 48
            aload 3 /* pfx */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        39: .line 1261
            aload 13 /* pfxout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 14 /* pfxData */
        start local 14 // byte[] pfxData
        40: .line 1262
            aload 1 /* stream */
            aload 14 /* pfxData */
            invokevirtual java.io.OutputStream.write:([B)V
        41: .line 1263
            aload 1 /* stream */
            invokevirtual java.io.OutputStream.flush:()V
        42: .line 1264
            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=6, locals=8, 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 1296
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineContainsAlias:(Ljava/lang/String;)Z
            ifne 2
         1: .line 1297
            aconst_null
            areturn
         2: .line 1300
      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 1301
            aload 2 /* protParam */
            ifnonnull 17
         4: .line 1302
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 14
         5: .line 1303
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 17
         6: .line 1304
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 17
         7: .line 1306
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 11
         8: .line 1307
            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
         9: .line 1308
            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;
        10: .line 1307
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 1311
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            new java.security.KeyStore$TrustedCertificateEntry
            dup
        12: .line 1312
            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;
        13: .line 1311
            invokespecial java.security.KeyStore$TrustedCertificateEntry.<init>:(Ljava/security/cert/Certificate;Ljava/util/Set;)V
            areturn
        14: .line 1315
      StackMap locals:
      StackMap stack:
            new java.security.UnrecoverableKeyException
            dup
        15: .line 1316
            ldc "requested entry requires a password"
        16: .line 1315
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 1320
      StackMap locals:
      StackMap stack:
            aload 2 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifeq 40
        18: .line 1321
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 22
        19: .line 1322
            new java.lang.UnsupportedOperationException
            dup
        20: .line 1323
            ldc "trusted certificate entries are not password-protected"
        21: .line 1322
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 1324
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifeq 36
        23: .line 1326
            aload 2 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
        24: .line 1325
            astore 4 /* pp */
        start local 4 // java.security.KeyStore$PasswordProtection pp
        25: .line 1327
            aload 4 /* pp */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            astore 5 /* password */
        start local 5 // char[] password
        26: .line 1329
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineGetKey:(Ljava/lang/String;[C)Ljava/security/Key;
            astore 6 /* key */
        start local 6 // java.security.Key key
        27: .line 1330
            aload 6 /* key */
            instanceof java.security.PrivateKey
            ifeq 32
        28: .line 1331
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineGetCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/Certificate;
            astore 7 /* chain */
        start local 7 // java.security.cert.Certificate[] chain
        29: .line 1333
            new java.security.KeyStore$PrivateKeyEntry
            dup
            aload 6 /* key */
            checkcast java.security.PrivateKey
            aload 7 /* chain */
        30: .line 1334
            aload 0 /* this */
            aload 3 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getAttributes:(Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
        31: .line 1333
            invokespecial java.security.KeyStore$PrivateKeyEntry.<init>:(Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;Ljava/util/Set;)V
            areturn
        end local 7 // java.security.cert.Certificate[] chain
        32: .line 1336
      StackMap locals: java.security.KeyStore$PasswordProtection char[] java.security.Key
      StackMap stack:
            aload 6 /* key */
            instanceof javax.crypto.SecretKey
            ifeq 40
        33: .line 1338
            new java.security.KeyStore$SecretKeyEntry
            dup
            aload 6 /* key */
            checkcast javax.crypto.SecretKey
        34: .line 1339
            aload 0 /* this */
            aload 3 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getAttributes:(Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
        35: .line 1338
            invokespecial java.security.KeyStore$SecretKeyEntry.<init>:(Ljavax/crypto/SecretKey;Ljava/util/Set;)V
            areturn
        end local 6 // java.security.Key key
        end local 5 // char[] password
        end local 4 // java.security.KeyStore$PasswordProtection pp
        36: .line 1341
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifne 40
        37: .line 1342
            new java.lang.UnsupportedOperationException
            dup
        38: .line 1343
            ldc "untrusted certificate entries are not password-protected"
        39: .line 1342
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        40: .line 1348
      StackMap locals:
      StackMap stack:
            new java.lang.UnsupportedOperationException
            dup
            invokespecial java.lang.UnsupportedOperationException.<init>:()V
            athrow
        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   41     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   41     1      alias  Ljava/lang/String;
            0   41     2  protParam  Ljava/security/KeyStore$ProtectionParameter;
            3   41     3      entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
           25   36     4         pp  Ljava/security/KeyStore$PasswordProtection;
           26   36     5   password  [C
           27   36     6        key  Ljava/security/Key;
           29   32     7      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=6, 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.KeyStore$Entry entry
        start local 3 // java.security.KeyStore$ProtectionParameter protParam
         0: .line 1374
            aload 3 /* protParam */
            ifnull 3
         1: .line 1375
            aload 3 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifne 3
         2: .line 1376
            new java.security.KeyStoreException
            dup
            ldc "unsupported protection parameter"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 1378
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* pProtect */
        start local 4 // java.security.KeyStore$PasswordProtection pProtect
         4: .line 1379
            aload 3 /* protParam */
            ifnull 6
         5: .line 1380
            aload 3 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
            astore 4 /* pProtect */
         6: .line 1384
      StackMap locals: java.security.KeyStore$PasswordProtection
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$TrustedCertificateEntry
            ifeq 17
         7: .line 1385
            aload 3 /* protParam */
            ifnull 11
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnull 11
         8: .line 1387
            new java.security.KeyStoreException
            dup
         9: .line 1388
            ldc "trusted certificate entries are not password-protected"
        10: .line 1387
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 1391
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$TrustedCertificateEntry
        12: .line 1390
            astore 5 /* tce */
        start local 5 // java.security.KeyStore$TrustedCertificateEntry tce
        13: .line 1392
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* tce */
            invokevirtual java.security.KeyStore$TrustedCertificateEntry.getTrustedCertificate:()Ljava/security/cert/Certificate;
        14: .line 1393
            aload 5 /* tce */
            invokevirtual java.security.KeyStore$TrustedCertificateEntry.getAttributes:()Ljava/util/Set;
        15: .line 1392
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setCertEntry:(Ljava/lang/String;Ljava/security/cert/Certificate;Ljava/util/Set;)V
        16: .line 1395
            return
        end local 5 // java.security.KeyStore$TrustedCertificateEntry tce
        17: .line 1397
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$PrivateKeyEntry
            ifeq 27
        18: .line 1398
            aload 4 /* pProtect */
            ifnull 19
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 22
        19: .line 1400
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        20: .line 1401
            ldc "non-null password required to create PrivateKeyEntry"
        21: .line 1400
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 1403
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$PrivateKeyEntry
            astore 5 /* pke */
        start local 5 // java.security.KeyStore$PrivateKeyEntry pke
        23: .line 1404
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* pke */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getPrivateKey:()Ljava/security/PrivateKey;
            aload 4 /* pProtect */
        24: .line 1405
            aload 5 /* pke */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
            aload 5 /* pke */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getAttributes:()Ljava/util/Set;
        25: .line 1404
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setKeyEntry:(Ljava/lang/String;Ljava/security/Key;Ljava/security/KeyStore$PasswordProtection;[Ljava/security/cert/Certificate;Ljava/util/Set;)V
        26: .line 1407
            return
        end local 5 // java.security.KeyStore$PrivateKeyEntry pke
        27: .line 1409
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$SecretKeyEntry
            ifeq 37
        28: .line 1410
            aload 4 /* pProtect */
            ifnull 29
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 32
        29: .line 1412
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        30: .line 1413
            ldc "non-null password required to create SecretKeyEntry"
        31: .line 1412
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 1415
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$SecretKeyEntry
            astore 5 /* ske */
        start local 5 // java.security.KeyStore$SecretKeyEntry ske
        33: .line 1416
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* ske */
            invokevirtual java.security.KeyStore$SecretKeyEntry.getSecretKey:()Ljavax/crypto/SecretKey;
            aload 4 /* pProtect */
        34: .line 1417
            aconst_null
            aload 5 /* ske */
            invokevirtual java.security.KeyStore$SecretKeyEntry.getAttributes:()Ljava/util/Set;
        35: .line 1416
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setKeyEntry:(Ljava/lang/String;Ljava/security/Key;Ljava/security/KeyStore$PasswordProtection;[Ljava/security/cert/Certificate;Ljava/util/Set;)V
        36: .line 1419
            return
        end local 5 // java.security.KeyStore$SecretKeyEntry ske
        37: .line 1423
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        38: .line 1424
            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;
        39: .line 1423
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        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   40     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   40     1      alias  Ljava/lang/String;
            0   40     2      entry  Ljava/security/KeyStore$Entry;
            0   40     3  protParam  Ljava/security/KeyStore$ProtectionParameter;
            4   40     4   pProtect  Ljava/security/KeyStore$PasswordProtection;
           13   17     5        tce  Ljava/security/KeyStore$TrustedCertificateEntry;
           23   27     5        pke  Ljava/security/KeyStore$PrivateKeyEntry;
           33   37     5        ske  Ljava/security/KeyStore$SecretKeyEntry;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
           Name  Flags
      alias      
      entry      
      protParam  

  private java.util.Set<java.security.KeyStore$Entry$Attribute> 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 1432
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            ifnonnull 2
         1: .line 1433
            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 1437
      StackMap locals:
      StackMap stack:
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new java.security.PKCS12Attribute
            dup
         3: .line 1438
            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 java.security.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         4: .line 1437
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         5: .line 1441
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.keyId:[B
            astore 2 /* keyIdValue */
        start local 2 // byte[] keyIdValue
         6: .line 1442
            aload 2 /* keyIdValue */
            ifnull 10
         7: .line 1443
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new java.security.PKCS12Attribute
            dup
         8: .line 1444
            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 java.security.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
         9: .line 1443
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        10: .line 1448
      StackMap locals: byte[]
      StackMap stack:
            aload 1 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 24
        11: .line 1450
            aload 1 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
        12: .line 1449
            astore 3 /* trustedKeyUsageValue */
        start local 3 // sun.security.util.ObjectIdentifier[] trustedKeyUsageValue
        13: .line 1451
            aload 3 /* trustedKeyUsageValue */
            ifnull 24
        14: .line 1452
            aload 3 /* trustedKeyUsageValue */
            arraylength
            iconst_1
            if_icmpne 20
        15: .line 1453
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new java.security.PKCS12Attribute
            dup
        16: .line 1454
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        17: .line 1455
            aload 3 /* trustedKeyUsageValue */
            iconst_0
            aaload
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokespecial java.security.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        18: .line 1453
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        19: .line 1456
            goto 24
        20: .line 1457
      StackMap locals: sun.security.util.ObjectIdentifier[]
      StackMap stack:
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new java.security.PKCS12Attribute
            dup
        21: .line 1458
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        22: .line 1459
            aload 3 /* trustedKeyUsageValue */
            invokestatic java.util.Arrays.toString:([Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.security.PKCS12Attribute.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        23: .line 1457
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // sun.security.util.ObjectIdentifier[] trustedKeyUsageValue
        24: .line 1464
      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<Ljava/security/KeyStore$Entry$Attribute;>;
    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 1472
            aconst_null
            astore 2 /* digest */
        start local 2 // byte[] digest
         1: .line 1475
            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 1476
            aload 3 /* md */
            aload 1 /* data */
            invokevirtual java.security.MessageDigest.update:([B)V
         3: .line 1477
            aload 3 /* md */
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 2 /* digest */
        end local 3 // java.security.MessageDigest md
         4: .line 1478
            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 1479
            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 1481
      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 1494
            aconst_null
            astore 3 /* mData */
        start local 3 // byte[] mData
         1: .line 1495
            ldc "SHA1"
            astore 4 /* algName */
        start local 4 // java.lang.String algName
         2: .line 1499
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getSalt:()[B
            astore 5 /* salt */
        start local 5 // byte[] salt
         3: .line 1502
            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 1504
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 5 /* salt */
            ldc 100000
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
         5: .line 1503
            astore 7 /* params */
        start local 7 // javax.crypto.spec.PBEParameterSpec params
         6: .line 1505
            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 1506
            aload 6 /* m */
            aload 8 /* key */
            aload 7 /* params */
            invokevirtual javax.crypto.Mac.init:(Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
         8: .line 1507
            aload 6 /* m */
            aload 2 /* data */
            invokevirtual javax.crypto.Mac.update:([B)V
         9: .line 1508
            aload 6 /* m */
            invokevirtual javax.crypto.Mac.doFinal:()[B
            astore 9 /* macResult */
        start local 9 // byte[] macResult
        10: .line 1511
            new sun.security.pkcs12.MacData
            dup
            aload 4 /* algName */
            aload 9 /* macResult */
            aload 5 /* salt */
        11: .line 1512
            ldc 100000
        12: .line 1511
            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 1513
            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 1514
            aload 11 /* bytes */
            aload 10 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        15: .line 1515
            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 1516
            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 1517
            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 1519
      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 1528
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 9
         2: .line 1530
      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 1529
            astore 3 /* issuerDN */
        start local 3 // javax.security.auth.x500.X500Principal issuerDN
         4: .line 1532
            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 1531
            astore 4 /* subjectDN */
        start local 4 // javax.security.auth.x500.X500Principal subjectDN
         6: .line 1533
            aload 3 /* issuerDN */
            aload 4 /* subjectDN */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 8
         7: .line 1534
            iconst_0
            ireturn
        end local 4 // javax.security.auth.x500.X500Principal subjectDN
        end local 3 // javax.security.auth.x500.X500Principal issuerDN
         8: .line 1528
      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 1540
            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 1541
            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 static void checkX509Certs(java.security.cert.Certificate[]);
    descriptor: ([Ljava/security/cert/Certificate;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // java.security.cert.Certificate[] certs
         0: .line 1549
            aload 0 /* certs */
            ifnull 11
         1: .line 1550
            aload 0 /* certs */
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 10
      StackMap locals: java.security.cert.Certificate[] top int int java.security.cert.Certificate[]
      StackMap stack:
         2: aload 4
            iload 2
            aaload
            astore 1 /* cert */
        start local 1 // java.security.cert.Certificate cert
         3: .line 1551
            aload 1 /* cert */
            instanceof java.security.cert.X509Certificate
            ifne 9
         4: .line 1552
            new java.security.KeyStoreException
            dup
         5: .line 1553
            new java.lang.StringBuilder
            dup
            ldc "Only X.509 certificates are supported - rejecting class: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 1554
            aload 1 /* cert */
            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;
         7: .line 1553
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 1552
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.security.cert.Certificate cert
         9: .line 1550
      StackMap locals:
      StackMap stack:
            iinc 2 1
      StackMap locals:
      StackMap stack:
        10: iload 2
            iload 3
            if_icmplt 2
        11: .line 1558
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            return
        end local 0 // java.security.cert.Certificate[] certs
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   12     0  certs  [Ljava/security/cert/Certificate;
            3    9     1   cert  Ljava/security/cert/Certificate;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      certs  

  private byte[] getBagAttributes(java.lang.String, byte[], java.util.Set<java.security.KeyStore$Entry$Attribute>);
    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 1597
            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<Ljava/security/KeyStore$Entry$Attribute;>;
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/lang/String;[BLjava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;)[B
    MethodParameters:
            Name  Flags
      alias       
      keyId       
      attributes  

  private byte[] getBagAttributes(java.lang.String, byte[], sun.security.util.ObjectIdentifier[], java.util.Set<java.security.KeyStore$Entry$Attribute>);
    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 1604
            aconst_null
            astore 5 /* localKeyID */
        start local 5 // byte[] localKeyID
         1: .line 1605
            aconst_null
            astore 6 /* friendlyName */
        start local 6 // byte[] friendlyName
         2: .line 1606
            aconst_null
            astore 7 /* trustedKeyUsage */
        start local 7 // byte[] trustedKeyUsage
         3: .line 1609
            aload 1 /* alias */
            ifnonnull 5
            aload 2 /* keyId */
            ifnonnull 5
            aload 7 /* trustedKeyUsage */
            ifnonnull 5
         4: .line 1610
            aconst_null
            areturn
         5: .line 1614
      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 1617
            aload 1 /* alias */
            ifnull 15
         7: .line 1618
            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 1619
            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 1620
            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 1621
            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 1622
            aload 10 /* bagAttrContent1 */
            aload 1 /* alias */
            invokevirtual sun.security.util.DerOutputStream.putBMPString:(Ljava/lang/String;)V
        12: .line 1623
            aload 9 /* bagAttr1 */
            bipush 49
            aload 10 /* bagAttrContent1 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        13: .line 1624
            aload 11 /* bagAttrValue1 */
            bipush 48
            aload 9 /* bagAttr1 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        14: .line 1625
            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 1629
      StackMap locals: sun.security.util.DerOutputStream
      StackMap stack:
            aload 2 /* keyId */
            ifnull 24
        16: .line 1630
            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 1631
            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 1632
            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 1633
            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 1634
            aload 10 /* bagAttrContent2 */
            aload 2 /* keyId */
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        21: .line 1635
            aload 9 /* bagAttr2 */
            bipush 49
            aload 10 /* bagAttrContent2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        22: .line 1636
            aload 11 /* bagAttrValue2 */
            bipush 48
            aload 9 /* bagAttr2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        23: .line 1637
            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 1641
      StackMap locals:
      StackMap stack:
            aload 3 /* trustedUsage */
            ifnull 37
        25: .line 1642
            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 1643
            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 1644
            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 1645
            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 1646
            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 1647
            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 1646
            iinc 13 1
      StackMap locals:
      StackMap stack:
        33: iload 13
            iload 14
            if_icmplt 30
        34: .line 1649
            aload 9 /* bagAttr3 */
            bipush 49
            aload 10 /* bagAttrContent3 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        35: .line 1650
            aload 11 /* bagAttrValue3 */
            bipush 48
            aload 9 /* bagAttr3 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        36: .line 1651
            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 1654
      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 1655
            aload 6 /* friendlyName */
            ifnull 40
        39: .line 1656
            aload 9 /* attrs */
            aload 6 /* friendlyName */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        40: .line 1658
      StackMap locals: sun.security.util.DerOutputStream
      StackMap stack:
            aload 5 /* localKeyID */
            ifnull 42
        41: .line 1659
            aload 9 /* attrs */
            aload 5 /* localKeyID */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        42: .line 1661
      StackMap locals:
      StackMap stack:
            aload 7 /* trustedKeyUsage */
            ifnull 44
        43: .line 1662
            aload 9 /* attrs */
            aload 7 /* trustedKeyUsage */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        44: .line 1665
      StackMap locals:
      StackMap stack:
            aload 4 /* attributes */
            ifnull 54
        45: .line 1666
            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 java.security.KeyStore$Entry$Attribute
            astore 10 /* attribute */
        start local 10 // java.security.KeyStore$Entry$Attribute attribute
        47: .line 1667
            aload 10 /* attribute */
            invokeinterface java.security.KeyStore$Entry$Attribute.getName:()Ljava/lang/String;
            astore 12 /* attributeName */
        start local 12 // java.lang.String attributeName
        48: .line 1669
            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 1670
            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 1671
            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 1672
            goto 53
        52: .line 1674
      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 java.security.KeyStore$Entry$Attribute java.util.Iterator java.lang.String
      StackMap stack:
            aload 9 /* attrs */
            aload 10 /* attribute */
            checkcast java.security.PKCS12Attribute
            invokevirtual java.security.PKCS12Attribute.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        end local 12 // java.lang.String attributeName
        end local 10 // java.security.KeyStore$Entry$Attribute attribute
        53: .line 1666
      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 1678
      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 1679
            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<Ljava/security/KeyStore$Entry$Attribute;>;
            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  Ljava/security/KeyStore$Entry$Attribute;
           48   53    12    attributeName  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/lang/String;[B[Lsun/security/util/ObjectIdentifier;Ljava/util/Set<Ljava/security/KeyStore$Entry$Attribute;>;)[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 1691
            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 1692
            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 1694
      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 1695
            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 1700
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 12
         6: .line 1701
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            astore 7 /* keyEntry */
        start local 7 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         7: .line 1702
            aload 7 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 10
         8: .line 1703
            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 1704
            goto 16
        end local 6 // java.security.cert.Certificate[] certs
        10: .line 1705
      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 1707
            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 1708
            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 1709
            goto 16
        end local 6 // java.security.cert.Certificate[] certs
        15: .line 1710
      StackMap locals:
      StackMap stack:
            iconst_0
            anewarray java.security.cert.Certificate
            astore 6 /* certs */
        start local 6 // java.security.cert.Certificate[] certs
        16: .line 1713
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        17: goto 64
        18: .line 1715
      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 1716
            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 1719
            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 1720
            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 1723
            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 1724
            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 1725
            aload 10 /* certValue */
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        25: .line 1726
            aload 9 /* certBag */
            bipush -128
        26: .line 1727
            iconst_1
            iconst_0
        27: .line 1726
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        28: .line 1727
            aload 10 /* certValue */
        29: .line 1726
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        30: .line 1730
            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 1731
            aload 12 /* certout */
            bipush 48
            aload 9 /* certBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        32: .line 1732
            aload 12 /* certout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 13 /* certBagValue */
        start local 13 // byte[] certBagValue
        33: .line 1735
            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 1736
            aload 14 /* bagValue */
            aload 13 /* certBagValue */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        35: .line 1738
            aload 8 /* safeBag */
            bipush -128
        36: .line 1739
            iconst_1
            iconst_0
        37: .line 1738
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        38: .line 1739
            aload 14 /* bagValue */
        39: .line 1738
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        40: .line 1744
            aconst_null
            astore 15 /* bagAttrs */
        start local 15 // byte[] bagAttrs
        41: .line 1745
            iload 7 /* i */
            ifne 56
        42: .line 1747
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 49
        43: .line 1748
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 16 /* keyEntry */
        start local 16 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
        44: .line 1750
            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 1751
            aload 16 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
        46: .line 1750
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[BLjava/util/Set;)[B
        47: .line 1749
            astore 15 /* bagAttrs */
        end local 16 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
        48: .line 1752
            goto 60
        49: .line 1753
      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 1755
            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 1756
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
        52: .line 1757
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.attributes:Ljava/util/Set;
        53: .line 1755
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[B[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)[B
        54: .line 1754
            astore 15 /* bagAttrs */
        end local 16 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
        55: .line 1759
            goto 60
        56: .line 1766
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        57: .line 1767
            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 1768
            aload 5 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
        59: .line 1766
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[BLjava/util/Set;)[B
            astore 15 /* bagAttrs */
        60: .line 1770
      StackMap locals:
      StackMap stack:
            aload 15 /* bagAttrs */
            ifnull 62
        61: .line 1771
            aload 8 /* safeBag */
            aload 15 /* bagAttrs */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        62: .line 1775
      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 1713
            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 1692
      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 1780
            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 1781
            aload 3 /* safeBagValue */
            bipush 48
            aload 2 /* out */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        68: .line 1782
            aload 3 /* safeBagValue */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 4 /* safeBagData */
        start local 4 // byte[] safeBagData
        69: .line 1785
            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 1788
            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 1789
            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 1790
            aload 6 /* encrData */
            iconst_0
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        73: .line 1791
            aload 6 /* encrData */
            aload 5 /* encrContentInfo */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        74: .line 1792
            aload 7 /* encrDataContent */
            bipush 48
            aload 6 /* encrData */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        75: .line 1793
            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 1806
            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 1807
            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 1809
      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 1810
            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 1811
            aload 4 /* entry */
            ifnull 54
            aload 4 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifne 7
         6: .line 1812
            goto 54
         7: .line 1814
      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 1815
            aload 4 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 6 /* keyEntry */
        start local 6 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
         9: .line 1818
            aload 6 /* keyEntry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 27
        10: .line 1820
            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 1823
            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 1824
            aconst_null
            astore 8 /* encrInfo */
        start local 8 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        13: .line 1826
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 7 /* encrBytes */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
            astore 8 /* encrInfo */
        14: .line 1828
            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 1829
            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 1831
            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 1829
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 9 // java.io.IOException ioe
        19: .line 1835
      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 1836
            aload 9 /* bagValue */
            aload 8 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        21: .line 1837
            aload 5 /* safeBag */
            bipush -128
        22: .line 1838
            iconst_1
            iconst_0
        23: .line 1837
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        24: .line 1838
            aload 9 /* bagValue */
        25: .line 1837
            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 1841
            goto 50
      StackMap locals:
      StackMap stack:
        27: aload 6 /* keyEntry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 54
        28: .line 1843
            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 1846
            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 1847
            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 1850
            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 1851
            aload 8 /* secretKeyValue */
        33: .line 1852
            aload 6 /* keyEntry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        34: .line 1851
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        35: .line 1853
            aload 7 /* secretBag */
            bipush -128
        36: .line 1854
            iconst_1
            iconst_0
        37: .line 1853
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        38: .line 1854
            aload 8 /* secretKeyValue */
        39: .line 1853
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        40: .line 1857
            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 1858
            aload 9 /* secretBagSeq */
            bipush 48
            aload 7 /* secretBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        42: .line 1859
            aload 9 /* secretBagSeq */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 10 /* secretBagValue */
        start local 10 // byte[] secretBagValue
        43: .line 1862
            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 1863
            aload 11 /* bagValue */
            aload 10 /* secretBagValue */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        45: .line 1866
            aload 5 /* safeBag */
            bipush -128
        46: .line 1867
            iconst_1
            iconst_0
        47: .line 1866
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        48: .line 1867
            aload 11 /* bagValue */
        49: .line 1866
            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 1874
      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 1873
            astore 7 /* bagAttrs */
        start local 7 // byte[] bagAttrs
        52: .line 1875
            aload 5 /* safeBag */
            aload 7 /* bagAttrs */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        53: .line 1878
            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 1807
      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 1882
            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 1883
            aload 2 /* safeBagValue */
            bipush 48
            aload 1 /* out */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        57: .line 1884
            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 1900
            aconst_null
            astore 3 /* encryptedData */
        start local 3 // byte[] encryptedData
         1: .line 1904
            aload 0 /* this */
            ldc "PBEWithSHA1AndRC2_40"
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
         2: .line 1903
            astore 4 /* algParams */
        start local 4 // java.security.AlgorithmParameters algParams
         3: .line 1905
            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 1907
            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 1906
            astore 6 /* algId */
        start local 6 // sun.security.x509.AlgorithmId algId
         6: .line 1908
            aload 6 /* algId */
            aload 5 /* bytes */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
         7: .line 1909
            aload 5 /* bytes */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 7 /* encodedAlgId */
        start local 7 // byte[] encodedAlgId
         8: .line 1913
            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 1914
            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 1915
            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 1916
            aload 9 /* cipher */
            aload 1 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 3 /* encryptedData */
        12: .line 1918
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 21
        13: .line 1919
            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 1920
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 1919
            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 1923
            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 1924
            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 1925
            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 1924
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 8 // java.lang.Exception e
        21: .line 1929
      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 1930
            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 1931
            aload 8 /* bytes2 */
            aload 7 /* encodedAlgId */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        24: .line 1934
            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 1935
            aload 9 /* tmpout2 */
            aload 3 /* encryptedData */
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        26: .line 1936
            aload 8 /* bytes2 */
            bipush -128
        27: .line 1937
            iconst_0
            iconst_0
        28: .line 1936
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        29: .line 1937
            aload 9 /* tmpout2 */
        30: .line 1936
            invokevirtual sun.security.util.DerOutputStream.writeImplicit:(BLsun/security/util/DerOutputStream;)V
        31: .line 1940
            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 1941
            aload 10 /* out */
            bipush 48
            aload 8 /* bytes2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        33: .line 1942
            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 1970
            aload 1 /* stream */
            ifnonnull 2
         1: .line 1971
            return
         2: .line 1974
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         3: .line 1976
            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 1977
            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 1978
            aload 4 /* s */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            istore 5 /* version */
        start local 5 // int version
         6: .line 1980
            iload 5 /* version */
            iconst_3
            if_icmpeq 8
         7: .line 1981
            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 1984
      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 1990
            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 1991
            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 1993
            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 14
        12: .line 1994
            aload 7 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            astore 6 /* authSafeData */
        start local 6 // byte[] authSafeData
        13: .line 1995
            goto 15
        end local 6 // byte[] authSafeData
        14: .line 1996
      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:
            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
        15: .line 1999
      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
        16: .line 2000
            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
        17: .line 2001
            aload 10 /* safeContentsArray */
            arraylength
            istore 11 /* count */
        start local 11 // int count
        18: .line 2004
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        19: .line 2005
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        20: .line 2006
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        21: .line 2011
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        22: goto 88
        23: .line 2017
      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
        24: .line 2018
            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
        25: .line 2019
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* contentType */
        26: .line 2020
            aconst_null
            astore 13 /* safeContentsData */
        start local 13 // byte[] safeContentsData
        27: .line 2021
            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
        28: .line 2023
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 30
        29: .line 2024
            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
        30: .line 2027
      StackMap locals: byte[] sun.security.pkcs.ContentInfo sun.security.util.DerInputStream
      StackMap stack:
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            astore 13 /* safeContentsData */
        31: .line 2028
            goto 85
      StackMap locals:
      StackMap stack:
        32: aload 8 /* contentType */
            getstatic sun.security.pkcs.ContentInfo.ENCRYPTED_DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 84
        33: .line 2029
            aload 2 /* password */
            ifnonnull 37
        34: .line 2031
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 87
        35: .line 2032
            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 2035
            goto 87
        37: .line 2039
      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 2038
            astore 16 /* edi */
        start local 16 // sun.security.util.DerInputStream edi
        39: .line 2040
            aload 16 /* edi */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
        40: .line 2041
            aload 16 /* edi */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 17 /* seq */
        start local 17 // sun.security.util.DerValue[] seq
        41: .line 2042
            aload 17 /* seq */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        42: .line 2043
            aload 17 /* seq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            pop
        43: .line 2044
            aload 17 /* seq */
            iconst_2
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 45
        44: .line 2045
            new java.io.IOException
            dup
            ldc "encrypted content not present!"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        45: .line 2047
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            iconst_4
            istore 18 /* newTag */
        start local 18 // byte newTag
        46: .line 2048
            aload 17 /* seq */
            iconst_2
            aaload
            invokevirtual sun.security.util.DerValue.isConstructed:()Z
            ifeq 48
        47: .line 2049
            iload 18 /* newTag */
            bipush 32
            ior
            i2b
            istore 18 /* newTag */
        48: .line 2050
      StackMap locals: int
      StackMap stack:
            aload 17 /* seq */
            iconst_2
            aaload
            iload 18 /* newTag */
            invokevirtual sun.security.util.DerValue.resetTag:(B)V
        49: .line 2051
            aload 17 /* seq */
            iconst_2
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            astore 13 /* safeContentsData */
        50: .line 2054
            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
        51: .line 2055
            aload 19 /* in */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 20 /* algOid */
        start local 20 // sun.security.util.ObjectIdentifier algOid
        52: .line 2056
            aload 0 /* this */
            aload 20 /* algOid */
            aload 19 /* in */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.parseAlgParameters:(Lsun/security/util/ObjectIdentifier;Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
            astore 21 /* algParams */
        start local 21 // java.security.AlgorithmParameters algParams
        53: .line 2059
            iconst_0
            istore 23 /* ic */
        start local 23 // int ic
        54: .line 2061
            aload 21 /* algParams */
            ifnull 65
        55: .line 2064
            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
        56: .line 2063
            astore 22 /* pbeSpec */
        start local 22 // javax.crypto.spec.PBEParameterSpec pbeSpec
        57: .line 2065
            goto 62
        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
        58: pop
        59: .line 2066
            new java.io.IOException
            dup
        60: .line 2067
            ldc "Invalid PBE algorithm parameters"
        61: .line 2066
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 22 // javax.crypto.spec.PBEParameterSpec pbeSpec
        62: .line 2069
      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 */
        63: .line 2071
            iload 23 /* ic */
            ldc 5000000
            if_icmple 65
        64: .line 2072
            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
        65: .line 2076
      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 70
        66: .line 2077
            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
        67: .line 2078
            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;
        68: .line 2079
            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;
        69: .line 2077
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        70: .line 2085
      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
        71: .line 2086
            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
        72: .line 2087
            aload 25 /* cipher */
            iconst_2
            aload 24 /* skey */
            aload 21 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        73: .line 2088
            aload 25 /* cipher */
            aload 13 /* safeContentsData */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 13 /* safeContentsData */
        74: .line 2089
            goto 85
        end local 25 // javax.crypto.Cipher cipher
        end local 24 // javax.crypto.SecretKey skey
        75: .line 2090
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 24 /* e */
        start local 24 // java.lang.Exception e
        76: .line 2091
            aload 2 /* password */
            arraylength
            ifne 79
        77: .line 2094
            iconst_1
            newarray 5
            astore 2 /* password */
        78: .line 2095
            goto 70
        79: .line 2097
      StackMap locals: java.lang.Exception
      StackMap stack:
            new java.io.IOException
            dup
            ldc "keystore password was incorrect"
        80: .line 2098
            new java.security.UnrecoverableKeyException
            dup
        81: .line 2099
            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;
        82: .line 2098
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        83: .line 2097
            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
        84: .line 2103
      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
        85: .line 2106
      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
        86: .line 2107
            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
        87: .line 2011
      StackMap locals:
      StackMap stack:
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        88: iload 12 /* i */
            iload 11 /* count */
            if_icmplt 23
        end local 12 // int i
        89: .line 2111
            aload 2 /* password */
            ifnull 114
            aload 4 /* s */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifle 114
        90: .line 2112
            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
        91: .line 2113
            aload 12 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getIterations:()I
            istore 13 /* ic */
        start local 13 // int ic
        92: .line 2116
            iload 13 /* ic */
            ldc 5000000
            if_icmple 96
        93: .line 2117
            new java.security.InvalidAlgorithmParameterException
            dup
        94: .line 2118
            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;
        95: .line 2117
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        96: .line 2122
      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;
        97: .line 2121
            astore 14 /* algName */
        start local 14 // java.lang.String algName
        98: .line 2125
            aload 14 /* algName */
            ldc "-"
            ldc ""
            invokevirtual java.lang.String.replace:(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
            astore 14 /* algName */
        99: .line 2128
            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
       100: .line 2130
            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
       101: .line 2129
            astore 16 /* params */
        start local 16 // javax.crypto.spec.PBEParameterSpec params
       102: .line 2131
            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
       103: .line 2132
            aload 15 /* m */
            aload 17 /* key */
            aload 16 /* params */
            invokevirtual javax.crypto.Mac.init:(Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
       104: .line 2133
            aload 15 /* m */
            aload 6 /* authSafeData */
            invokevirtual javax.crypto.Mac.update:([B)V
       105: .line 2134
            aload 15 /* m */
            invokevirtual javax.crypto.Mac.doFinal:()[B
            astore 18 /* macResult */
        start local 18 // byte[] macResult
       106: .line 2136
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 110
       107: .line 2137
            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
       108: .line 2138
            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;
       109: .line 2137
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       110: .line 2141
      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 114
       111: .line 2142
            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
       112: .line 2145
      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
       113: .line 2146
            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
       114: .line 2154
      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[]
       115: .line 2153
            astore 12 /* list */
        start local 12 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] list
       116: .line 2155
            iconst_0
            istore 13 /* m */
        start local 13 // int m
       117: goto 145
       118: .line 2156
      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
       119: .line 2157
            aload 14 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.keyId:[B
            ifnull 144
       120: .line 2159
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
       121: .line 2158
            astore 15 /* chain */
        start local 15 // java.util.ArrayList chain
       122: .line 2160
            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
       123: .line 2163
            goto 141
       124: .line 2165
      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 136
       125: .line 2166
            aload 15 /* chain */
            invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
            astore 18
            goto 135
      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:
       126: 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
       127: .line 2167
            aload 16 /* cert */
            aload 17 /* chainCert */
            invokevirtual java.security.cert.X509Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 135
       128: .line 2168
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 142
       129: .line 2169
            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
       130: .line 2172
            aload 16 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
       131: .line 2173
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
       132: .line 2172
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       133: .line 2169
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       134: .line 2175
            goto 142
        end local 17 // java.security.cert.X509Certificate chainCert
       135: .line 2166
      StackMap locals:
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 126
       136: .line 2179
      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
       137: .line 2180
            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
       138: .line 2181
            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 140
       139: .line 2182
            goto 142
       140: .line 2184
      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
       141: .line 2163
      StackMap locals:
      StackMap stack:
            aload 16 /* cert */
            ifnonnull 124
       142: .line 2187
      StackMap locals:
      StackMap stack:
            aload 15 /* chain */
            invokevirtual java.util.ArrayList.size:()I
            ifle 144
       143: .line 2188
            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
       144: .line 2155
      StackMap locals:
      StackMap stack:
            iinc 13 /* m */ 1
      StackMap locals:
      StackMap stack:
       145: iload 13 /* m */
            aload 12 /* list */
            arraylength
            if_icmplt 118
        end local 13 // int m
       146: .line 2192
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 159
       147: .line 2193
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            ifle 151
       148: .line 2194
            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;
       149: .line 2195
            ldc " protected private key(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       150: .line 2194
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       151: .line 2197
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            ifle 155
       152: .line 2198
            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;
       153: .line 2199
            ldc " protected secret key(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       154: .line 2198
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       155: .line 2201
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            ifle 159
       156: .line 2202
            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;
       157: .line 2203
            ldc " certificate(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       158: .line 2202
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       159: .line 2207
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
       160: .line 2208
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.clear:()V
       161: .line 2209
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
       162: .line 2210
            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  163     0               this  Lsun/security/pkcs12/PKCS12KeyStore;
            0  163     1             stream  Ljava/io/InputStream;
            0  163     2           password  [C
            4  163     3                val  Lsun/security/util/DerValue;
            5  163     4                  s  Lsun/security/util/DerInputStream;
            6  163     5            version  I
           13   14     6       authSafeData  [B
           15  163     6       authSafeData  [B
           10  163     7           authSafe  Lsun/security/pkcs/ContentInfo;
           11  163     8        contentType  Lsun/security/util/ObjectIdentifier;
           16  163     9                 as  Lsun/security/util/DerInputStream;
           17  163    10  safeContentsArray  [Lsun/security/util/DerValue;
           18  163    11              count  I
           22   89    12                  i  I
           27   87    13   safeContentsData  [B
           25   87    14       safeContents  Lsun/security/pkcs/ContentInfo;
           24   87    15                sci  Lsun/security/util/DerInputStream;
           39   84    16                edi  Lsun/security/util/DerInputStream;
           41   84    17                seq  [Lsun/security/util/DerValue;
           46   84    18             newTag  B
           51   84    19                 in  Lsun/security/util/DerInputStream;
           52   84    20             algOid  Lsun/security/util/ObjectIdentifier;
           53   84    21          algParams  Ljava/security/AlgorithmParameters;
           57   58    22            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           62   65    22            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           54   84    23                 ic  I
           71   75    24               skey  Ljavax/crypto/SecretKey;
           72   75    25             cipher  Ljavax/crypto/Cipher;
           76   84    24                  e  Ljava/lang/Exception;
           86   87    16                 sc  Lsun/security/util/DerInputStream;
           91  114    12            macData  Lsun/security/pkcs12/MacData;
           92  114    13                 ic  I
           98  112    14            algName  Ljava/lang/String;
          100  112    15                  m  Ljavax/crypto/Mac;
          102  112    16             params  Ljavax/crypto/spec/PBEParameterSpec;
          103  112    17                key  Ljavax/crypto/SecretKey;
          106  112    18          macResult  [B
          113  114    14                  e  Ljava/lang/Exception;
          116  163    12               list  [Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
          117  146    13                  m  I
          119  144    14              entry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
          122  144    15              chain  Ljava/util/ArrayList<Ljava/security/cert/X509Certificate;>;
          123  144    16               cert  Ljava/security/cert/X509Certificate;
          127  135    17          chainCert  Ljava/security/cert/X509Certificate;
          138  141    17           issuerDN  Ljavax/security/auth/x500/X500Principal;
      Exception table:
        from    to  target  type
          55    57      58  Class java.security.spec.InvalidParameterSpecException
          70    74      75  Class java.lang.Exception
          92   112     112  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 2218
            aconst_null
            astore 2 /* keyIdMatch */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$CertEntry keyIdMatch
         1: .line 2219
            aconst_null
            astore 3 /* aliasMatch */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$CertEntry aliasMatch
         2: .line 2220
            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 2221
            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 2222
            aload 4 /* ce */
            astore 2 /* keyIdMatch */
         6: .line 2223
            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 2225
            aload 4 /* ce */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
         8: .line 2227
      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 2228
            aload 4 /* ce */
            astore 3 /* aliasMatch */
        end local 4 // sun.security.pkcs12.PKCS12KeyStore$CertEntry ce
        10: .line 2220
      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 2232
            aload 2 /* keyIdMatch */
            ifnull 12
            aload 2 /* keyIdMatch */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
        12: .line 2233
      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 2234
      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 2240
            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 2241
            aload 3 /* safeBags */
            arraylength
            istore 4 /* count */
        start local 4 // int count
         2: .line 2246
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         3: goto 142
         4: .line 2250
      StackMap locals: sun.security.util.DerValue[] int int
      StackMap stack:
            aconst_null
            astore 9 /* bagItem */
        start local 9 // java.lang.Object bagItem
         5: .line 2252
            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 2253
            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 2254
            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 2255
            aload 8 /* bagValue */
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 12
         9: .line 2256
            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 2257
            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 2256
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 2259
      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 2260
            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 2261
            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 2262
            aload 10 /* kEntry */
            aload 8 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        16: .line 2263
            aload 10 /* kEntry */
            astore 9 /* bagItem */
        17: .line 2264
            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 2265
            goto 53
      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 35
        20: .line 2266
            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 2267
            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 2268
            aload 11 /* certValues */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        23: .line 2269
            aload 11 /* certValues */
            iconst_1
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 27
        24: .line 2270
            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
        25: .line 2271
            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;
        26: .line 2270
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 2273
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      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
        28: .line 2274
            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
        29: .line 2276
            aload 13 /* cf */
        30: .line 2277
            new java.io.ByteArrayInputStream
            dup
            aload 12 /* certValue */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
        31: .line 2276
            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
        32: .line 2278
            aload 14 /* cert */
            astore 9 /* bagItem */
        33: .line 2279
            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
        34: .line 2280
            goto 53
      StackMap locals:
      StackMap stack:
        35: 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 51
        36: .line 2281
            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
        37: .line 2282
            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
        38: .line 2283
            aload 11 /* secretValues */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        39: .line 2284
            aload 11 /* secretValues */
            iconst_1
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 45
        40: .line 2285
            new java.io.IOException
            dup
        41: .line 2286
            new java.lang.StringBuilder
            dup
            ldc "unsupported PKCS12 secret value type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        42: .line 2287
            aload 11 /* secretValues */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.tag:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        43: .line 2286
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        44: .line 2285
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        45: .line 2289
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      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
        46: .line 2290
            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
        47: .line 2291
            aload 13 /* kEntry */
            aload 12 /* secretValue */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        48: .line 2292
            aload 13 /* kEntry */
            astore 9 /* bagItem */
        49: .line 2293
            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
        50: .line 2294
            goto 53
        51: .line 2296
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 53
        52: .line 2297
            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
        53: .line 2303
      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
        54: .line 2304
            goto 57
        end local 10 // sun.security.util.DerValue[] attrSet
      StackMap locals:
      StackMap stack: java.io.IOException
        55: pop
        56: .line 2308
            aconst_null
            astore 10 /* attrSet */
        start local 10 // sun.security.util.DerValue[] attrSet
        57: .line 2311
      StackMap locals: sun.security.util.DerValue[]
      StackMap stack:
            aconst_null
            astore 11 /* alias */
        start local 11 // java.lang.String alias
        58: .line 2312
            aconst_null
            astore 12 /* keyId */
        start local 12 // byte[] keyId
        59: .line 2313
            aconst_null
            astore 13 /* trustedKeyUsage */
        start local 13 // sun.security.util.ObjectIdentifier[] trustedKeyUsage
        60: .line 2314
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 14 /* attributes */
        start local 14 // java.util.Set attributes
        61: .line 2316
            aload 10 /* attrSet */
            ifnull 93
        62: .line 2317
            iconst_0
            istore 15 /* j */
        start local 15 // int j
        63: goto 92
        64: .line 2318
      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
        65: .line 2319
            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
        66: .line 2320
            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
        67: .line 2321
            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
        68: .line 2323
            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
        69: .line 2322
            astore 20 /* vs */
        start local 20 // sun.security.util.DerInputStream vs
        70: .line 2326
            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
        71: .line 2327
            goto 76
        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
        72: astore 22 /* e */
        start local 22 // java.io.IOException e
        73: .line 2328
            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;
        74: .line 2329
            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;
        75: .line 2328
            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
        76: .line 2331
      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 79
        77: .line 2332
            aload 21 /* valSet */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getBMPString:()Ljava/lang/String;
            astore 11 /* alias */
        78: .line 2333
            goto 91
      StackMap locals:
      StackMap stack:
        79: 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 82
        80: .line 2334
            aload 21 /* valSet */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            astore 12 /* keyId */
        81: .line 2335
            goto 91
        82: .line 2336
      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 90
        83: .line 2337
            aload 21 /* valSet */
            arraylength
            anewarray sun.security.util.ObjectIdentifier
            astore 13 /* trustedKeyUsage */
        84: .line 2338
            iconst_0
            istore 22 /* k */
        start local 22 // int k
        85: goto 88
        86: .line 2339
      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
        87: .line 2338
            iinc 22 /* k */ 1
      StackMap locals:
      StackMap stack:
        88: iload 22 /* k */
            aload 21 /* valSet */
            arraylength
            if_icmplt 86
        end local 22 // int k
        89: .line 2341
            goto 91
        90: .line 2342
      StackMap locals:
      StackMap stack:
            aload 14 /* attributes */
            new java.security.PKCS12Attribute
            dup
            aload 16 /* encoded */
            invokespecial java.security.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
        91: .line 2317
      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:
        92: iload 15 /* j */
            aload 10 /* attrSet */
            arraylength
            if_icmplt 64
        end local 15 // int j
        93: .line 2356
      StackMap locals:
      StackMap stack:
            aload 9 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 122
        94: .line 2357
            aload 9 /* bagItem */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 15 /* entry */
        start local 15 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry entry
        95: .line 2359
            aload 9 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 99
        96: .line 2360
            aload 12 /* keyId */
            ifnonnull 99
        97: .line 2365
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            if_icmpne 141
        98: .line 2366
            ldc "01"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 12 /* keyId */
        99: .line 2372
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$KeyEntry
      StackMap stack:
            aload 15 /* entry */
            aload 12 /* keyId */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.keyId:[B
       100: .line 2374
            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
       101: .line 2375
            aconst_null
            astore 17 /* date */
        start local 17 // java.util.Date date
       102: .line 2376
            aload 16 /* keyIdStr */
            ldc "Time "
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 109
       103: .line 2378
            new java.util.Date
            dup
       104: .line 2379
            aload 16 /* keyIdStr */
            iconst_5
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic java.lang.Long.parseLong:(Ljava/lang/String;)J
       105: .line 2378
            invokespecial java.util.Date.<init>:(J)V
            astore 17 /* date */
       106: .line 2380
            goto 109
      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
       107: pop
       108: .line 2381
            aconst_null
            astore 17 /* date */
       109: .line 2384
      StackMap locals:
      StackMap stack:
            aload 17 /* date */
            ifnonnull 111
       110: .line 2385
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 17 /* date */
       111: .line 2387
      StackMap locals:
      StackMap stack:
            aload 15 /* entry */
            aload 17 /* date */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.date:Ljava/util/Date;
       112: .line 2389
            aload 9 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 114
       113: .line 2390
            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
       114: .line 2392
      StackMap locals:
      StackMap stack:
            aload 15 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
            ifnonnull 116
       115: .line 2393
            aload 15 /* entry */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
       116: .line 2395
      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
       117: .line 2396
            aload 11 /* alias */
            ifnonnull 119
       118: .line 2397
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getUnfriendlyName:()Ljava/lang/String;
            astore 11 /* alias */
       119: .line 2399
      StackMap locals:
      StackMap stack:
            aload 15 /* entry */
            aload 11 /* alias */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.alias:Ljava/lang/String;
       120: .line 2400
            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
       121: .line 2402
            goto 141
      StackMap locals:
      StackMap stack:
       122: aload 9 /* bagItem */
            instanceof java.security.cert.X509Certificate
            ifeq 141
       123: .line 2403
            aload 9 /* bagItem */
            checkcast java.security.cert.X509Certificate
            astore 15 /* cert */
        start local 15 // java.security.cert.X509Certificate cert
       124: .line 2408
            aload 12 /* keyId */
            ifnonnull 127
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            if_icmpne 127
       125: .line 2410
            iload 5 /* i */
            ifne 127
       126: .line 2411
            ldc "01"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 12 /* keyId */
       127: .line 2415
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 13 /* trustedKeyUsage */
            ifnull 136
       128: .line 2416
            aload 11 /* alias */
            ifnonnull 130
       129: .line 2417
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getUnfriendlyName:()Ljava/lang/String;
            astore 11 /* alias */
       130: .line 2420
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs12.PKCS12KeyStore$CertEntry
            dup
            aload 15 /* cert */
            aload 12 /* keyId */
            aload 11 /* alias */
            aload 13 /* trustedKeyUsage */
       131: .line 2421
            aload 14 /* attributes */
       132: .line 2420
            invokespecial sun.security.pkcs12.PKCS12KeyStore$CertEntry.<init>:(Ljava/security/cert/X509Certificate;[BLjava/lang/String;[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)V
       133: .line 2419
            astore 16 /* certEntry */
        start local 16 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
       134: .line 2422
            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
       135: .line 2423
            goto 137
       136: .line 2424
      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
       137: .line 2426
      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
       138: .line 2427
            aload 16 /* subjectDN */
            ifnull 141
       139: .line 2428
            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 141
       140: .line 2429
            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
       141: .line 2246
      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:
       142: iload 5 /* i */
            iload 4 /* count */
            if_icmplt 4
        end local 5 // int i
       143: .line 2434
            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  144     0             this  Lsun/security/pkcs12/PKCS12KeyStore;
            0  144     1           stream  Lsun/security/util/DerInputStream;
            0  144     2         password  [C
            1  144     3         safeBags  [Lsun/security/util/DerValue;
            2  144     4            count  I
            3  143     5                i  I
            7  141     6            bagId  Lsun/security/util/ObjectIdentifier;
            6  141     7              sbi  Lsun/security/util/DerInputStream;
            8  141     8         bagValue  Lsun/security/util/DerValue;
            5  141     9          bagItem  Ljava/lang/Object;
           15   18    10           kEntry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
           21   34    10               cs  Lsun/security/util/DerInputStream;
           22   34    11       certValues  [Lsun/security/util/DerValue;
           28   34    12        certValue  Lsun/security/util/DerValue;
           29   34    13               cf  Ljava/security/cert/CertificateFactory;
           32   34    14             cert  Ljava/security/cert/X509Certificate;
           37   50    10               ss  Lsun/security/util/DerInputStream;
           38   50    11     secretValues  [Lsun/security/util/DerValue;
           46   50    12      secretValue  Lsun/security/util/DerValue;
           47   50    13           kEntry  Lsun/security/pkcs12/PKCS12KeyStore$SecretKeyEntry;
           54   55    10          attrSet  [Lsun/security/util/DerValue;
           57  141    10          attrSet  [Lsun/security/util/DerValue;
           58  141    11            alias  Ljava/lang/String;
           59  141    12            keyId  [B
           60  141    13  trustedKeyUsage  [Lsun/security/util/ObjectIdentifier;
           61  141    14       attributes  Ljava/util/Set<Ljava/security/PKCS12Attribute;>;
           63   93    15                j  I
           65   91    16          encoded  [B
           66   91    17               as  Lsun/security/util/DerInputStream;
           67   91    18          attrSeq  [Lsun/security/util/DerValue;
           68   91    19           attrId  Lsun/security/util/ObjectIdentifier;
           70   91    20               vs  Lsun/security/util/DerInputStream;
           71   72    21           valSet  [Lsun/security/util/DerValue;
           76   91    21           valSet  [Lsun/security/util/DerValue;
           73   76    22                e  Ljava/io/IOException;
           85   89    22                k  I
           95  121    15            entry  Lsun/security/pkcs12/PKCS12KeyStore$KeyEntry;
          101  121    16         keyIdStr  Ljava/lang/String;
          102  121    17             date  Ljava/util/Date;
          124  141    15             cert  Ljava/security/cert/X509Certificate;
          134  135    16        certEntry  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
          138  141    16        subjectDN  Ljavax/security/auth/x500/X500Principal;
      Exception table:
        from    to  target  type
          53    54      55  Class java.io.IOException
          70    71      72  Class java.io.IOException
         103   106     107  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 2437
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.counter:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         1: .line 2438
            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;

  public boolean engineProbe(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=11, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.io.InputStream stream
         0: .line 2484
            aload 1 /* stream */
            instanceof java.io.DataInputStream
            ifeq 3
         1: .line 2485
            aload 1 /* stream */
            checkcast java.io.DataInputStream
            astore 2 /* dataStream */
        start local 2 // java.io.DataInputStream dataStream
         2: .line 2486
            goto 4
        end local 2 // java.io.DataInputStream dataStream
         3: .line 2487
      StackMap locals:
      StackMap stack:
            new java.io.DataInputStream
            dup
            aload 1 /* stream */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 2 /* dataStream */
        start local 2 // java.io.DataInputStream dataStream
         4: .line 2490
      StackMap locals: java.io.DataInputStream
      StackMap stack:
            aload 2 /* dataStream */
            invokevirtual java.io.DataInputStream.readLong:()J
            lstore 3 /* firstPeek */
        start local 3 // long firstPeek
         5: .line 2491
            aload 2 /* dataStream */
            invokevirtual java.io.DataInputStream.readLong:()J
            lstore 5 /* nextPeek */
        start local 5 // long nextPeek
         6: .line 2492
            aload 2 /* dataStream */
            invokevirtual java.io.DataInputStream.readLong:()J
            lstore 7 /* finalPeek */
        start local 7 // long finalPeek
         7: .line 2493
            iconst_0
            istore 9 /* result */
        start local 9 // boolean result
         8: .line 2495
            iconst_0
            istore 10 /* i */
        start local 10 // int i
         9: goto 22
        10: .line 2496
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.io.InputStream java.io.DataInputStream long long long int int
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
            iload 10 /* i */
            aaload
            iconst_0
            laload
        11: .line 2497
            lload 3 /* firstPeek */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
            iload 10 /* i */
            aaload
            iconst_0
            laload
            land
        12: .line 2496
            lcmp
            ifne 21
        13: .line 2498
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
            iload 10 /* i */
            aaload
            iconst_1
            laload
        14: .line 2499
            lload 5 /* nextPeek */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
            iload 10 /* i */
            aaload
            iconst_1
            laload
            land
        15: .line 2498
            lcmp
            ifne 21
        16: .line 2500
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
            iload 10 /* i */
            aaload
            iconst_2
            laload
        17: .line 2501
            lload 7 /* finalPeek */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
            iload 10 /* i */
            aaload
            iconst_2
            laload
            land
        18: .line 2500
            lcmp
            ifne 21
        19: .line 2502
            iconst_1
            istore 9 /* result */
        20: .line 2503
            goto 23
        21: .line 2495
      StackMap locals:
      StackMap stack:
            iinc 10 /* i */ 1
      StackMap locals:
      StackMap stack:
        22: iload 10 /* i */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
            arraylength
            if_icmplt 10
        end local 10 // int i
        23: .line 2507
      StackMap locals:
      StackMap stack:
            iload 9 /* result */
            ireturn
        end local 9 // boolean result
        end local 7 // long finalPeek
        end local 5 // long nextPeek
        end local 3 // long firstPeek
        end local 2 // java.io.DataInputStream dataStream
        end local 1 // java.io.InputStream stream
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   24     0        this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   24     1      stream  Ljava/io/InputStream;
            2    3     2  dataStream  Ljava/io/DataInputStream;
            4   24     2  dataStream  Ljava/io/DataInputStream;
            5   24     3   firstPeek  J
            6   24     5    nextPeek  J
            7   24     7   finalPeek  J
            8   24     9      result  Z
            9   23    10           i  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
        Name  Flags
      stream  
}
SourceFile: "PKCS12KeyStore.java"
NestMembers:
  sun.security.pkcs12.PKCS12KeyStore$1  sun.security.pkcs12.PKCS12KeyStore$CertEntry  sun.security.pkcs12.PKCS12KeyStore$DualFormatPKCS12  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 abstract Attribute = java.security.KeyStore$Entry$Attribute of java.security.KeyStore$Entry
  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
  sun.security.pkcs12.PKCS12KeyStore$1
  private CertEntry = sun.security.pkcs12.PKCS12KeyStore$CertEntry of sun.security.pkcs12.PKCS12KeyStore
  public final DualFormatPKCS12 = sun.security.pkcs12.PKCS12KeyStore$DualFormatPKCS12 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