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

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

  private static final int 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[] 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 final sun.security.util.ObjectIdentifier PKCS8ShroudedKeyBag_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

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

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

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

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

  private static final sun.security.util.ObjectIdentifier pbes2_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

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

  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.lang.String certProtectionAlgorithm;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

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

  private java.lang.String macAlgorithm;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private int macIterationCount;
    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=1, args_size=0
         0: .line 148
            iconst_3
            anewarray java.lang.String
            dup
            iconst_0
         1: .line 149
            ldc "1.2.840.113549.1.9.20"
            aastore
            dup
            iconst_1
         2: .line 150
            ldc "1.2.840.113549.1.9.21"
            aastore
            dup
            iconst_2
         3: .line 151
            ldc "2.16.840.1.113894.746875.1.1"
            aastore
         4: .line 148
            putstatic sun.security.pkcs12.PKCS12KeyStore.CORE_ATTRIBUTES:[Ljava/lang/String;
         5: .line 154
            ldc "pkcs12"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
         6: .line 156
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            bipush 10
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_2
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.keyBag:[I
         7: .line 157
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            bipush 10
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_3
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.certBag:[I
         8: .line 158
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 12
            iastore
            dup
            bipush 6
            bipush 10
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_5
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.secretBag:[I
         9: .line 160
            bipush 7
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 9
            iastore
            dup
            bipush 6
            bipush 20
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9Name:[I
        10: .line 161
            bipush 7
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 9
            iastore
            dup
            bipush 6
            bipush 21
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9KeyId:[I
        11: .line 163
            bipush 8
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            bipush 9
            iastore
            dup
            bipush 6
            bipush 22
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            putstatic sun.security.pkcs12.PKCS12KeyStore.pkcs9certType:[I
        12: .line 165
            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
        13: .line 172
            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
        14: .line 171
            putstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage:[I
        15: .line 173
            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
        16: .line 214
            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;
        17: .line 215
            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;
        18: .line 216
            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;
        19: .line 217
            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;
        20: .line 218
            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;
        21: .line 219
            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;
        22: .line 220
            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;
        23: .line 221
            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;
        24: .line 222
            iconst_1
            anewarray sun.security.util.ObjectIdentifier
            dup
            iconst_0
        25: .line 223
            new sun.security.util.ObjectIdentifier
            dup
            getstatic sun.security.pkcs12.PKCS12KeyStore.AnyExtendedKeyUsage:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            aastore
        26: .line 222
            putstatic sun.security.pkcs12.PKCS12KeyStore.AnyUsage:[Lsun/security/util/ObjectIdentifier;
        27: .line 224
            goto 30
      StackMap locals:
      StackMap stack: java.io.IOException
        28: astore 0 /* ioe */
        start local 0 // java.io.IOException ioe
        29: .line 225
            new java.lang.AssertionError
            dup
            ldc "OID not initialized"
            aload 0 /* ioe */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 0 // java.io.IOException ioe
        30: .line 2538
      StackMap locals:
      StackMap stack:
            bipush 8
            anewarray long[]
            dup
            iconst_0
        31: .line 2539
            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
        32: .line 2540
            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
        33: .line 2541
            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
        34: .line 2542
            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
        35: .line 2543
            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
        36: .line 2544
            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
        37: .line 2545
            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
        38: .line 2546
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc 3495919210746348033
            lastore
            dup
            iconst_1
            ldc 229828716530761734
            lastore
            dup
            iconst_2
            ldc 660487941423303937
            lastore
            aastore
        39: .line 2538
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
        40: .line 2549
            bipush 8
            anewarray long[]
            dup
            iconst_0
        41: .line 2550
            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
        42: .line 2551
            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
        43: .line 2552
            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
        44: .line 2553
            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
        45: .line 2554
            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
        46: .line 2555
            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
        47: .line 2556
            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
        48: .line 2557
            iconst_3
            newarray 11
            dup
            iconst_0
            ldc -281474976645121
            lastore
            dup
            iconst_1
            ldc -1099511627521
            lastore
            dup
            iconst_2
            ldc -1
            lastore
            aastore
        49: .line 2549
            putstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
        50: .line 2558
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
           29   30     0   ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
          16    27      28  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 133
            aload 0 /* this */
            invokespecial java.security.KeyStoreSpi.<init>:()V
         1: .line 185
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         2: .line 190
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
         3: .line 193
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
         4: .line 196
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
         5: .line 204
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
         6: .line 205
            aload 0 /* this */
            iconst_m1
            putfield sun.security.pkcs12.PKCS12KeyStore.certPbeIterationCount:I
         7: .line 206
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
         8: .line 207
            aload 0 /* this */
            iconst_m1
            putfield sun.security.pkcs12.PKCS12KeyStore.macIterationCount:I
         9: .line 305
            aload 0 /* this */
        10: .line 306
            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;
        11: .line 308
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
        12: .line 309
            aload 0 /* this */
        13: .line 310
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
        14: .line 311
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
        15: .line 133
            return
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   16     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=7, locals=12, 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 331
            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 332
            aconst_null
            astore 4 /* key */
        start local 4 // java.security.Key key
         2: .line 334
            aload 3 /* entry */
            ifnull 3
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifne 4
         3: .line 335
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry java.security.Key
      StackMap stack:
            aconst_null
            areturn
         4: .line 339
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 5 /* encrBytes */
        start local 5 // byte[] encrBytes
         5: .line 340
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 8
         6: .line 341
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
            astore 5 /* encrBytes */
         7: .line 342
            goto 12
      StackMap locals: byte[]
      StackMap stack:
         8: aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 11
         9: .line 343
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
            astore 5 /* encrBytes */
        10: .line 344
            goto 12
        11: .line 345
      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 355
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 5 /* encrBytes */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
        13: .line 354
            astore 9 /* encrInfo */
        start local 9 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        14: .line 356
            aload 9 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncryptedData:()[B
            astore 6 /* encryptedKey */
        start local 6 // byte[] encryptedKey
        15: .line 359
            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 360
            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 361
            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 362
            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 364
            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 366
            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 367
            aload 9 /* ioe */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        23: .line 366
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        24: .line 365
            astore 10 /* uke */
        start local 10 // java.security.UnrecoverableKeyException uke
        25: .line 368
            aload 10 /* uke */
            aload 9 /* ioe */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        26: .line 369
            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 376
      StackMap locals: byte[] java.security.AlgorithmParameters sun.security.util.ObjectIdentifier
      StackMap stack:
            aload 7 /* algParams */
            ifnull 36
        28: .line 379
            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
        29: .line 378
            astore 9 /* pbeSpec */
        start local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
        30: .line 380
            goto 33
        end local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
      StackMap locals:
      StackMap stack: java.security.spec.InvalidParameterSpecException
        31: pop
        32: .line 381
            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
        33: .line 383
      StackMap locals: javax.crypto.spec.PBEParameterSpec
      StackMap stack:
            aload 9 /* pbeSpec */
            invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
            istore 10 /* ic */
        start local 10 // int ic
        34: .line 385
            iload 10 /* ic */
            ldc 5000000
            if_icmple 37
        35: .line 386
            new java.io.IOException
            dup
            ldc "key PBE iteration count too large"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 10 // int ic
        end local 9 // javax.crypto.spec.PBEParameterSpec pbeSpec
        36: .line 389
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 10 /* ic */
        start local 10 // int ic
        37: .line 392
      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 8 /* algOid */
            aload 7 /* algParams */
            aload 6 /* encryptedKey */
            aload 3 /* entry */
            aload 1 /* alias */
            iload 10 /* ic */
            invokedynamic tryOnce(Lsun/security/pkcs12/PKCS12KeyStore;Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;[BLsun/security/pkcs12/PKCS12KeyStore$Entry;Ljava/lang/String;I)Lsun/security/pkcs12/PKCS12KeyStore$RetryWithZero;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ([C)Ljava/lang/Object;
                  sun/security/pkcs12/PKCS12KeyStore.lambda$0(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;[BLsun/security/pkcs12/PKCS12KeyStore$Entry;Ljava/lang/String;I[C)Ljava/security/Key; (7)
                  ([C)Ljava/security/Key;
        38: .line 449
            aload 2 /* password */
        39: .line 392
            invokestatic sun.security.pkcs12.PKCS12KeyStore$RetryWithZero.run:(Lsun/security/pkcs12/PKCS12KeyStore$RetryWithZero;[C)Ljava/lang/Object;
            checkcast java.security.Key
            astore 4 /* key */
        end local 10 // int ic
        40: .line 451
            goto 48
      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
        41: astore 9 /* e */
        start local 9 // java.lang.Exception e
        42: .line 453
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Get Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        43: .line 454
            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;
        44: .line 453
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        45: .line 452
            astore 10 /* uke */
        start local 10 // java.security.UnrecoverableKeyException uke
        46: .line 455
            aload 10 /* uke */
            aload 9 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        47: .line 456
            aload 10 /* uke */
            athrow
        end local 10 // java.security.UnrecoverableKeyException uke
        end local 9 // java.lang.Exception e
        48: .line 458
      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   49     0          this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   49     1         alias  Ljava/lang/String;
            0   49     2      password  [C
            1   49     3         entry  Lsun/security/pkcs12/PKCS12KeyStore$Entry;
            2   49     4           key  Ljava/security/Key;
            5   49     5     encrBytes  [B
           15   20     6  encryptedKey  [B
           27   49     6  encryptedKey  [B
           19   20     7     algParams  Ljava/security/AlgorithmParameters;
           27   49     7     algParams  Ljava/security/AlgorithmParameters;
           18   20     8        algOid  Lsun/security/util/ObjectIdentifier;
           27   49     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;
           30   31     9       pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           33   36     9       pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           34   36    10            ic  I
           37   40    10            ic  I
           42   48     9             e  Ljava/lang/Exception;
           46   48    10           uke  Ljava/security/UnrecoverableKeyException;
      Exception table:
        from    to  target  type
          12    19      20  Class java.io.IOException
          28    30      31  Class java.security.spec.InvalidParameterSpecException
          27    40      41  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 473
            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 474
            aload 2 /* entry */
            ifnull 10
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 10
         2: .line 475
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 4
         3: .line 476
            aconst_null
            areturn
         4: .line 479
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 9
         5: .line 480
            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 481
            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 482
            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 480
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         9: .line 485
      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 488
      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 508
            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 509
            aload 2 /* entry */
            ifnonnull 3
         2: .line 510
            aconst_null
            areturn
         3: .line 512
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 18
         4: .line 513
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 18
         5: .line 515
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 17
         6: .line 516
            getstatic sun.security.pkcs12.PKCS12KeyStore.AnyUsage:[Lsun/security/util/ObjectIdentifier;
         7: .line 517
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
         8: .line 516
            invokestatic java.util.Arrays.equals:([Ljava/lang/Object;[Ljava/lang/Object;)Z
         9: .line 517
            ifeq 14
        10: .line 518
            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 519
            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 518
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 520
            goto 17
        14: .line 521
      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 522
            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 521
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        17: .line 526
      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 528
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 26
        19: .line 529
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnonnull 21
        20: .line 530
            aconst_null
            areturn
        21: .line 533
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 25
        22: .line 534
            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 535
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        24: .line 534
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        25: .line 538
      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 542
      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 555
            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 556
            aload 2 /* entry */
            ifnull 3
         2: .line 557
            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 559
      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 590
            new java.security.KeyStore$PasswordProtection
            dup
            aload 3 /* password */
            invokespecial java.security.KeyStore$PasswordProtection.<init>:([C)V
         1: .line 589
            astore 5 /* passwordProtection */
        start local 5 // java.security.KeyStore$PasswordProtection passwordProtection
         2: .line 593
            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 595
            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 597
            aload 5 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.destroy:()V
         6: .line 598
            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 601
      StackMap locals:
      StackMap stack:
            aload 6
            athrow
         9: .line 597
      StackMap locals:
      StackMap stack:
            aload 5 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.destroy:()V
        10: .line 598
            goto 12
      StackMap locals:
      StackMap stack: javax.security.auth.DestroyFailedException
        11: pop
        12: .line 602
      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 615
            aload 2 /* key */
            instanceof java.security.PrivateKey
            ifeq 29
         1: .line 617
            aload 4 /* chain */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.checkX509Certs:([Ljava/security/cert/Certificate;)V
         2: .line 619
            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 620
            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 622
            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 623
            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 625
      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 626
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
         8: .line 627
            new java.lang.StringBuilder
            dup
            ldc "Setting a protected private key at alias '"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         9: .line 628
            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 627
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        11: .line 626
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 632
      StackMap locals:
      StackMap stack:
            aload 7 /* keyEntry */
        13: .line 633
            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 632
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        15: .line 634
            goto 17
        16: .line 635
      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 640
      StackMap locals:
      StackMap stack:
            aload 4 /* chain */
            ifnull 26
        18: .line 642
            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 643
            new java.security.KeyStoreException
            dup
            ldc "Certificate chain is not valid"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 645
      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 646
            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 648
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 26
        23: .line 649
            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 650
            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 649
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        26: .line 653
      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 654
            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 656
            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 657
            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 658
            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 661
            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 662
            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 663
            aload 9 /* secretKeyInfo */
            iconst_0
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        35: .line 664
            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 665
            aload 10 /* algId */
            aload 9 /* secretKeyInfo */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
        37: .line 666
            aload 9 /* secretKeyInfo */
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        38: .line 667
            aload 8 /* pkcs8 */
            bipush 48
            aload 9 /* secretKeyInfo */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        39: .line 670
            aload 7 /* keyEntry */
        40: .line 671
            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 670
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        42: .line 673
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 46
        43: .line 674
            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 675
            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 674
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        46: .line 677
      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 678
            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 680
            goto 50
        end local 6 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        49: .line 681
      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 684
      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 685
            aload 5 /* attributes */
            ifnull 53
        52: .line 686
            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 689
      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 691
            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 693
            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 695
            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 696
            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 697
            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 696
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.lang.Exception nsae
        61: .line 699
      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 729
            aload 3 /* chain */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.checkX509Certs:([Ljava/security/cert/Certificate;)V
         1: .line 734
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            aload 2 /* key */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
         2: .line 735
            goto 7
      StackMap locals:
      StackMap stack: java.io.IOException
         3: astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
         4: .line 736
            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 737
            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 736
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.io.IOException ioe
         7: .line 740
      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 741
            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 743
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 13
        10: .line 744
            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 745
            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 744
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        13: .line 750
      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 751
            goto 16
      StackMap locals:
      StackMap stack: java.io.UnsupportedEncodingException
        15: pop
        16: .line 755
      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 757
            aload 4 /* entry */
            aload 2 /* key */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        18: .line 758
            aload 3 /* chain */
            ifnull 27
        19: .line 760
            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 761
            new java.security.KeyStoreException
            dup
            ldc "Certificate chain is not valid"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 764
      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 765
            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 767
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 27
        24: .line 768
            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 769
            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 768
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        27: .line 774
      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 775
            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 776
            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 785
            bipush 20
            newarray 8
            astore 1 /* salt */
        start local 1 // byte[] salt
         1: .line 786
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.random:Ljava/security/SecureRandom;
            ifnonnull 3
         2: .line 787
            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 789
      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 790
            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, int);
    descriptor: (Ljava/lang/String;I)Ljava/security/AlgorithmParameters;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // java.lang.String algorithm
        start local 2 // int iterationCount
         0: .line 798
            aconst_null
            astore 3 /* algParams */
        start local 3 // java.security.AlgorithmParameters algParams
         1: .line 802
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getSalt:()[B
            iload 2 /* iterationCount */
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
         2: .line 801
            astore 4 /* paramSpec */
        start local 4 // javax.crypto.spec.PBEParameterSpec paramSpec
         3: .line 804
            aload 1 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 3 /* algParams */
         4: .line 805
            aload 3 /* algParams */
            aload 4 /* paramSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         5: .line 806
            goto 10
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore java.lang.String int java.security.AlgorithmParameters javax.crypto.spec.PBEParameterSpec
      StackMap stack: java.lang.Exception
         6: astore 5 /* e */
        start local 5 // java.lang.Exception e
         7: .line 807
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getPBEAlgorithmParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 808
            aload 5 /* 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 5 /* e */
         9: .line 807
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.lang.Exception e
        10: .line 810
      StackMap locals:
      StackMap stack:
            aload 3 /* algParams */
            areturn
        end local 4 // javax.crypto.spec.PBEParameterSpec paramSpec
        end local 3 // java.security.AlgorithmParameters algParams
        end local 2 // int iterationCount
        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;
            0   11     2  iterationCount  I
            1   11     3       algParams  Ljava/security/AlgorithmParameters;
            3   11     4       paramSpec  Ljavax/crypto/spec/PBEParameterSpec;
            7   10     5               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       
      iterationCount  

  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 819
            aconst_null
            astore 3 /* algParams */
        start local 3 // java.security.AlgorithmParameters algParams
         1: .line 822
            aload 2 /* in */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifne 4
         2: .line 823
            aconst_null
            astore 4 /* params */
        start local 4 // sun.security.util.DerValue params
         3: .line 824
            goto 7
        end local 4 // sun.security.util.DerValue params
         4: .line 825
      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 826
            aload 4 /* params */
            getfield sun.security.util.DerValue.tag:B
            iconst_5
            if_icmpne 7
         6: .line 827
            aconst_null
            astore 4 /* params */
         7: .line 830
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 4 /* params */
            ifnull 18
         8: .line 831
            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 832
            ldc "PBES2"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 3 /* algParams */
        10: .line 833
            goto 12
        11: .line 834
      StackMap locals:
      StackMap stack:
            ldc "PBE"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            astore 3 /* algParams */
        12: .line 836
      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 838
            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 839
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "parseAlgParameters failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        16: .line 840
            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 839
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Exception e
        18: .line 842
      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 850
            aconst_null
            astore 2 /* skey */
        start local 2 // javax.crypto.SecretKey skey
         1: .line 853
            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 854
            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 855
            aload 4 /* skFac */
            aload 3 /* keySpec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            astore 2 /* skey */
         4: .line 856
            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 857
            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 858
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "getSecretKey failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 859
            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 858
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        10: .line 861
      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 878
            aconst_null
            astore 3 /* key */
        start local 3 // byte[] key
         1: .line 886
            aload 2 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.getProtectionAlgorithm:()Ljava/lang/String;
            astore 4 /* algorithm */
        start local 4 // java.lang.String algorithm
         2: .line 887
            aload 4 /* algorithm */
            ifnull 13
         3: .line 889
            aload 2 /* passwordProtection */
            invokevirtual java.security.KeyStore$PasswordProtection.getProtectionParameters:()Ljava/security/spec/AlgorithmParameterSpec;
         4: .line 888
            astore 7 /* algParamSpec */
        start local 7 // java.security.spec.AlgorithmParameterSpec algParamSpec
         5: .line 890
            aload 7 /* algParamSpec */
            ifnull 9
         6: .line 891
            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 892
            aload 5 /* algParams */
            aload 7 /* algParamSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         8: .line 893
            goto 17
        end local 5 // java.security.AlgorithmParameters algParams
         9: .line 894
      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 */
        10: .line 895
            invokestatic sun.security.pkcs12.PKCS12KeyStore.defaultKeyPbeIterationCount:()I
        11: .line 894
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;I)Ljava/security/AlgorithmParameters;
            astore 5 /* algParams */
        end local 7 // java.security.spec.AlgorithmParameterSpec algParamSpec
        start local 5 // java.security.AlgorithmParameters algParams
        12: .line 897
            goto 17
        end local 5 // java.security.AlgorithmParameters algParams
        13: .line 899
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] java.security.KeyStore$PasswordProtection byte[] java.lang.String
      StackMap stack:
            invokestatic sun.security.pkcs12.PKCS12KeyStore.defaultKeyProtectionAlgorithm:()Ljava/lang/String;
            astore 4 /* algorithm */
        14: .line 900
            aload 0 /* this */
            aload 4 /* algorithm */
        15: .line 901
            invokestatic sun.security.pkcs12.PKCS12KeyStore.defaultKeyPbeIterationCount:()I
        16: .line 900
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;I)Ljava/security/AlgorithmParameters;
            astore 5 /* algParams */
        start local 5 // java.security.AlgorithmParameters algParams
        17: .line 904
      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
        18: .line 905
            aload 7 /* pbeOID */
            ifnonnull 22
        19: .line 906
            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;
        20: .line 907
            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;
        21: .line 906
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 911
      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
        23: .line 912
            aload 4 /* algorithm */
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 9 /* cipher */
        start local 9 // javax.crypto.Cipher cipher
        24: .line 913
            aload 9 /* cipher */
            iconst_1
            aload 8 /* skey */
            aload 5 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        25: .line 914
            aload 9 /* cipher */
            aload 1 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 10 /* encryptedKey */
        start local 10 // byte[] encryptedKey
        26: .line 915
            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
        27: .line 917
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 31
        28: .line 918
            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;
        29: .line 919
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        30: .line 918
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        31: .line 925
      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
        32: .line 924
            astore 11 /* encrInfo */
        start local 11 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        33: .line 926
            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
        34: .line 927
            goto 42
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] java.security.KeyStore$PasswordProtection byte[]
      StackMap stack: java.lang.Exception
        35: astore 4 /* e */
        start local 4 // java.lang.Exception e
        36: .line 929
            new java.security.UnrecoverableKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Encrypt Private Key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        37: .line 930
            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;
        38: .line 929
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        39: .line 928
            astore 5 /* uke */
        start local 5 // java.security.UnrecoverableKeyException uke
        40: .line 931
            aload 5 /* uke */
            aload 4 /* e */
            invokevirtual java.security.UnrecoverableKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        41: .line 932
            aload 5 /* uke */
            athrow
        end local 5 // java.security.UnrecoverableKeyException uke
        end local 4 // java.lang.Exception e
        42: .line 935
      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   43     0                this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   43     1                data  [B
            0   43     2  passwordProtection  Ljava/security/KeyStore$PasswordProtection;
            1   43     3                 key  [B
            2   34     4           algorithm  Ljava/lang/String;
            7    9     5           algParams  Ljava/security/AlgorithmParameters;
           12   13     5           algParams  Ljava/security/AlgorithmParameters;
           17   34     5           algParams  Ljava/security/AlgorithmParameters;
           27   34     6               algid  Lsun/security/x509/AlgorithmId;
            5   12     7        algParamSpec  Ljava/security/spec/AlgorithmParameterSpec;
           18   34     7              pbeOID  Lsun/security/util/ObjectIdentifier;
           23   34     8                skey  Ljavax/crypto/SecretKey;
           24   34     9              cipher  Ljavax/crypto/Cipher;
           26   34    10        encryptedKey  [B
           33   34    11            encrInfo  Lsun/security/pkcs/EncryptedPrivateKeyInfo;
           36   42     4                   e  Ljava/lang/Exception;
           40   42     5                 uke  Ljava/security/UnrecoverableKeyException;
      Exception table:
        from    to  target  type
           1    34      35  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 944
            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 945
            getstatic sun.security.pkcs12.PKCS12KeyStore.pbes2_OID:Lsun/security/util/ObjectIdentifier;
            areturn
         2: .line 947
      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=3, locals=2, args_size=2
        start local 0 // sun.security.util.ObjectIdentifier algorithm
        start local 1 // java.security.AlgorithmParameters algParams
         0: .line 956
            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 957
            aload 1 /* algParams */
            invokevirtual java.security.AlgorithmParameters.toString:()Ljava/lang/String;
            areturn
         2: .line 959
      StackMap locals:
      StackMap stack:
            new sun.security.x509.AlgorithmId
            dup
            aload 0 /* algorithm */
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;)V
            invokevirtual sun.security.x509.AlgorithmId.getName:()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 979
            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 980
            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 989
            aload 2 /* cert */
            ifnull 6
            aload 2 /* cert */
            instanceof java.security.cert.X509Certificate
            ifne 6
         1: .line 990
            new java.security.KeyStoreException
            dup
         2: .line 991
            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 992
            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 991
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 990
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 995
      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 996
            aload 4 /* entry */
            ifnull 9
            aload 4 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 9
         8: .line 997
            new java.security.KeyStoreException
            dup
            ldc "Cannot overwrite own certificate"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 1001
      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 1002
            aload 3 /* attributes */
        11: .line 1001
            invokespecial sun.security.pkcs12.PKCS12KeyStore$CertEntry.<init>:(Ljava/security/cert/X509Certificate;[BLjava/lang/String;[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)V
        12: .line 1000
            astore 5 /* certEntry */
        start local 5 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
        13: .line 1003
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        14: .line 1004
            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 1006
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 19
        16: .line 1007
            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 1008
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 1007
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        19: .line 1010
      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 1022
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 2
         1: .line 1023
            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 1026
      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 1027
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 9
         4: .line 1028
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            astore 3 /* keyEntry */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         5: .line 1029
            aload 3 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 7
         6: .line 1030
            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 1032
      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 1033
            goto 14
      StackMap locals:
      StackMap stack:
         9: aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 12
        10: .line 1034
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        11: .line 1035
            goto 14
      StackMap locals:
      StackMap stack:
        12: aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 14
        13: .line 1036
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            iconst_1
            isub
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        14: .line 1038
      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 1039
            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 1047
            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 1058
            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 1067
            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 1078
            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 1079
            aload 2 /* entry */
            ifnull 3
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 3
         2: .line 1080
            iconst_1
            ireturn
         3: .line 1082
      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 1094
            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 1095
            aload 2 /* entry */
            ifnull 4
            aload 2 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 4
         2: .line 1096
            aload 2 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 4
         3: .line 1097
            iconst_1
            ireturn
         4: .line 1099
      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 1122
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$TrustedCertificateEntry;
            if_acmpne 2
         1: .line 1123
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ireturn
         2: .line 1126
      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 1127
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$PrivateKeyEntry;
            if_acmpne 6
         4: .line 1128
            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 1130
      StackMap locals:
      StackMap stack:
            aload 2 /* entryClass */
            ldc Ljava/security/KeyStore$SecretKeyEntry;
            if_acmpne 9
         7: .line 1131
            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 1133
      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 1153
            aconst_null
            astore 2 /* certElem */
        start local 2 // java.security.cert.Certificate certElem
         1: .line 1155
            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 1156
      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 1157
            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 1158
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 9
         6: .line 1159
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 12
         7: .line 1160
            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 1162
            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 1163
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 14
        11: .line 1164
            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 1168
      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 1169
            aload 4 /* alias */
            areturn
        end local 5 // sun.security.pkcs12.PKCS12KeyStore$Entry entry
        end local 4 // java.lang.String alias
        14: .line 1155
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        end local 3 // java.util.Enumeration e
        15: .line 1172
            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=14, 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 1193
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* pfx */
        start local 3 // sun.security.util.DerOutputStream pfx
         1: .line 1196
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 4 /* version */
        start local 4 // sun.security.util.DerOutputStream version
         2: .line 1197
            aload 4 /* version */
            iconst_3
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
         3: .line 1198
            aload 4 /* version */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 5 /* pfxVersion */
        start local 5 // byte[] pfxVersion
         4: .line 1199
            aload 3 /* pfx */
            aload 5 /* pfxVersion */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
         5: .line 1202
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 6 /* authSafe */
        start local 6 // sun.security.util.DerOutputStream authSafe
         6: .line 1205
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 7 /* authSafeContentInfo */
        start local 7 // sun.security.util.DerOutputStream authSafeContentInfo
         7: .line 1208
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            ifgt 8
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            ifle 15
         8: .line 1210
      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 12
         9: .line 1211
            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;
        10: .line 1212
            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;
        11: .line 1211
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        12: .line 1215
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.createSafeContent:()[B
            astore 8 /* safeContentData */
        start local 8 // byte[] safeContentData
        13: .line 1216
            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
        14: .line 1217
            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
        15: .line 1221
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            ifle 34
        16: .line 1223
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
            ifnonnull 18
        17: .line 1224
            aload 0 /* this */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.defaultCertProtectionAlgorithm:()Ljava/lang/String;
            putfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
        18: .line 1226
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certPbeIterationCount:I
            ifge 20
        19: .line 1227
            aload 0 /* this */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.defaultCertPbeIterationCount:()I
            putfield sun.security.pkcs12.PKCS12KeyStore.certPbeIterationCount:I
        20: .line 1230
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 24
        21: .line 1231
            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;
        22: .line 1232
            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;
        23: .line 1231
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        24: .line 1235
      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
        25: .line 1236
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
            ldc "NONE"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 32
        26: .line 1238
            new sun.security.pkcs.ContentInfo
            dup
            getstatic sun.security.pkcs.ContentInfo.ENCRYPTED_DATA_OID:Lsun/security/util/ObjectIdentifier;
        27: .line 1239
            new sun.security.util.DerValue
            dup
            aload 8 /* encrData */
            invokespecial sun.security.util.DerValue.<init>:([B)V
        28: .line 1238
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/ObjectIdentifier;Lsun/security/util/DerValue;)V
        29: .line 1237
            astore 9 /* encrContentInfo */
        start local 9 // sun.security.pkcs.ContentInfo encrContentInfo
        30: .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
        31: .line 1241
            goto 34
        32: .line 1242
      StackMap locals: byte[]
      StackMap stack:
            new sun.security.pkcs.ContentInfo
            dup
            aload 8 /* encrData */
            invokespecial sun.security.pkcs.ContentInfo.<init>:([B)V
            astore 9 /* dataContentInfo */
        start local 9 // sun.security.pkcs.ContentInfo dataContentInfo
        33: .line 1243
            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[] encrData
        34: .line 1248
      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
        35: .line 1249
            aload 8 /* cInfo */
            bipush 48
            aload 7 /* authSafeContentInfo */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        36: .line 1250
            aload 8 /* cInfo */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 9 /* authenticatedSafe */
        start local 9 // byte[] authenticatedSafe
        37: .line 1253
            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
        38: .line 1254
            aload 10 /* contentInfo */
            aload 6 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.encode:(Lsun/security/util/DerOutputStream;)V
        39: .line 1255
            aload 6 /* authSafe */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 11 /* authSafeData */
        start local 11 // byte[] authSafeData
        40: .line 1256
            aload 3 /* pfx */
            aload 11 /* authSafeData */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        41: .line 1259
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
            ifnonnull 43
        42: .line 1260
            aload 0 /* this */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.defaultMacAlgorithm:()Ljava/lang/String;
            putfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
        43: .line 1262
      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 sun.security.util.DerOutputStream byte[] sun.security.pkcs.ContentInfo byte[]
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macIterationCount:I
            ifge 45
        44: .line 1263
            aload 0 /* this */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.defaultMacIterationCount:()I
            putfield sun.security.pkcs12.PKCS12KeyStore.macIterationCount:I
        45: .line 1265
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
            ldc "NONE"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 48
        46: .line 1266
            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
        47: .line 1267
            aload 3 /* pfx */
            aload 12 /* macData */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        end local 12 // byte[] macData
        48: .line 1270
      StackMap locals:
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 12 /* pfxout */
        start local 12 // sun.security.util.DerOutputStream pfxout
        49: .line 1271
            aload 12 /* pfxout */
            bipush 48
            aload 3 /* pfx */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        50: .line 1272
            aload 12 /* pfxout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 13 /* pfxData */
        start local 13 // byte[] pfxData
        51: .line 1273
            aload 1 /* stream */
            aload 13 /* pfxData */
            invokevirtual java.io.OutputStream.write:([B)V
        52: .line 1274
            aload 1 /* stream */
            invokevirtual java.io.OutputStream.flush:()V
        53: .line 1275
            return
        end local 13 // byte[] pfxData
        end local 12 // sun.security.util.DerOutputStream pfxout
        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   54     0                 this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   54     1               stream  Ljava/io/OutputStream;
            0   54     2             password  [C
            1   54     3                  pfx  Lsun/security/util/DerOutputStream;
            2   54     4              version  Lsun/security/util/DerOutputStream;
            4   54     5           pfxVersion  [B
            6   54     6             authSafe  Lsun/security/util/DerOutputStream;
            7   54     7  authSafeContentInfo  Lsun/security/util/DerOutputStream;
           13   15     8      safeContentData  [B
           14   15     9      dataContentInfo  Lsun/security/pkcs/ContentInfo;
           25   34     8             encrData  [B
           30   31     9      encrContentInfo  Lsun/security/pkcs/ContentInfo;
           33   34     9      dataContentInfo  Lsun/security/pkcs/ContentInfo;
           35   54     8                cInfo  Lsun/security/util/DerOutputStream;
           37   54     9    authenticatedSafe  [B
           38   54    10          contentInfo  Lsun/security/pkcs/ContentInfo;
           40   54    11         authSafeData  [B
           47   48    12              macData  [B
           49   54    12               pfxout  Lsun/security/util/DerOutputStream;
           51   54    13              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 1307
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineContainsAlias:(Ljava/lang/String;)Z
            ifne 2
         1: .line 1308
            aconst_null
            areturn
         2: .line 1311
      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 1312
            aload 2 /* protParam */
            ifnonnull 17
         4: .line 1313
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 14
         5: .line 1314
            aload 3 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 17
         6: .line 1315
            aload 3 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
            ifnull 17
         7: .line 1317
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 11
         8: .line 1318
            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 1319
            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 1318
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        11: .line 1322
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$Entry
      StackMap stack:
            new java.security.KeyStore$TrustedCertificateEntry
            dup
        12: .line 1323
            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 1322
            invokespecial java.security.KeyStore$TrustedCertificateEntry.<init>:(Ljava/security/cert/Certificate;Ljava/util/Set;)V
            areturn
        14: .line 1326
      StackMap locals:
      StackMap stack:
            new java.security.UnrecoverableKeyException
            dup
        15: .line 1327
            ldc "requested entry requires a password"
        16: .line 1326
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 1331
      StackMap locals:
      StackMap stack:
            aload 2 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifeq 40
        18: .line 1332
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsCertificateEntry:(Ljava/lang/String;)Z
            ifeq 22
        19: .line 1333
            new java.lang.UnsupportedOperationException
            dup
        20: .line 1334
            ldc "trusted certificate entries are not password-protected"
        21: .line 1333
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 1335
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifeq 36
        23: .line 1337
            aload 2 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
        24: .line 1336
            astore 4 /* pp */
        start local 4 // java.security.KeyStore$PasswordProtection pp
        25: .line 1338
            aload 4 /* pp */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            astore 5 /* password */
        start local 5 // char[] password
        26: .line 1340
            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 1341
            aload 6 /* key */
            instanceof java.security.PrivateKey
            ifeq 32
        28: .line 1342
            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 1344
            new java.security.KeyStore$PrivateKeyEntry
            dup
            aload 6 /* key */
            checkcast java.security.PrivateKey
            aload 7 /* chain */
        30: .line 1345
            aload 0 /* this */
            aload 3 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getAttributes:(Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
        31: .line 1344
            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 1347
      StackMap locals: java.security.KeyStore$PasswordProtection char[] java.security.Key
      StackMap stack:
            aload 6 /* key */
            instanceof javax.crypto.SecretKey
            ifeq 40
        33: .line 1349
            new java.security.KeyStore$SecretKeyEntry
            dup
            aload 6 /* key */
            checkcast javax.crypto.SecretKey
        34: .line 1350
            aload 0 /* this */
            aload 3 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getAttributes:(Lsun/security/pkcs12/PKCS12KeyStore$Entry;)Ljava/util/Set;
        35: .line 1349
            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 1352
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* alias */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.engineIsKeyEntry:(Ljava/lang/String;)Z
            ifne 40
        37: .line 1353
            new java.lang.UnsupportedOperationException
            dup
        38: .line 1354
            ldc "untrusted certificate entries are not password-protected"
        39: .line 1353
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
        40: .line 1359
      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 1385
            aload 3 /* protParam */
            ifnull 3
         1: .line 1386
            aload 3 /* protParam */
            instanceof java.security.KeyStore$PasswordProtection
            ifne 3
         2: .line 1387
            new java.security.KeyStoreException
            dup
            ldc "unsupported protection parameter"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 1389
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* pProtect */
        start local 4 // java.security.KeyStore$PasswordProtection pProtect
         4: .line 1390
            aload 3 /* protParam */
            ifnull 6
         5: .line 1391
            aload 3 /* protParam */
            checkcast java.security.KeyStore$PasswordProtection
            astore 4 /* pProtect */
         6: .line 1395
      StackMap locals: java.security.KeyStore$PasswordProtection
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$TrustedCertificateEntry
            ifeq 17
         7: .line 1396
            aload 3 /* protParam */
            ifnull 11
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnull 11
         8: .line 1398
            new java.security.KeyStoreException
            dup
         9: .line 1399
            ldc "trusted certificate entries are not password-protected"
        10: .line 1398
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 1402
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            checkcast java.security.KeyStore$TrustedCertificateEntry
        12: .line 1401
            astore 5 /* tce */
        start local 5 // java.security.KeyStore$TrustedCertificateEntry tce
        13: .line 1403
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* tce */
            invokevirtual java.security.KeyStore$TrustedCertificateEntry.getTrustedCertificate:()Ljava/security/cert/Certificate;
        14: .line 1404
            aload 5 /* tce */
            invokevirtual java.security.KeyStore$TrustedCertificateEntry.getAttributes:()Ljava/util/Set;
        15: .line 1403
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.setCertEntry:(Ljava/lang/String;Ljava/security/cert/Certificate;Ljava/util/Set;)V
        16: .line 1406
            return
        end local 5 // java.security.KeyStore$TrustedCertificateEntry tce
        17: .line 1408
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$PrivateKeyEntry
            ifeq 27
        18: .line 1409
            aload 4 /* pProtect */
            ifnull 19
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 22
        19: .line 1411
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        20: .line 1412
            ldc "non-null password required to create PrivateKeyEntry"
        21: .line 1411
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 1414
      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 1415
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* pke */
            invokevirtual java.security.KeyStore$PrivateKeyEntry.getPrivateKey:()Ljava/security/PrivateKey;
            aload 4 /* pProtect */
        24: .line 1416
            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 1415
            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 1418
            return
        end local 5 // java.security.KeyStore$PrivateKeyEntry pke
        27: .line 1420
      StackMap locals:
      StackMap stack:
            aload 2 /* entry */
            instanceof java.security.KeyStore$SecretKeyEntry
            ifeq 37
        28: .line 1421
            aload 4 /* pProtect */
            ifnull 29
            aload 4 /* pProtect */
            invokevirtual java.security.KeyStore$PasswordProtection.getPassword:()[C
            ifnonnull 32
        29: .line 1423
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        30: .line 1424
            ldc "non-null password required to create SecretKeyEntry"
        31: .line 1423
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 1426
      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 1427
            aload 0 /* this */
            aload 1 /* alias */
            aload 5 /* ske */
            invokevirtual java.security.KeyStore$SecretKeyEntry.getSecretKey:()Ljavax/crypto/SecretKey;
            aload 4 /* pProtect */
        34: .line 1428
            aconst_null
            aload 5 /* ske */
            invokevirtual java.security.KeyStore$SecretKeyEntry.getAttributes:()Ljava/util/Set;
        35: .line 1427
            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 1430
            return
        end local 5 // java.security.KeyStore$SecretKeyEntry ske
        37: .line 1434
      StackMap locals:
      StackMap stack:
            new java.security.KeyStoreException
            dup
        38: .line 1435
            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 1434
            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 1443
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            ifnonnull 2
         1: .line 1444
            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 1448
      StackMap locals:
      StackMap stack:
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new java.security.PKCS12Attribute
            dup
         3: .line 1449
            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 1448
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         5: .line 1452
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.keyId:[B
            astore 2 /* keyIdValue */
        start local 2 // byte[] keyIdValue
         6: .line 1453
            aload 2 /* keyIdValue */
            ifnull 10
         7: .line 1454
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new java.security.PKCS12Attribute
            dup
         8: .line 1455
            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 1454
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        10: .line 1459
      StackMap locals: byte[]
      StackMap stack:
            aload 1 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$CertEntry
            ifeq 24
        11: .line 1461
            aload 1 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$CertEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
        12: .line 1460
            astore 3 /* trustedKeyUsageValue */
        start local 3 // sun.security.util.ObjectIdentifier[] trustedKeyUsageValue
        13: .line 1462
            aload 3 /* trustedKeyUsageValue */
            ifnull 24
        14: .line 1463
            aload 3 /* trustedKeyUsageValue */
            arraylength
            iconst_1
            if_icmpne 20
        15: .line 1464
            aload 1 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
            new java.security.PKCS12Attribute
            dup
        16: .line 1465
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        17: .line 1466
            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 1464
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        19: .line 1467
            goto 24
        20: .line 1468
      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 1469
            getstatic sun.security.pkcs12.PKCS12KeyStore.TrustedKeyUsage_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
        22: .line 1470
            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 1468
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // sun.security.util.ObjectIdentifier[] trustedKeyUsageValue
        24: .line 1475
      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[] 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 1487
            aconst_null
            astore 3 /* mData */
        start local 3 // byte[] mData
         1: .line 1488
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
            bipush 7
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 4 /* algName */
        start local 4 // java.lang.String algName
         2: .line 1492
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getSalt:()[B
            astore 5 /* salt */
        start local 5 // byte[] salt
         3: .line 1495
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;)Ljavax/crypto/Mac;
            astore 6 /* m */
        start local 6 // javax.crypto.Mac m
         4: .line 1497
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 5 /* salt */
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macIterationCount:I
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
         5: .line 1496
            astore 7 /* params */
        start local 7 // javax.crypto.spec.PBEParameterSpec params
         6: .line 1498
            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 1499
            aload 6 /* m */
            aload 8 /* key */
            aload 7 /* params */
            invokevirtual javax.crypto.Mac.init:(Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
         8: .line 1500
            aload 6 /* m */
            aload 2 /* data */
            invokevirtual javax.crypto.Mac.update:([B)V
         9: .line 1501
            aload 6 /* m */
            invokevirtual javax.crypto.Mac.doFinal:()[B
            astore 9 /* macResult */
        start local 9 // byte[] macResult
        10: .line 1504
            new sun.security.pkcs12.MacData
            dup
            aload 4 /* algName */
            aload 9 /* macResult */
            aload 5 /* salt */
        11: .line 1505
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macIterationCount:I
        12: .line 1504
            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 1506
            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 1507
            aload 11 /* bytes */
            aload 10 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        15: .line 1508
            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 1509
            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 1510
            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 1512
      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 1521
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 9
         2: .line 1523
      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 1522
            astore 3 /* issuerDN */
        start local 3 // javax.security.auth.x500.X500Principal issuerDN
         4: .line 1525
            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 1524
            astore 4 /* subjectDN */
        start local 4 // javax.security.auth.x500.X500Principal subjectDN
         6: .line 1526
            aload 3 /* issuerDN */
            aload 4 /* subjectDN */
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifne 8
         7: .line 1527
            iconst_0
            ireturn
        end local 4 // javax.security.auth.x500.X500Principal subjectDN
        end local 3 // javax.security.auth.x500.X500Principal issuerDN
         8: .line 1521
      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 1533
            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 1534
            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 1542
            aload 0 /* certs */
            ifnull 11
         1: .line 1543
            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 1544
            aload 1 /* cert */
            instanceof java.security.cert.X509Certificate
            ifne 9
         4: .line 1545
            new java.security.KeyStoreException
            dup
         5: .line 1546
            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 1547
            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 1546
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 1545
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.security.cert.Certificate cert
         9: .line 1543
      StackMap locals:
      StackMap stack:
            iinc 2 1
      StackMap locals:
      StackMap stack:
        10: iload 2
            iload 3
            if_icmplt 2
        11: .line 1551
      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 1590
            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 1597
            aconst_null
            astore 5 /* localKeyID */
        start local 5 // byte[] localKeyID
         1: .line 1598
            aconst_null
            astore 6 /* friendlyName */
        start local 6 // byte[] friendlyName
         2: .line 1599
            aconst_null
            astore 7 /* trustedKeyUsage */
        start local 7 // byte[] trustedKeyUsage
         3: .line 1602
            aload 1 /* alias */
            ifnonnull 5
            aload 2 /* keyId */
            ifnonnull 5
            aload 7 /* trustedKeyUsage */
            ifnonnull 5
         4: .line 1603
            aconst_null
            areturn
         5: .line 1607
      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 1610
            aload 1 /* alias */
            ifnull 15
         7: .line 1611
            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 1612
            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 1613
            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 1614
            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 1615
            aload 10 /* bagAttrContent1 */
            aload 1 /* alias */
            invokevirtual sun.security.util.DerOutputStream.putBMPString:(Ljava/lang/String;)V
        12: .line 1616
            aload 9 /* bagAttr1 */
            bipush 49
            aload 10 /* bagAttrContent1 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        13: .line 1617
            aload 11 /* bagAttrValue1 */
            bipush 48
            aload 9 /* bagAttr1 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        14: .line 1618
            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 1622
      StackMap locals: sun.security.util.DerOutputStream
      StackMap stack:
            aload 2 /* keyId */
            ifnull 24
        16: .line 1623
            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 1624
            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 1625
            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 1626
            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 1627
            aload 10 /* bagAttrContent2 */
            aload 2 /* keyId */
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        21: .line 1628
            aload 9 /* bagAttr2 */
            bipush 49
            aload 10 /* bagAttrContent2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        22: .line 1629
            aload 11 /* bagAttrValue2 */
            bipush 48
            aload 9 /* bagAttr2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        23: .line 1630
            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 1634
      StackMap locals:
      StackMap stack:
            aload 3 /* trustedUsage */
            ifnull 37
        25: .line 1635
            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 1636
            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 1637
            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 1638
            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 1639
            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 1640
            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 1639
            iinc 13 1
      StackMap locals:
      StackMap stack:
        33: iload 13
            iload 14
            if_icmplt 30
        34: .line 1642
            aload 9 /* bagAttr3 */
            bipush 49
            aload 10 /* bagAttrContent3 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        35: .line 1643
            aload 11 /* bagAttrValue3 */
            bipush 48
            aload 9 /* bagAttr3 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        36: .line 1644
            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 1647
      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 1648
            aload 6 /* friendlyName */
            ifnull 40
        39: .line 1649
            aload 9 /* attrs */
            aload 6 /* friendlyName */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        40: .line 1651
      StackMap locals: sun.security.util.DerOutputStream
      StackMap stack:
            aload 5 /* localKeyID */
            ifnull 42
        41: .line 1652
            aload 9 /* attrs */
            aload 5 /* localKeyID */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        42: .line 1654
      StackMap locals:
      StackMap stack:
            aload 7 /* trustedKeyUsage */
            ifnull 44
        43: .line 1655
            aload 9 /* attrs */
            aload 7 /* trustedKeyUsage */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        44: .line 1658
      StackMap locals:
      StackMap stack:
            aload 4 /* attributes */
            ifnull 54
        45: .line 1659
            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 1660
            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 1662
            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 1663
            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 1664
            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 1665
            goto 53
        52: .line 1667
      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 1659
      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 1671
      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 1672
            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 1684
            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 1685
            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 1687
      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 1688
            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 1693
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 12
         6: .line 1694
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            astore 7 /* keyEntry */
        start local 7 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry keyEntry
         7: .line 1695
            aload 7 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
            ifnull 10
         8: .line 1696
            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 1697
            goto 16
        end local 6 // java.security.cert.Certificate[] certs
        10: .line 1698
      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 1700
            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 1701
            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 1702
            goto 16
        end local 6 // java.security.cert.Certificate[] certs
        15: .line 1703
      StackMap locals:
      StackMap stack:
            iconst_0
            anewarray java.security.cert.Certificate
            astore 6 /* certs */
        start local 6 // java.security.cert.Certificate[] certs
        16: .line 1706
      StackMap locals: java.security.cert.Certificate[]
      StackMap stack:
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        17: goto 64
        18: .line 1708
      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 1709
            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 1712
            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 1713
            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 1716
            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 1717
            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 1718
            aload 10 /* certValue */
            aload 11 /* cert */
            invokevirtual java.security.cert.X509Certificate.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        25: .line 1719
            aload 9 /* certBag */
            bipush -128
        26: .line 1720
            iconst_1
            iconst_0
        27: .line 1719
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        28: .line 1720
            aload 10 /* certValue */
        29: .line 1719
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        30: .line 1723
            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 1724
            aload 12 /* certout */
            bipush 48
            aload 9 /* certBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        32: .line 1725
            aload 12 /* certout */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 13 /* certBagValue */
        start local 13 // byte[] certBagValue
        33: .line 1728
            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 1729
            aload 14 /* bagValue */
            aload 13 /* certBagValue */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        35: .line 1731
            aload 8 /* safeBag */
            bipush -128
        36: .line 1732
            iconst_1
            iconst_0
        37: .line 1731
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        38: .line 1732
            aload 14 /* bagValue */
        39: .line 1731
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        40: .line 1737
            aconst_null
            astore 15 /* bagAttrs */
        start local 15 // byte[] bagAttrs
        41: .line 1738
            iload 7 /* i */
            ifne 56
        42: .line 1740
            aload 5 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 49
        43: .line 1741
            aload 5 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 16 /* keyEntry */
        start local 16 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
        44: .line 1743
            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 1744
            aload 16 /* keyEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
        46: .line 1743
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[BLjava/util/Set;)[B
        47: .line 1742
            astore 15 /* bagAttrs */
        end local 16 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
        48: .line 1745
            goto 60
        49: .line 1746
      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 1748
            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 1749
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.trustedKeyUsage:[Lsun/security/util/ObjectIdentifier;
        52: .line 1750
            aload 16 /* certEntry */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.attributes:Ljava/util/Set;
        53: .line 1748
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[B[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)[B
        54: .line 1747
            astore 15 /* bagAttrs */
        end local 16 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
        55: .line 1752
            goto 60
        56: .line 1759
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        57: .line 1760
            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 1761
            aload 5 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$Entry.attributes:Ljava/util/Set;
        59: .line 1759
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getBagAttributes:(Ljava/lang/String;[BLjava/util/Set;)[B
            astore 15 /* bagAttrs */
        60: .line 1763
      StackMap locals:
      StackMap stack:
            aload 15 /* bagAttrs */
            ifnull 62
        61: .line 1764
            aload 8 /* safeBag */
            aload 15 /* bagAttrs */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        62: .line 1768
      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 1706
            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 1685
      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 1773
            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 1774
            aload 3 /* safeBagValue */
            bipush 48
            aload 2 /* out */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        68: .line 1775
            aload 3 /* safeBagValue */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 4 /* safeBagData */
        start local 4 // byte[] safeBagData
        69: .line 1778
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
            ldc "NONE"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 77
        70: .line 1779
            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
        71: .line 1782
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 6 /* encrData */
        start local 6 // sun.security.util.DerOutputStream encrData
        72: .line 1783
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 7 /* encrDataContent */
        start local 7 // sun.security.util.DerOutputStream encrDataContent
        73: .line 1784
            aload 6 /* encrData */
            iconst_0
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        74: .line 1785
            aload 6 /* encrData */
            aload 5 /* encrContentInfo */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        75: .line 1786
            aload 7 /* encrDataContent */
            bipush 48
            aload 6 /* encrData */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        76: .line 1787
            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
        77: .line 1789
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore char[] sun.security.util.DerOutputStream sun.security.util.DerOutputStream byte[]
      StackMap stack:
            aload 4 /* safeBagData */
            areturn
        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   78     0             this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   78     1         password  [C
            1   78     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   78     3     safeBagValue  Lsun/security/util/DerOutputStream;
           69   78     4      safeBagData  [B
           71   77     5  encrContentInfo  [B
           72   77     6         encrData  Lsun/security/util/DerOutputStream;
           73   77     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 1803
            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 1804
            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 1806
      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 1807
            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 1808
            aload 4 /* entry */
            ifnull 54
            aload 4 /* entry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifne 7
         6: .line 1809
            goto 54
         7: .line 1811
      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 1812
            aload 4 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 6 /* keyEntry */
        start local 6 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry keyEntry
         9: .line 1815
            aload 6 /* keyEntry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 27
        10: .line 1817
            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 1820
            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 1821
            aconst_null
            astore 8 /* encrInfo */
        start local 8 // sun.security.pkcs.EncryptedPrivateKeyInfo encrInfo
        13: .line 1823
            new sun.security.pkcs.EncryptedPrivateKeyInfo
            dup
            aload 7 /* encrBytes */
            invokespecial sun.security.pkcs.EncryptedPrivateKeyInfo.<init>:([B)V
            astore 8 /* encrInfo */
        14: .line 1825
            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 1826
            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 1828
            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 1826
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 9 // java.io.IOException ioe
        19: .line 1832
      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 1833
            aload 9 /* bagValue */
            aload 8 /* encrInfo */
            invokevirtual sun.security.pkcs.EncryptedPrivateKeyInfo.getEncoded:()[B
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        21: .line 1834
            aload 5 /* safeBag */
            bipush -128
        22: .line 1835
            iconst_1
            iconst_0
        23: .line 1834
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        24: .line 1835
            aload 9 /* bagValue */
        25: .line 1834
            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 1838
            goto 50
      StackMap locals:
      StackMap stack:
        27: aload 6 /* keyEntry */
            instanceof sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            ifeq 54
        28: .line 1840
            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 1843
            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 1844
            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 1847
            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 1848
            aload 8 /* secretKeyValue */
        33: .line 1849
            aload 6 /* keyEntry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            getfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        34: .line 1848
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        35: .line 1850
            aload 7 /* secretBag */
            bipush -128
        36: .line 1851
            iconst_1
            iconst_0
        37: .line 1850
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        38: .line 1851
            aload 8 /* secretKeyValue */
        39: .line 1850
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        40: .line 1854
            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 1855
            aload 9 /* secretBagSeq */
            bipush 48
            aload 7 /* secretBag */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        42: .line 1856
            aload 9 /* secretBagSeq */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 10 /* secretBagValue */
        start local 10 // byte[] secretBagValue
        43: .line 1859
            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 1860
            aload 11 /* bagValue */
            aload 10 /* secretBagValue */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        45: .line 1863
            aload 5 /* safeBag */
            bipush -128
        46: .line 1864
            iconst_1
            iconst_0
        47: .line 1863
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        48: .line 1864
            aload 11 /* bagValue */
        49: .line 1863
            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 1871
      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 1870
            astore 7 /* bagAttrs */
        start local 7 // byte[] bagAttrs
        52: .line 1872
            aload 5 /* safeBag */
            aload 7 /* bagAttrs */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        53: .line 1875
            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 1804
      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 1879
            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 1880
            aload 2 /* safeBagValue */
            bipush 48
            aload 1 /* out */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        57: .line 1881
            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=13, args_size=3
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // byte[] data
        start local 2 // char[] password
         0: .line 1897
            aconst_null
            astore 3 /* encryptedData */
        start local 3 // byte[] encryptedData
         1: .line 1902
            aload 0 /* this */
         2: .line 1903
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certPbeIterationCount:I
         3: .line 1902
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEAlgorithmParameters:(Ljava/lang/String;I)Ljava/security/AlgorithmParameters;
            astore 4 /* algParams */
        start local 4 // java.security.AlgorithmParameters algParams
         4: .line 1904
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 5 /* bytes */
        start local 5 // sun.security.util.DerOutputStream bytes
         5: .line 1907
            aload 0 /* this */
            aload 2 /* password */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 6 /* skey */
        start local 6 // javax.crypto.SecretKey skey
         6: .line 1908
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 7 /* cipher */
        start local 7 // javax.crypto.Cipher cipher
         7: .line 1909
            aload 7 /* cipher */
            iconst_1
            aload 6 /* skey */
            aload 4 /* algParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
         8: .line 1910
            aload 7 /* cipher */
            aload 1 /* data */
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 3 /* encryptedData */
         9: .line 1912
            new sun.security.x509.AlgorithmId
            dup
        10: .line 1913
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEAlgorithmToOID:(Ljava/lang/String;)Lsun/security/util/ObjectIdentifier;
        11: .line 1914
            aload 7 /* cipher */
            invokevirtual javax.crypto.Cipher.getParameters:()Ljava/security/AlgorithmParameters;
        12: .line 1912
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)V
            astore 8 /* algId */
        start local 8 // sun.security.x509.AlgorithmId algId
        13: .line 1916
            aload 8 /* algId */
            aload 5 /* bytes */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
        14: .line 1917
            aload 5 /* bytes */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            astore 9 /* encodedAlgId */
        start local 9 // byte[] encodedAlgId
        15: .line 1919
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 19
        16: .line 1920
            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 7 /* cipher */
            invokevirtual javax.crypto.Cipher.getAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        17: .line 1921
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 1920
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        19: .line 1925
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] char[] byte[] java.security.AlgorithmParameters sun.security.util.DerOutputStream javax.crypto.SecretKey javax.crypto.Cipher sun.security.x509.AlgorithmId byte[]
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 10 /* bytes2 */
        start local 10 // sun.security.util.DerOutputStream bytes2
        20: .line 1926
            aload 10 /* bytes2 */
            getstatic sun.security.pkcs.ContentInfo.DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        21: .line 1927
            aload 10 /* bytes2 */
            aload 9 /* encodedAlgId */
            invokevirtual sun.security.util.DerOutputStream.write:([B)V
        22: .line 1930
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 11 /* tmpout2 */
        start local 11 // sun.security.util.DerOutputStream tmpout2
        23: .line 1931
            aload 11 /* tmpout2 */
            aload 3 /* encryptedData */
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        24: .line 1932
            aload 10 /* bytes2 */
            bipush -128
        25: .line 1933
            iconst_0
            iconst_0
        26: .line 1932
            invokestatic sun.security.util.DerValue.createTag:(BZB)B
        27: .line 1933
            aload 11 /* tmpout2 */
        28: .line 1932
            invokevirtual sun.security.util.DerOutputStream.writeImplicit:(BLsun/security/util/DerOutputStream;)V
        29: .line 1936
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 12 /* out */
        start local 12 // sun.security.util.DerOutputStream out
        30: .line 1937
            aload 12 /* out */
            bipush 48
            aload 10 /* bytes2 */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        31: .line 1938
            aload 12 /* out */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
        32: areturn
        end local 12 // sun.security.util.DerOutputStream out
        end local 11 // sun.security.util.DerOutputStream tmpout2
        end local 10 // sun.security.util.DerOutputStream bytes2
        end local 9 // byte[] encodedAlgId
        end local 8 // sun.security.x509.AlgorithmId algId
        end local 7 // javax.crypto.Cipher cipher
        end local 6 // javax.crypto.SecretKey skey
        end local 5 // sun.security.util.DerOutputStream bytes
        end local 4 // java.security.AlgorithmParameters algParams
        33: .line 1939
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore byte[] char[] byte[]
      StackMap stack: java.io.IOException
            astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
        34: .line 1940
            aload 4 /* ioe */
            athrow
        end local 4 // java.io.IOException ioe
        35: .line 1941
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 4 /* e */
        start local 4 // java.lang.Exception e
        36: .line 1942
            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
        37: .line 1943
            aload 4 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* e */
        38: .line 1942
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.lang.Exception e
        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   39     0           this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   39     1           data  [B
            0   39     2       password  [C
            1   39     3  encryptedData  [B
            4   33     4      algParams  Ljava/security/AlgorithmParameters;
            5   33     5          bytes  Lsun/security/util/DerOutputStream;
            6   33     6           skey  Ljavax/crypto/SecretKey;
            7   33     7         cipher  Ljavax/crypto/Cipher;
           13   33     8          algId  Lsun/security/x509/AlgorithmId;
           15   33     9   encodedAlgId  [B
           20   33    10         bytes2  Lsun/security/util/DerOutputStream;
           23   33    11        tmpout2  Lsun/security/util/DerOutputStream;
           30   33    12            out  Lsun/security/util/DerOutputStream;
           34   35     4            ioe  Ljava/io/IOException;
           36   39     4              e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    32      33  Class java.io.IOException
           1    32      35  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 1969
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
         1: .line 1970
            aload 0 /* this */
            iconst_m1
            putfield sun.security.pkcs12.PKCS12KeyStore.certPbeIterationCount:I
         2: .line 1971
            aload 0 /* this */
            aconst_null
            putfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
         3: .line 1972
            aload 0 /* this */
            iconst_m1
            putfield sun.security.pkcs12.PKCS12KeyStore.macIterationCount:I
         4: .line 1974
            aload 1 /* stream */
            ifnonnull 6
         5: .line 1975
            return
         6: .line 1978
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         7: .line 1980
            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
         8: .line 1981
            aload 3 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 4 /* s */
        start local 4 // sun.security.util.DerInputStream s
         9: .line 1982
            aload 4 /* s */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            istore 5 /* version */
        start local 5 // int version
        10: .line 1984
            iload 5 /* version */
            iconst_3
            if_icmpeq 12
        11: .line 1985
            new java.io.IOException
            dup
            ldc "PKCS12 keystore not in version 3 format"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 1988
      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
        13: .line 1994
            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
        14: .line 1995
            aload 7 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* contentType */
        start local 8 // sun.security.util.ObjectIdentifier contentType
        15: .line 1997
            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 18
        16: .line 1998
            aload 7 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            astore 6 /* authSafeData */
        start local 6 // byte[] authSafeData
        17: .line 1999
            goto 19
        end local 6 // byte[] authSafeData
        18: .line 2000
      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
        19: .line 2003
      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
        20: .line 2004
            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
        21: .line 2005
            aload 10 /* safeContentsArray */
            arraylength
            istore 11 /* count */
        start local 11 // int count
        22: .line 2008
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        23: .line 2009
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        24: .line 2010
            aload 0 /* this */
            iconst_0
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        25: .line 2012
            iconst_0
            istore 12 /* seeEncBag */
        start local 12 // boolean seeEncBag
        26: .line 2017
            iconst_0
            istore 13 /* i */
        start local 13 // int i
        27: goto 91
        28: .line 2022
      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 int
      StackMap stack:
            new sun.security.util.DerInputStream
            dup
            aload 10 /* safeContentsArray */
            iload 13 /* 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
        29: .line 2023
            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
        30: .line 2024
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
            astore 8 /* contentType */
        31: .line 2025
            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 36
        32: .line 2027
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 34
        33: .line 2028
            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
        34: .line 2031
      StackMap locals: sun.security.pkcs.ContentInfo sun.security.util.DerInputStream
      StackMap stack:
            aload 0 /* this */
            new sun.security.util.DerInputStream
            dup
            aload 14 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.loadSafeContents:(Lsun/security/util/DerInputStream;)V
        35: .line 2032
            goto 90
      StackMap locals:
      StackMap stack:
        36: 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 89
        37: .line 2033
            aload 2 /* password */
            ifnonnull 41
        38: .line 2035
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 90
        39: .line 2036
            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
        40: .line 2054
            goto 90
        41: .line 2058
      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;
        42: .line 2057
            astore 16 /* edi */
        start local 16 // sun.security.util.DerInputStream edi
        43: .line 2059
            aload 16 /* edi */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
        44: .line 2060
            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
        45: .line 2061
            aload 17 /* seq */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        46: .line 2062
            aload 17 /* seq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            pop
        47: .line 2063
            aload 17 /* seq */
            iconst_2
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 49
        48: .line 2064
            new java.io.IOException
            dup
            ldc "encrypted content not present!"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        49: .line 2066
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            iconst_4
            istore 18 /* newTag */
        start local 18 // byte newTag
        50: .line 2067
            aload 17 /* seq */
            iconst_2
            aaload
            invokevirtual sun.security.util.DerValue.isConstructed:()Z
            ifeq 52
        51: .line 2068
            iload 18 /* newTag */
            bipush 32
            ior
            i2b
            istore 18 /* newTag */
        52: .line 2069
      StackMap locals: int
      StackMap stack:
            aload 17 /* seq */
            iconst_2
            aaload
            iload 18 /* newTag */
            invokevirtual sun.security.util.DerValue.resetTag:(B)V
        53: .line 2070
            aload 17 /* seq */
            iconst_2
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            astore 19 /* rawData */
        start local 19 // byte[] rawData
        54: .line 2073
            aload 17 /* seq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 20 /* in */
        start local 20 // sun.security.util.DerInputStream in
        55: .line 2074
            aload 20 /* in */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 21 /* algOid */
        start local 21 // sun.security.util.ObjectIdentifier algOid
        56: .line 2075
            aload 0 /* this */
            aload 21 /* algOid */
            aload 20 /* in */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.parseAlgParameters:(Lsun/security/util/ObjectIdentifier;Lsun/security/util/DerInputStream;)Ljava/security/AlgorithmParameters;
            astore 22 /* algParams */
        start local 22 // java.security.AlgorithmParameters algParams
        57: .line 2078
            iconst_0
            istore 24 /* ic */
        start local 24 // int ic
        58: .line 2080
            aload 22 /* algParams */
            ifnull 74
        59: .line 2083
            aload 22 /* algParams */
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            checkcast javax.crypto.spec.PBEParameterSpec
        60: .line 2082
            astore 23 /* pbeSpec */
        start local 23 // javax.crypto.spec.PBEParameterSpec pbeSpec
        61: .line 2084
            goto 66
        end local 23 // 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 int sun.security.pkcs.ContentInfo sun.security.util.DerInputStream sun.security.util.DerInputStream sun.security.util.DerValue[] int byte[] sun.security.util.DerInputStream sun.security.util.ObjectIdentifier java.security.AlgorithmParameters top int
      StackMap stack: java.security.spec.InvalidParameterSpecException
        62: pop
        63: .line 2085
            new java.io.IOException
            dup
        64: .line 2086
            ldc "Invalid PBE algorithm parameters"
        65: .line 2085
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 23 // javax.crypto.spec.PBEParameterSpec pbeSpec
        66: .line 2088
      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 int sun.security.pkcs.ContentInfo sun.security.util.DerInputStream sun.security.util.DerInputStream sun.security.util.DerValue[] int byte[] sun.security.util.DerInputStream sun.security.util.ObjectIdentifier java.security.AlgorithmParameters javax.crypto.spec.PBEParameterSpec int
      StackMap stack:
            aload 23 /* pbeSpec */
            invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
            istore 24 /* ic */
        67: .line 2090
            iload 24 /* ic */
            ldc 5000000
            if_icmple 69
        68: .line 2091
            new java.io.IOException
            dup
            ldc "cert PBE iteration count too large"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        69: .line 2094
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        70: .line 2095
            aload 21 /* algOid */
            aload 22 /* algParams */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEParamsToAlgorithm:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
        71: .line 2094
            putfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
        72: .line 2096
            aload 0 /* this */
            iload 24 /* ic */
            putfield sun.security.pkcs12.PKCS12KeyStore.certPbeIterationCount:I
        73: .line 2097
            iconst_1
            istore 12 /* seeEncBag */
        end local 23 // javax.crypto.spec.PBEParameterSpec pbeSpec
        74: .line 2100
      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 int sun.security.pkcs.ContentInfo sun.security.util.DerInputStream sun.security.util.DerInputStream sun.security.util.DerValue[] int byte[] 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 79
        75: .line 2101
            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
        76: .line 2102
            aload 21 /* algOid */
            aload 22 /* algParams */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEParamsToAlgorithm:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        77: .line 2103
            ldc " iterations: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 24 /* 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;
        78: .line 2101
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        79: .line 2107
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 21 /* algOid */
            aload 22 /* algParams */
            aload 19 /* rawData */
            invokedynamic tryOnce(Lsun/security/pkcs12/PKCS12KeyStore;Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;[B)Lsun/security/pkcs12/PKCS12KeyStore$RetryWithZero;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ([C)Ljava/lang/Object;
                  sun/security/pkcs12/PKCS12KeyStore.lambda$1(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;[B[C)Ljava/lang/Object; (7)
                  ([C)Ljava/lang/Object;
        80: .line 2115
            aload 2 /* password */
        81: .line 2107
            invokestatic sun.security.pkcs12.PKCS12KeyStore$RetryWithZero.run:(Lsun/security/pkcs12/PKCS12KeyStore$RetryWithZero;[C)Ljava/lang/Object;
            pop
        82: .line 2116
            goto 90
      StackMap locals:
      StackMap stack: java.lang.Exception
        83: astore 25 /* e */
        start local 25 // java.lang.Exception e
        84: .line 2117
            new java.io.IOException
            dup
            ldc "keystore password was incorrect"
        85: .line 2118
            new java.security.UnrecoverableKeyException
            dup
        86: .line 2119
            new java.lang.StringBuilder
            dup
            ldc "failed to decrypt safe contents entry: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 25 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        87: .line 2118
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
        88: .line 2117
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 25 // java.lang.Exception e
        end local 24 // int ic
        end local 22 // java.security.AlgorithmParameters algParams
        end local 21 // sun.security.util.ObjectIdentifier algOid
        end local 20 // sun.security.util.DerInputStream in
        end local 19 // byte[] rawData
        end local 18 // byte newTag
        end local 17 // sun.security.util.DerValue[] seq
        end local 16 // sun.security.util.DerInputStream edi
        89: .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 int int 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
        end local 15 // sun.security.util.DerInputStream sci
        end local 14 // sun.security.pkcs.ContentInfo safeContents
        90: .line 2017
      StackMap locals:
      StackMap stack:
            iinc 13 /* i */ 1
      StackMap locals:
      StackMap stack:
        91: iload 13 /* i */
            iload 11 /* count */
            if_icmplt 28
        end local 13 // int i
        92: .line 2128
            iload 12 /* seeEncBag */
            ifne 94
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            ifle 94
        93: .line 2129
            aload 0 /* this */
            ldc "NONE"
            putfield sun.security.pkcs12.PKCS12KeyStore.certProtectionAlgorithm:Ljava/lang/String;
        94: .line 2133
      StackMap locals:
      StackMap stack:
            aload 4 /* s */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifle 116
        95: .line 2136
            aload 2 /* password */
            ifnull 117
        96: .line 2137
            new sun.security.pkcs12.MacData
            dup
            aload 4 /* s */
            invokespecial sun.security.pkcs12.MacData.<init>:(Lsun/security/util/DerInputStream;)V
            astore 13 /* macData */
        start local 13 // sun.security.pkcs12.MacData macData
        97: .line 2138
            aload 13 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getIterations:()I
            istore 14 /* ic */
        start local 14 // int ic
        98: .line 2141
            iload 14 /* ic */
            ldc 5000000
            if_icmple 102
        99: .line 2142
            new java.security.InvalidAlgorithmParameterException
            dup
       100: .line 2143
            new java.lang.StringBuilder
            dup
            ldc "MAC iteration count too large: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 14 /* ic */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       101: .line 2142
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
       102: .line 2147
      StackMap locals: sun.security.pkcs12.MacData int
      StackMap stack:
            aload 13 /* 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;
       103: .line 2146
            astore 15 /* algName */
        start local 15 // java.lang.String algName
       104: .line 2150
            aload 15 /* algName */
            ldc "-"
            ldc ""
            invokevirtual java.lang.String.replace:(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
            astore 15 /* algName */
       105: .line 2152
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            ldc "HmacPBE"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* algName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            putfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
       106: .line 2153
            aload 0 /* this */
            iload 14 /* ic */
            putfield sun.security.pkcs12.PKCS12KeyStore.macIterationCount:I
       107: .line 2156
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;)Ljavax/crypto/Mac;
            astore 16 /* m */
        start local 16 // javax.crypto.Mac m
       108: .line 2158
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 13 /* macData */
            invokevirtual sun.security.pkcs12.MacData.getSalt:()[B
            iload 14 /* ic */
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
       109: .line 2157
            astore 17 /* params */
        start local 17 // javax.crypto.spec.PBEParameterSpec params
       110: .line 2160
            aload 0 /* this */
            aload 16 /* m */
            aload 17 /* params */
            aload 6 /* authSafeData */
            iload 14 /* ic */
            aload 13 /* macData */
            invokedynamic tryOnce(Lsun/security/pkcs12/PKCS12KeyStore;Ljavax/crypto/Mac;Ljavax/crypto/spec/PBEParameterSpec;[BILsun/security/pkcs12/MacData;)Lsun/security/pkcs12/PKCS12KeyStore$RetryWithZero;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ([C)Ljava/lang/Object;
                  sun/security/pkcs12/PKCS12KeyStore.lambda$2(Ljavax/crypto/Mac;Ljavax/crypto/spec/PBEParameterSpec;[BILsun/security/pkcs12/MacData;[C)Ljava/lang/Void; (7)
                  ([C)Ljava/lang/Void;
       111: .line 2176
            aload 2 /* password */
       112: .line 2160
            invokestatic sun.security.pkcs12.PKCS12KeyStore$RetryWithZero.run:(Lsun/security/pkcs12/PKCS12KeyStore$RetryWithZero;[C)Ljava/lang/Object;
            pop
        end local 17 // javax.crypto.spec.PBEParameterSpec params
        end local 16 // javax.crypto.Mac m
        end local 15 // java.lang.String algName
       113: .line 2177
            goto 117
      StackMap locals:
      StackMap stack: java.lang.Exception
       114: astore 15 /* e */
        start local 15 // java.lang.Exception e
       115: .line 2178
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Integrity check failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 15 /* e */
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 15 // java.lang.Exception e
        end local 14 // int ic
        end local 13 // sun.security.pkcs12.MacData macData
       116: .line 2182
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "NONE"
            putfield sun.security.pkcs12.PKCS12KeyStore.macAlgorithm:Ljava/lang/String;
       117: .line 2189
      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[]
       118: .line 2188
            astore 13 /* list */
        start local 13 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] list
       119: .line 2190
            iconst_0
            istore 14 /* m */
        start local 14 // int m
       120: goto 150
       121: .line 2191
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] int
      StackMap stack:
            aload 13 /* list */
            iload 14 /* m */
            aaload
            astore 15 /* entry */
        start local 15 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
       122: .line 2192
            aload 15 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.keyId:[B
            ifnull 149
       123: .line 2194
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
       124: .line 2193
            astore 16 /* chain */
        start local 16 // java.util.ArrayList chain
       125: .line 2195
            aload 0 /* this */
            aload 15 /* entry */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.findMatchedCertificate:(Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;)Ljava/security/cert/X509Certificate;
            astore 17 /* cert */
        start local 17 // java.security.cert.X509Certificate cert
       126: .line 2198
            goto 144
       127: .line 2200
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry java.util.ArrayList java.security.cert.X509Certificate
      StackMap stack:
            aload 16 /* chain */
            invokevirtual java.util.ArrayList.isEmpty:()Z
            ifne 139
       128: .line 2201
            aload 16 /* chain */
            invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
            astore 19
            goto 138
      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 sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] int sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry java.util.ArrayList java.security.cert.X509Certificate top java.util.Iterator
      StackMap stack:
       129: aload 19
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 18 /* chainCert */
        start local 18 // java.security.cert.X509Certificate chainCert
       130: .line 2202
            aload 17 /* cert */
            aload 18 /* chainCert */
            invokevirtual java.security.cert.X509Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 138
       131: .line 2203
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 145
       132: .line 2204
            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
       133: .line 2207
            aload 17 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
       134: .line 2208
            invokevirtual javax.security.auth.x500.X500Principal.toString:()Ljava/lang/String;
       135: .line 2207
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       136: .line 2204
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       137: .line 2210
            goto 145
        end local 18 // java.security.cert.X509Certificate chainCert
       138: .line 2201
      StackMap locals:
      StackMap stack:
            aload 19
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 129
       139: .line 2214
      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 sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] int sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry java.util.ArrayList java.security.cert.X509Certificate
      StackMap stack:
            aload 16 /* chain */
            aload 17 /* cert */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
       140: .line 2215
            aload 17 /* cert */
            invokevirtual java.security.cert.X509Certificate.getIssuerX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 18 /* issuerDN */
        start local 18 // javax.security.auth.x500.X500Principal issuerDN
       141: .line 2216
            aload 18 /* issuerDN */
            aload 17 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            invokevirtual javax.security.auth.x500.X500Principal.equals:(Ljava/lang/Object;)Z
            ifeq 143
       142: .line 2217
            goto 145
       143: .line 2219
      StackMap locals: javax.security.auth.x500.X500Principal
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            aload 18 /* issuerDN */
            invokevirtual java.util.LinkedHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.cert.X509Certificate
            astore 17 /* cert */
        end local 18 // javax.security.auth.x500.X500Principal issuerDN
       144: .line 2198
      StackMap locals:
      StackMap stack:
            aload 17 /* cert */
            ifnonnull 127
       145: .line 2222
      StackMap locals:
      StackMap stack:
            aload 16 /* chain */
            invokevirtual java.util.ArrayList.size:()I
            ifle 148
       146: .line 2223
            aload 15 /* entry */
            aload 16 /* chain */
            aload 16 /* 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;
       147: .line 2224
            goto 149
       148: .line 2228
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 15 /* entry */
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 17 // java.security.cert.X509Certificate cert
        end local 16 // java.util.ArrayList chain
        end local 15 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry entry
       149: .line 2190
      StackMap locals:
      StackMap stack:
            iinc 14 /* m */ 1
      StackMap locals:
      StackMap stack:
       150: iload 14 /* m */
            aload 13 /* list */
            arraylength
            if_icmplt 121
        end local 14 // int m
       151: .line 2233
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 164
       152: .line 2234
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            ifle 156
       153: .line 2235
            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;
       154: .line 2236
            ldc " protected private key(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       155: .line 2235
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       156: .line 2238
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            ifle 160
       157: .line 2239
            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;
       158: .line 2240
            ldc " protected secret key(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       159: .line 2239
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       160: .line 2242
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            ifle 164
       161: .line 2243
            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;
       162: .line 2244
            ldc " certificate(s)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       163: .line 2243
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
       164: .line 2248
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
       165: .line 2249
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            invokevirtual java.util.LinkedHashMap.clear:()V
       166: .line 2250
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.clear:()V
       167: .line 2251
            return
        end local 13 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry[] list
        end local 12 // boolean seeEncBag
        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  168     0               this  Lsun/security/pkcs12/PKCS12KeyStore;
            0  168     1             stream  Ljava/io/InputStream;
            0  168     2           password  [C
            8  168     3                val  Lsun/security/util/DerValue;
            9  168     4                  s  Lsun/security/util/DerInputStream;
           10  168     5            version  I
           17   18     6       authSafeData  [B
           19  168     6       authSafeData  [B
           14  168     7           authSafe  Lsun/security/pkcs/ContentInfo;
           15  168     8        contentType  Lsun/security/util/ObjectIdentifier;
           20  168     9                 as  Lsun/security/util/DerInputStream;
           21  168    10  safeContentsArray  [Lsun/security/util/DerValue;
           22  168    11              count  I
           26  168    12          seeEncBag  Z
           27   92    13                  i  I
           30   90    14       safeContents  Lsun/security/pkcs/ContentInfo;
           29   90    15                sci  Lsun/security/util/DerInputStream;
           43   89    16                edi  Lsun/security/util/DerInputStream;
           45   89    17                seq  [Lsun/security/util/DerValue;
           50   89    18             newTag  B
           54   89    19            rawData  [B
           55   89    20                 in  Lsun/security/util/DerInputStream;
           56   89    21             algOid  Lsun/security/util/ObjectIdentifier;
           57   89    22          algParams  Ljava/security/AlgorithmParameters;
           61   62    23            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           66   74    23            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           58   89    24                 ic  I
           84   89    25                  e  Ljava/lang/Exception;
           97  116    13            macData  Lsun/security/pkcs12/MacData;
           98  116    14                 ic  I
          104  113    15            algName  Ljava/lang/String;
          108  113    16                  m  Ljavax/crypto/Mac;
          110  113    17             params  Ljavax/crypto/spec/PBEParameterSpec;
          115  116    15                  e  Ljava/lang/Exception;
          119  168    13               list  [Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
          120  151    14                  m  I
          122  149    15              entry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
          125  149    16              chain  Ljava/util/ArrayList<Ljava/security/cert/X509Certificate;>;
          126  149    17               cert  Ljava/security/cert/X509Certificate;
          130  138    18          chainCert  Ljava/security/cert/X509Certificate;
          141  144    18           issuerDN  Ljavax/security/auth/x500/X500Principal;
      Exception table:
        from    to  target  type
          59    61      62  Class java.security.spec.InvalidParameterSpecException
          79    82      83  Class java.lang.Exception
          98   113     114  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
          Name  Flags
      stream    
      password  

  public static boolean isPasswordless(java.io.File);
    descriptor: (Ljava/io/File;)Z
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=14, args_size=1
        start local 0 // java.io.File f
         0: .line 2267
            aconst_null
            astore 1
            aconst_null
            astore 2
         1: new java.io.FileInputStream
            dup
            aload 0 /* f */
            invokespecial java.io.FileInputStream.<init>:(Ljava/io/File;)V
            astore 3 /* stream */
        start local 3 // java.io.FileInputStream stream
         2: .line 2268
            new sun.security.util.DerValue
            dup
            aload 3 /* stream */
            invokespecial sun.security.util.DerValue.<init>:(Ljava/io/InputStream;)V
            astore 4 /* val */
        start local 4 // sun.security.util.DerValue val
         3: .line 2269
            aload 4 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 5 /* s */
        start local 5 // sun.security.util.DerInputStream s
         4: .line 2271
            aload 5 /* s */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
         5: .line 2273
            new sun.security.pkcs.ContentInfo
            dup
            aload 5 /* s */
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/DerInputStream;)V
            astore 6 /* authSafe */
        start local 6 // sun.security.pkcs.ContentInfo authSafe
         6: .line 2274
            new sun.security.util.DerInputStream
            dup
            aload 6 /* authSafe */
            invokevirtual sun.security.pkcs.ContentInfo.getData:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 7 /* as */
        start local 7 // sun.security.util.DerInputStream as
         7: .line 2275
            aload 7 /* as */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            dup
            astore 11
            arraylength
            istore 10
            iconst_0
            istore 9
            goto 16
      StackMap locals: java.io.File java.lang.Throwable java.lang.Throwable java.io.FileInputStream sun.security.util.DerValue sun.security.util.DerInputStream sun.security.pkcs.ContentInfo sun.security.util.DerInputStream top int int sun.security.util.DerValue[]
      StackMap stack:
         8: aload 11
            iload 9
            aaload
            astore 8 /* seq */
        start local 8 // sun.security.util.DerValue seq
         9: .line 2276
            new sun.security.util.DerInputStream
            dup
            aload 8 /* seq */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 12 /* sci */
        start local 12 // sun.security.util.DerInputStream sci
        10: .line 2277
            new sun.security.pkcs.ContentInfo
            dup
            aload 12 /* sci */
            invokespecial sun.security.pkcs.ContentInfo.<init>:(Lsun/security/util/DerInputStream;)V
            astore 13 /* safeContents */
        start local 13 // sun.security.pkcs.ContentInfo safeContents
        11: .line 2278
            aload 13 /* safeContents */
            invokevirtual sun.security.pkcs.ContentInfo.getContentType:()Lsun/security/util/ObjectIdentifier;
        12: .line 2279
            getstatic sun.security.pkcs.ContentInfo.ENCRYPTED_DATA_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 15
        13: .line 2289
            aload 3 /* stream */
            ifnull 14
            aload 3 /* stream */
            invokevirtual java.io.FileInputStream.close:()V
        14: .line 2281
      StackMap locals: java.io.File java.lang.Throwable java.lang.Throwable java.io.FileInputStream sun.security.util.DerValue sun.security.util.DerInputStream sun.security.pkcs.ContentInfo sun.security.util.DerInputStream sun.security.util.DerValue int int sun.security.util.DerValue[] sun.security.util.DerInputStream sun.security.pkcs.ContentInfo
      StackMap stack:
            iconst_0
            ireturn
        end local 13 // sun.security.pkcs.ContentInfo safeContents
        end local 12 // sun.security.util.DerInputStream sci
        end local 8 // sun.security.util.DerValue seq
        15: .line 2275
      StackMap locals: java.io.File java.lang.Throwable java.lang.Throwable java.io.FileInputStream sun.security.util.DerValue sun.security.util.DerInputStream sun.security.pkcs.ContentInfo sun.security.util.DerInputStream top int int sun.security.util.DerValue[]
      StackMap stack:
            iinc 9 1
      StackMap locals:
      StackMap stack:
        16: iload 9
            iload 10
            if_icmplt 8
        17: .line 2285
            aload 5 /* s */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifle 20
        18: .line 2289
            aload 3 /* stream */
            ifnull 19
            aload 3 /* stream */
            invokevirtual java.io.FileInputStream.close:()V
        19: .line 2287
      StackMap locals: java.io.File java.lang.Throwable java.lang.Throwable java.io.FileInputStream sun.security.util.DerValue sun.security.util.DerInputStream sun.security.pkcs.ContentInfo sun.security.util.DerInputStream
      StackMap stack:
            iconst_0
            ireturn
        end local 7 // sun.security.util.DerInputStream as
        end local 6 // sun.security.pkcs.ContentInfo authSafe
        end local 5 // sun.security.util.DerInputStream s
        end local 4 // sun.security.util.DerValue val
        20: .line 2289
      StackMap locals: java.io.File java.lang.Throwable java.lang.Throwable java.io.FileInputStream
      StackMap stack:
            aload 3 /* stream */
            ifnull 26
            aload 3 /* stream */
            invokevirtual java.io.FileInputStream.close:()V
            goto 26
      StackMap locals:
      StackMap stack: java.lang.Throwable
        21: astore 1
            aload 3 /* stream */
            ifnull 22
            aload 3 /* stream */
            invokevirtual java.io.FileInputStream.close:()V
        end local 3 // java.io.FileInputStream stream
      StackMap locals:
      StackMap stack:
        22: aload 1
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        23: astore 2
            aload 1
            ifnonnull 24
            aload 2
            astore 1
            goto 25
      StackMap locals:
      StackMap stack:
        24: aload 1
            aload 2
            if_acmpeq 25
            aload 1
            aload 2
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        25: aload 1
            athrow
        26: .line 2290
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 0 // java.io.File f
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   27     0             f  Ljava/io/File;
            2   22     3        stream  Ljava/io/FileInputStream;
            3   20     4           val  Lsun/security/util/DerValue;
            4   20     5             s  Lsun/security/util/DerInputStream;
            6   20     6      authSafe  Lsun/security/pkcs/ContentInfo;
            7   20     7            as  Lsun/security/util/DerInputStream;
            9   15     8           seq  Lsun/security/util/DerValue;
           10   15    12           sci  Lsun/security/util/DerInputStream;
           11   15    13  safeContents  Lsun/security/pkcs/ContentInfo;
      Exception table:
        from    to  target  type
           2    13      21  any
          15    18      21  any
           1    14      23  any
          15    19      23  any
          20    23      23  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      f     

  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 2299
            aconst_null
            astore 2 /* keyIdMatch */
        start local 2 // sun.security.pkcs12.PKCS12KeyStore$CertEntry keyIdMatch
         1: .line 2300
            aconst_null
            astore 3 /* aliasMatch */
        start local 3 // sun.security.pkcs12.PKCS12KeyStore$CertEntry aliasMatch
         2: .line 2301
            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 2302
            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 2303
            aload 4 /* ce */
            astore 2 /* keyIdMatch */
         6: .line 2304
            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 2306
            aload 4 /* ce */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
         8: .line 2308
      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 2309
            aload 4 /* ce */
            astore 3 /* aliasMatch */
        end local 4 // sun.security.pkcs12.PKCS12KeyStore$CertEntry ce
        10: .line 2301
      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 2313
            aload 2 /* keyIdMatch */
            ifnull 12
            aload 2 /* keyIdMatch */
            getfield sun.security.pkcs12.PKCS12KeyStore$CertEntry.cert:Ljava/security/cert/X509Certificate;
            areturn
        12: .line 2314
      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 2315
      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);
    descriptor: (Lsun/security/util/DerInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=22, args_size=2
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 1 // sun.security.util.DerInputStream stream
         0: .line 2321
            aload 1 /* stream */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 2 /* safeBags */
        start local 2 // sun.security.util.DerValue[] safeBags
         1: .line 2322
            aload 2 /* safeBags */
            arraylength
            istore 3 /* count */
        start local 3 // int count
         2: .line 2327
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         3: goto 144
         4: .line 2331
      StackMap locals: sun.security.util.DerValue[] int int
      StackMap stack:
            aconst_null
            astore 8 /* bagItem */
        start local 8 // java.lang.Object bagItem
         5: .line 2333
            aload 2 /* safeBags */
            iload 4 /* i */
            aaload
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 6 /* sbi */
        start local 6 // sun.security.util.DerInputStream sbi
         6: .line 2334
            aload 6 /* sbi */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 5 /* bagId */
        start local 5 // sun.security.util.ObjectIdentifier bagId
         7: .line 2335
            aload 6 /* sbi */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 7 /* bagValue */
        start local 7 // sun.security.util.DerValue bagValue
         8: .line 2336
            aload 7 /* bagValue */
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 12
         9: .line 2337
            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 2338
            aload 7 /* 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 2337
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 2340
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream sun.security.util.DerValue[] int int sun.security.util.ObjectIdentifier sun.security.util.DerInputStream sun.security.util.DerValue java.lang.Object
      StackMap stack:
            aload 7 /* bagValue */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 7 /* bagValue */
        13: .line 2341
            aload 5 /* 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 2342
            new sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.<init>:()V
            astore 9 /* kEntry */
        start local 9 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry kEntry
        15: .line 2343
            aload 9 /* kEntry */
            aload 7 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            putfield sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry.protectedPrivKey:[B
        16: .line 2344
            aload 9 /* kEntry */
            astore 8 /* bagItem */
        17: .line 2345
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
        end local 9 // sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry kEntry
        18: .line 2346
            goto 53
      StackMap locals:
      StackMap stack:
        19: aload 5 /* 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 2347
            new sun.security.util.DerInputStream
            dup
            aload 7 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 9 /* cs */
        start local 9 // sun.security.util.DerInputStream cs
        21: .line 2348
            aload 9 /* cs */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 10 /* certValues */
        start local 10 // sun.security.util.DerValue[] certValues
        22: .line 2349
            aload 10 /* certValues */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        23: .line 2350
            aload 10 /* certValues */
            iconst_1
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 27
        24: .line 2351
            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 2352
            aload 10 /* 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 2351
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        27: .line 2354
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 10 /* 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 11 /* certValue */
        start local 11 // sun.security.util.DerValue certValue
        28: .line 2355
            ldc "X509"
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 12 /* cf */
        start local 12 // java.security.cert.CertificateFactory cf
        29: .line 2357
            aload 12 /* cf */
        30: .line 2358
            new java.io.ByteArrayInputStream
            dup
            aload 11 /* certValue */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
        31: .line 2357
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate
            astore 13 /* cert */
        start local 13 // java.security.cert.X509Certificate cert
        32: .line 2359
            aload 13 /* cert */
            astore 8 /* bagItem */
        33: .line 2360
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.certificateCount:I
        end local 13 // java.security.cert.X509Certificate cert
        end local 12 // java.security.cert.CertificateFactory cf
        end local 11 // sun.security.util.DerValue certValue
        end local 10 // sun.security.util.DerValue[] certValues
        end local 9 // sun.security.util.DerInputStream cs
        34: .line 2361
            goto 53
      StackMap locals:
      StackMap stack:
        35: aload 5 /* 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 2362
            new sun.security.util.DerInputStream
            dup
            aload 7 /* bagValue */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 9 /* ss */
        start local 9 // sun.security.util.DerInputStream ss
        37: .line 2363
            aload 9 /* ss */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 10 /* secretValues */
        start local 10 // sun.security.util.DerValue[] secretValues
        38: .line 2364
            aload 10 /* secretValues */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
        39: .line 2365
            aload 10 /* secretValues */
            iconst_1
            aaload
            iconst_0
            invokevirtual sun.security.util.DerValue.isContextSpecific:(B)Z
            ifne 45
        40: .line 2366
            new java.io.IOException
            dup
        41: .line 2367
            new java.lang.StringBuilder
            dup
            ldc "unsupported PKCS12 secret value type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        42: .line 2368
            aload 10 /* secretValues */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.tag:B
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        43: .line 2367
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        44: .line 2366
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        45: .line 2370
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 10 /* 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 11 /* secretValue */
        start local 11 // sun.security.util.DerValue secretValue
        46: .line 2371
            new sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.<init>:()V
            astore 12 /* kEntry */
        start local 12 // sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry kEntry
        47: .line 2372
            aload 12 /* kEntry */
            aload 11 /* secretValue */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry.protectedSecretKey:[B
        48: .line 2373
            aload 12 /* kEntry */
            astore 8 /* bagItem */
        49: .line 2374
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.secretKeyCount:I
        end local 12 // sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry kEntry
        end local 11 // sun.security.util.DerValue secretValue
        end local 10 // sun.security.util.DerValue[] secretValues
        end local 9 // sun.security.util.DerInputStream ss
        50: .line 2375
            goto 53
        51: .line 2377
      StackMap locals:
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 53
        52: .line 2378
            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 5 /* 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 2384
      StackMap locals:
      StackMap stack:
            aload 6 /* sbi */
            iconst_3
            invokevirtual sun.security.util.DerInputStream.getSet:(I)[Lsun/security/util/DerValue;
            astore 9 /* attrSet */
        start local 9 // sun.security.util.DerValue[] attrSet
        54: .line 2385
            goto 57
        end local 9 // sun.security.util.DerValue[] attrSet
      StackMap locals:
      StackMap stack: java.io.IOException
        55: pop
        56: .line 2389
            aconst_null
            astore 9 /* attrSet */
        start local 9 // sun.security.util.DerValue[] attrSet
        57: .line 2392
      StackMap locals: sun.security.util.DerValue[]
      StackMap stack:
            aconst_null
            astore 10 /* alias */
        start local 10 // java.lang.String alias
        58: .line 2393
            aconst_null
            astore 11 /* keyId */
        start local 11 // byte[] keyId
        59: .line 2394
            aconst_null
            astore 12 /* trustedKeyUsage */
        start local 12 // sun.security.util.ObjectIdentifier[] trustedKeyUsage
        60: .line 2395
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 13 /* attributes */
        start local 13 // java.util.Set attributes
        61: .line 2397
            aload 9 /* attrSet */
            ifnull 93
        62: .line 2398
            iconst_0
            istore 14 /* j */
        start local 14 // int j
        63: goto 92
        64: .line 2399
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream 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 9 /* attrSet */
            iload 14 /* j */
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            astore 15 /* encoded */
        start local 15 // byte[] encoded
        65: .line 2400
            new sun.security.util.DerInputStream
            dup
            aload 15 /* encoded */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 16 /* as */
        start local 16 // sun.security.util.DerInputStream as
        66: .line 2401
            aload 16 /* as */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 17 /* attrSeq */
        start local 17 // sun.security.util.DerValue[] attrSeq
        67: .line 2402
            aload 17 /* attrSeq */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            astore 18 /* attrId */
        start local 18 // sun.security.util.ObjectIdentifier attrId
        68: .line 2404
            new sun.security.util.DerInputStream
            dup
            aload 17 /* attrSeq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
        69: .line 2403
            astore 19 /* vs */
        start local 19 // sun.security.util.DerInputStream vs
        70: .line 2407
            aload 19 /* vs */
            iconst_1
            invokevirtual sun.security.util.DerInputStream.getSet:(I)[Lsun/security/util/DerValue;
            astore 20 /* valSet */
        start local 20 // sun.security.util.DerValue[] valSet
        71: .line 2408
            goto 76
        end local 20 // sun.security.util.DerValue[] valSet
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream 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 21 /* e */
        start local 21 // java.io.IOException e
        73: .line 2409
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Attribute "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 18 /* attrId */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        74: .line 2410
            ldc " should have a value "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 21 /* 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 2409
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 21 // java.io.IOException e
        start local 20 // sun.security.util.DerValue[] valSet
        76: .line 2412
      StackMap locals: sun.security.util.DerValue[]
      StackMap stack:
            aload 18 /* 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 2413
            aload 20 /* valSet */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getBMPString:()Ljava/lang/String;
            astore 10 /* alias */
        78: .line 2414
            goto 91
      StackMap locals:
      StackMap stack:
        79: aload 18 /* 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 2415
            aload 20 /* valSet */
            iconst_0
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            astore 11 /* keyId */
        81: .line 2416
            goto 91
        82: .line 2417
      StackMap locals:
      StackMap stack:
            aload 18 /* 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 2418
            aload 20 /* valSet */
            arraylength
            anewarray sun.security.util.ObjectIdentifier
            astore 12 /* trustedKeyUsage */
        84: .line 2419
            iconst_0
            istore 21 /* k */
        start local 21 // int k
        85: goto 88
        86: .line 2420
      StackMap locals: int
      StackMap stack:
            aload 12 /* trustedKeyUsage */
            iload 21 /* k */
            aload 20 /* valSet */
            iload 21 /* k */
            aaload
            invokevirtual sun.security.util.DerValue.getOID:()Lsun/security/util/ObjectIdentifier;
            aastore
        87: .line 2419
            iinc 21 /* k */ 1
      StackMap locals:
      StackMap stack:
        88: iload 21 /* k */
            aload 20 /* valSet */
            arraylength
            if_icmplt 86
        end local 21 // int k
        89: .line 2422
            goto 91
        90: .line 2423
      StackMap locals:
      StackMap stack:
            aload 13 /* attributes */
            new java.security.PKCS12Attribute
            dup
            aload 15 /* encoded */
            invokespecial java.security.PKCS12Attribute.<init>:([B)V
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 20 // sun.security.util.DerValue[] valSet
        end local 19 // sun.security.util.DerInputStream vs
        end local 18 // sun.security.util.ObjectIdentifier attrId
        end local 17 // sun.security.util.DerValue[] attrSeq
        end local 16 // sun.security.util.DerInputStream as
        end local 15 // byte[] encoded
        91: .line 2398
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream 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 14 /* j */ 1
      StackMap locals:
      StackMap stack:
        92: iload 14 /* j */
            aload 9 /* attrSet */
            arraylength
            if_icmplt 64
        end local 14 // int j
        93: .line 2437
      StackMap locals:
      StackMap stack:
            aload 8 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            ifeq 124
        94: .line 2438
            aload 8 /* bagItem */
            checkcast sun.security.pkcs12.PKCS12KeyStore$KeyEntry
            astore 14 /* entry */
        start local 14 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry entry
        95: .line 2440
            aload 11 /* keyId */
            ifnonnull 101
        96: .line 2441
            aload 8 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 100
        97: .line 2446
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            if_icmpne 143
        98: .line 2447
            ldc "01"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 11 /* keyId */
        99: .line 2451
            goto 101
       100: .line 2453
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore$KeyEntry
      StackMap stack:
            ldc "00"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 11 /* keyId */
       101: .line 2456
      StackMap locals:
      StackMap stack:
            aload 14 /* entry */
            aload 11 /* keyId */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.keyId:[B
       102: .line 2458
            new java.lang.String
            dup
            aload 11 /* keyId */
            ldc "UTF8"
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            astore 15 /* keyIdStr */
        start local 15 // java.lang.String keyIdStr
       103: .line 2459
            aconst_null
            astore 16 /* date */
        start local 16 // java.util.Date date
       104: .line 2460
            aload 15 /* keyIdStr */
            ldc "Time "
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 111
       105: .line 2462
            new java.util.Date
            dup
       106: .line 2463
            aload 15 /* keyIdStr */
            iconst_5
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic java.lang.Long.parseLong:(Ljava/lang/String;)J
       107: .line 2462
            invokespecial java.util.Date.<init>:(J)V
            astore 16 /* date */
       108: .line 2464
            goto 111
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream 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
       109: pop
       110: .line 2465
            aconst_null
            astore 16 /* date */
       111: .line 2468
      StackMap locals:
      StackMap stack:
            aload 16 /* date */
            ifnonnull 113
       112: .line 2469
            new java.util.Date
            dup
            invokespecial java.util.Date.<init>:()V
            astore 16 /* date */
       113: .line 2471
      StackMap locals:
      StackMap stack:
            aload 14 /* entry */
            aload 16 /* date */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.date:Ljava/util/Date;
       114: .line 2473
            aload 8 /* bagItem */
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 116
       115: .line 2474
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.keyList:Ljava/util/ArrayList;
            aload 14 /* entry */
            checkcast sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
       116: .line 2476
      StackMap locals:
      StackMap stack:
            aload 14 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
            ifnonnull 118
       117: .line 2477
            aload 14 /* entry */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
       118: .line 2479
      StackMap locals:
      StackMap stack:
            aload 14 /* entry */
            getfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.attributes:Ljava/util/Set;
            aload 13 /* attributes */
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
       119: .line 2480
            aload 10 /* alias */
            ifnonnull 121
       120: .line 2481
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getUnfriendlyName:()Ljava/lang/String;
            astore 10 /* alias */
       121: .line 2483
      StackMap locals:
      StackMap stack:
            aload 14 /* entry */
            aload 10 /* alias */
            putfield sun.security.pkcs12.PKCS12KeyStore$KeyEntry.alias:Ljava/lang/String;
       122: .line 2484
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 10 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            aload 14 /* entry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 16 // java.util.Date date
        end local 15 // java.lang.String keyIdStr
        end local 14 // sun.security.pkcs12.PKCS12KeyStore$KeyEntry entry
       123: .line 2486
            goto 143
      StackMap locals:
      StackMap stack:
       124: aload 8 /* bagItem */
            instanceof java.security.cert.X509Certificate
            ifeq 143
       125: .line 2487
            aload 8 /* bagItem */
            checkcast java.security.cert.X509Certificate
            astore 14 /* cert */
        start local 14 // java.security.cert.X509Certificate cert
       126: .line 2492
            aload 11 /* keyId */
            ifnonnull 129
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.privateKeyCount:I
            iconst_1
            if_icmpne 129
       127: .line 2494
            iload 4 /* i */
            ifne 129
       128: .line 2495
            ldc "01"
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 11 /* keyId */
       129: .line 2499
      StackMap locals: java.security.cert.X509Certificate
      StackMap stack:
            aload 12 /* trustedKeyUsage */
            ifnull 138
       130: .line 2500
            aload 10 /* alias */
            ifnonnull 132
       131: .line 2501
            aload 0 /* this */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getUnfriendlyName:()Ljava/lang/String;
            astore 10 /* alias */
       132: .line 2504
      StackMap locals:
      StackMap stack:
            new sun.security.pkcs12.PKCS12KeyStore$CertEntry
            dup
            aload 14 /* cert */
            aload 11 /* keyId */
            aload 10 /* alias */
            aload 12 /* trustedKeyUsage */
       133: .line 2505
            aload 13 /* attributes */
       134: .line 2504
            invokespecial sun.security.pkcs12.PKCS12KeyStore$CertEntry.<init>:(Ljava/security/cert/X509Certificate;[BLjava/lang/String;[Lsun/security/util/ObjectIdentifier;Ljava/util/Set;)V
       135: .line 2503
            astore 15 /* certEntry */
        start local 15 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
       136: .line 2506
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.entries:Ljava/util/Map;
            aload 10 /* alias */
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
            invokevirtual java.lang.String.toLowerCase:(Ljava/util/Locale;)Ljava/lang/String;
            aload 15 /* certEntry */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 15 // sun.security.pkcs12.PKCS12KeyStore$CertEntry certEntry
       137: .line 2507
            goto 139
       138: .line 2508
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certEntries:Ljava/util/ArrayList;
            new sun.security.pkcs12.PKCS12KeyStore$CertEntry
            dup
            aload 14 /* cert */
            aload 11 /* keyId */
            aload 10 /* 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
       139: .line 2510
      StackMap locals:
      StackMap stack:
            aload 14 /* cert */
            invokevirtual java.security.cert.X509Certificate.getSubjectX500Principal:()Ljavax/security/auth/x500/X500Principal;
            astore 15 /* subjectDN */
        start local 15 // javax.security.auth.x500.X500Principal subjectDN
       140: .line 2511
            aload 15 /* subjectDN */
            ifnull 143
       141: .line 2512
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            aload 15 /* subjectDN */
            invokevirtual java.util.LinkedHashMap.containsKey:(Ljava/lang/Object;)Z
            ifne 143
       142: .line 2513
            aload 0 /* this */
            getfield sun.security.pkcs12.PKCS12KeyStore.certsMap:Ljava/util/LinkedHashMap;
            aload 15 /* subjectDN */
            aload 14 /* cert */
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 15 // javax.security.auth.x500.X500Principal subjectDN
        end local 14 // java.security.cert.X509Certificate cert
        end local 13 // java.util.Set attributes
        end local 12 // sun.security.util.ObjectIdentifier[] trustedKeyUsage
        end local 11 // byte[] keyId
        end local 10 // java.lang.String alias
        end local 9 // sun.security.util.DerValue[] attrSet
        end local 8 // java.lang.Object bagItem
        end local 7 // sun.security.util.DerValue bagValue
        end local 6 // sun.security.util.DerInputStream sbi
        end local 5 // sun.security.util.ObjectIdentifier bagId
       143: .line 2327
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.DerInputStream sun.security.util.DerValue[] int int
      StackMap stack:
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
       144: iload 4 /* i */
            iload 3 /* count */
            if_icmplt 4
        end local 4 // int i
       145: .line 2518
            return
        end local 3 // int count
        end local 2 // sun.security.util.DerValue[] safeBags
        end local 1 // sun.security.util.DerInputStream stream
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0  146     0             this  Lsun/security/pkcs12/PKCS12KeyStore;
            0  146     1           stream  Lsun/security/util/DerInputStream;
            1  146     2         safeBags  [Lsun/security/util/DerValue;
            2  146     3            count  I
            3  145     4                i  I
            7  143     5            bagId  Lsun/security/util/ObjectIdentifier;
            6  143     6              sbi  Lsun/security/util/DerInputStream;
            8  143     7         bagValue  Lsun/security/util/DerValue;
            5  143     8          bagItem  Ljava/lang/Object;
           15   18     9           kEntry  Lsun/security/pkcs12/PKCS12KeyStore$PrivateKeyEntry;
           21   34     9               cs  Lsun/security/util/DerInputStream;
           22   34    10       certValues  [Lsun/security/util/DerValue;
           28   34    11        certValue  Lsun/security/util/DerValue;
           29   34    12               cf  Ljava/security/cert/CertificateFactory;
           32   34    13             cert  Ljava/security/cert/X509Certificate;
           37   50     9               ss  Lsun/security/util/DerInputStream;
           38   50    10     secretValues  [Lsun/security/util/DerValue;
           46   50    11      secretValue  Lsun/security/util/DerValue;
           47   50    12           kEntry  Lsun/security/pkcs12/PKCS12KeyStore$SecretKeyEntry;
           54   55     9          attrSet  [Lsun/security/util/DerValue;
           57  143     9          attrSet  [Lsun/security/util/DerValue;
           58  143    10            alias  Ljava/lang/String;
           59  143    11            keyId  [B
           60  143    12  trustedKeyUsage  [Lsun/security/util/ObjectIdentifier;
           61  143    13       attributes  Ljava/util/Set<Ljava/security/PKCS12Attribute;>;
           63   93    14                j  I
           65   91    15          encoded  [B
           66   91    16               as  Lsun/security/util/DerInputStream;
           67   91    17          attrSeq  [Lsun/security/util/DerValue;
           68   91    18           attrId  Lsun/security/util/ObjectIdentifier;
           70   91    19               vs  Lsun/security/util/DerInputStream;
           71   72    20           valSet  [Lsun/security/util/DerValue;
           76   91    20           valSet  [Lsun/security/util/DerValue;
           73   76    21                e  Ljava/io/IOException;
           85   89    21                k  I
           95  123    14            entry  Lsun/security/pkcs12/PKCS12KeyStore$KeyEntry;
          103  123    15         keyIdStr  Ljava/lang/String;
          104  123    16             date  Ljava/util/Date;
          126  143    14             cert  Ljava/security/cert/X509Certificate;
          136  137    15        certEntry  Lsun/security/pkcs12/PKCS12KeyStore$CertEntry;
          140  143    15        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
         105   108     109  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException, java.security.NoSuchAlgorithmException, java.security.cert.CertificateException
    MethodParameters:
        Name  Flags
      stream  

  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 2521
            aload 0 /* this */
            dup
            getfield sun.security.pkcs12.PKCS12KeyStore.counter:I
            iconst_1
            iadd
            putfield sun.security.pkcs12.PKCS12KeyStore.counter:I
         1: .line 2522
            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 2568
            aload 1 /* stream */
            instanceof java.io.DataInputStream
            ifeq 3
         1: .line 2569
            aload 1 /* stream */
            checkcast java.io.DataInputStream
            astore 2 /* dataStream */
        start local 2 // java.io.DataInputStream dataStream
         2: .line 2570
            goto 4
        end local 2 // java.io.DataInputStream dataStream
         3: .line 2571
      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 2574
      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 2575
            aload 2 /* dataStream */
            invokevirtual java.io.DataInputStream.readLong:()J
            lstore 5 /* nextPeek */
        start local 5 // long nextPeek
         6: .line 2576
            aload 2 /* dataStream */
            invokevirtual java.io.DataInputStream.readLong:()J
            lstore 7 /* finalPeek */
        start local 7 // long finalPeek
         7: .line 2577
            iconst_0
            istore 9 /* result */
        start local 9 // boolean result
         8: .line 2579
            iconst_0
            istore 10 /* i */
        start local 10 // int i
         9: goto 22
        10: .line 2580
      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 2581
            lload 3 /* firstPeek */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
            iload 10 /* i */
            aaload
            iconst_0
            laload
            land
        12: .line 2580
            lcmp
            ifne 21
        13: .line 2582
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
            iload 10 /* i */
            aaload
            iconst_1
            laload
        14: .line 2583
            lload 5 /* nextPeek */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
            iload 10 /* i */
            aaload
            iconst_1
            laload
            land
        15: .line 2582
            lcmp
            ifne 21
        16: .line 2584
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_PATTERNS:[[J
            iload 10 /* i */
            aaload
            iconst_2
            laload
        17: .line 2585
            lload 7 /* finalPeek */
            getstatic sun.security.pkcs12.PKCS12KeyStore.PKCS12_HEADER_MASKS:[[J
            iload 10 /* i */
            aaload
            iconst_2
            laload
            land
        18: .line 2584
            lcmp
            ifne 21
        19: .line 2586
            iconst_1
            istore 9 /* result */
        20: .line 2587
            goto 23
        21: .line 2579
      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 2591
      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  

  private static java.lang.String defaultCertProtectionAlgorithm();
    descriptor: ()Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=0
         0: .line 2598
            ldc "keystore.pkcs12.certProtectionAlgorithm"
         1: .line 2597
            invokestatic sun.security.util.SecurityProperties.privilegedGetOverridable:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* result */
        start local 0 // java.lang.String result
         2: .line 2599
            aload 0 /* result */
            ifnull 4
            aload 0 /* result */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 4
         3: .line 2600
            aload 0 /* result */
            goto 5
      StackMap locals: java.lang.String
      StackMap stack:
         4: ldc "PBEWithSHA1AndRC2_40"
         5: .line 2599
      StackMap locals:
      StackMap stack: java.lang.String
            areturn
        end local 0 // java.lang.String result
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            2    6     0  result  Ljava/lang/String;

  private static int defaultCertPbeIterationCount();
    descriptor: ()I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 2605
            ldc "keystore.pkcs12.certPbeIterationCount"
         1: .line 2604
            invokestatic sun.security.util.SecurityProperties.privilegedGetOverridable:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* result */
        start local 0 // java.lang.String result
         2: .line 2606
            aload 0 /* result */
            ifnull 4
            aload 0 /* result */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 4
         3: .line 2607
            ldc "certPbeIterationCount"
            aload 0 /* result */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.string2IC:(Ljava/lang/String;Ljava/lang/String;)I
            goto 5
      StackMap locals: java.lang.String
      StackMap stack:
         4: ldc 50000
         5: .line 2606
      StackMap locals:
      StackMap stack: int
            ireturn
        end local 0 // java.lang.String result
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            2    6     0  result  Ljava/lang/String;

  private static java.lang.String defaultKeyProtectionAlgorithm();
    descriptor: ()Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 2613
            new sun.security.pkcs12.PKCS12KeyStore$1
            dup
            invokespecial sun.security.pkcs12.PKCS12KeyStore$1.<init>:()V
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 0 /* result */
        start local 0 // java.lang.String result
         1: .line 2633
            aload 0 /* result */
            ifnull 3
            aload 0 /* result */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 3
         2: .line 2634
            aload 0 /* result */
            goto 4
      StackMap locals: java.lang.String
      StackMap stack:
         3: ldc "PBEWithSHA1AndDESede"
         4: .line 2633
      StackMap locals:
      StackMap stack: java.lang.String
            areturn
        end local 0 // java.lang.String result
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            1    5     0  result  Ljava/lang/String;

  private static int defaultKeyPbeIterationCount();
    descriptor: ()I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 2639
            ldc "keystore.pkcs12.keyPbeIterationCount"
         1: .line 2638
            invokestatic sun.security.util.SecurityProperties.privilegedGetOverridable:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* result */
        start local 0 // java.lang.String result
         2: .line 2640
            aload 0 /* result */
            ifnull 4
            aload 0 /* result */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 4
         3: .line 2641
            ldc "keyPbeIterationCount"
            aload 0 /* result */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.string2IC:(Ljava/lang/String;Ljava/lang/String;)I
            goto 5
      StackMap locals: java.lang.String
      StackMap stack:
         4: ldc 50000
         5: .line 2640
      StackMap locals:
      StackMap stack: int
            ireturn
        end local 0 // java.lang.String result
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            2    6     0  result  Ljava/lang/String;

  private static java.lang.String defaultMacAlgorithm();
    descriptor: ()Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=0
         0: .line 2646
            ldc "keystore.pkcs12.macAlgorithm"
         1: .line 2645
            invokestatic sun.security.util.SecurityProperties.privilegedGetOverridable:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* result */
        start local 0 // java.lang.String result
         2: .line 2647
            aload 0 /* result */
            ifnull 4
            aload 0 /* result */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 4
         3: .line 2648
            aload 0 /* result */
            goto 5
      StackMap locals: java.lang.String
      StackMap stack:
         4: ldc "HmacPBESHA1"
         5: .line 2647
      StackMap locals:
      StackMap stack: java.lang.String
            areturn
        end local 0 // java.lang.String result
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            2    6     0  result  Ljava/lang/String;

  private static int defaultMacIterationCount();
    descriptor: ()I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 2653
            ldc "keystore.pkcs12.macIterationCount"
         1: .line 2652
            invokestatic sun.security.util.SecurityProperties.privilegedGetOverridable:(Ljava/lang/String;)Ljava/lang/String;
            astore 0 /* result */
        start local 0 // java.lang.String result
         2: .line 2654
            aload 0 /* result */
            ifnull 4
            aload 0 /* result */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 4
         3: .line 2655
            ldc "macIterationCount"
            aload 0 /* result */
            invokestatic sun.security.pkcs12.PKCS12KeyStore.string2IC:(Ljava/lang/String;Ljava/lang/String;)I
            goto 5
      StackMap locals: java.lang.String
      StackMap stack:
         4: ldc 100000
         5: .line 2654
      StackMap locals:
      StackMap stack: int
            ireturn
        end local 0 // java.lang.String result
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            2    6     0  result  Ljava/lang/String;

  private static int string2IC(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // java.lang.String type
        start local 1 // java.lang.String value
         0: .line 2661
            aload 1 /* value */
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            istore 2 /* number */
        start local 2 // int number
         1: .line 2662
            goto 6
        end local 2 // int number
      StackMap locals:
      StackMap stack: java.lang.NumberFormatException
         2: pop
         3: .line 2663
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "keystore.pkcs12."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* type */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 2664
            ldc " is not a number: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* value */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 2663
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        start local 2 // int number
         6: .line 2666
      StackMap locals: int
      StackMap stack:
            iload 2 /* number */
            ifle 7
            iload 2 /* number */
            ldc 5000000
            if_icmple 10
         7: .line 2667
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid keystore.pkcs12."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         8: .line 2668
            aload 0 /* type */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 1 /* value */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 2667
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 2670
      StackMap locals:
      StackMap stack:
            iload 2 /* number */
            ireturn
        end local 2 // int number
        end local 1 // java.lang.String value
        end local 0 // java.lang.String type
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    type  Ljava/lang/String;
            0   11     1   value  Ljava/lang/String;
            1    2     2  number  I
            6   11     2  number  I
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.NumberFormatException
    MethodParameters:
       Name  Flags
      type   
      value  

  private java.security.Key lambda$0(sun.security.util.ObjectIdentifier, java.security.AlgorithmParameters, byte[], sun.security.pkcs12.PKCS12KeyStore$Entry, java.lang.String, int, char[]);
    descriptor: (Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;[BLsun/security/pkcs12/PKCS12KeyStore$Entry;Ljava/lang/String;I[C)Ljava/security/Key;
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=4, locals=21, args_size=8
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 7 // char[] pass
         0: .line 394
            aload 0 /* this */
            aload 7 /* pass */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 8 /* skey */
        start local 8 // javax.crypto.SecretKey skey
         1: .line 396
            aload 1
            aload 2
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEParamsToAlgorithm:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
         2: .line 395
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 9 /* cipher */
        start local 9 // javax.crypto.Cipher cipher
         3: .line 397
            aload 9 /* cipher */
            iconst_2
            aload 8 /* skey */
            aload 2
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
         4: .line 398
            aload 9 /* cipher */
            aload 3
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 10 /* keyInfo */
        start local 10 // byte[] keyInfo
         5: .line 403
            new sun.security.util.DerValue
            dup
            aload 10 /* keyInfo */
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 11 /* val */
        start local 11 // sun.security.util.DerValue val
         6: .line 404
            aload 11 /* val */
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 12 /* in */
        start local 12 // sun.security.util.DerInputStream in
         7: .line 405
            aload 12 /* in */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            pop
         8: .line 406
            aload 12 /* in */
            iconst_2
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 13 /* value */
        start local 13 // sun.security.util.DerValue[] value
         9: .line 407
            new sun.security.x509.AlgorithmId
            dup
            aload 13 /* 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 14 /* algId */
        start local 14 // sun.security.x509.AlgorithmId algId
        10: .line 408
            aload 14 /* algId */
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            astore 15 /* keyAlgo */
        start local 15 // java.lang.String keyAlgo
        11: .line 411
            aload 4
            instanceof sun.security.pkcs12.PKCS12KeyStore$PrivateKeyEntry
            ifeq 22
        12: .line 412
            aload 15 /* keyAlgo */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 16 /* kfac */
        start local 16 // java.security.KeyFactory kfac
        13: .line 413
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 10 /* keyInfo */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            astore 17 /* kspec */
        start local 17 // java.security.spec.PKCS8EncodedKeySpec kspec
        14: .line 414
            aload 16 /* kfac */
            aload 17 /* kspec */
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
            astore 18 /* tmp */
        start local 18 // java.security.Key tmp
        15: .line 416
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 21
        16: .line 417
            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
        17: .line 418
            aload 5
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "' ("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        18: .line 419
            aload 1
            aload 2
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEParamsToAlgorithm:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        19: .line 420
            ldc " iterations: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 6
            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;
        20: .line 417
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        21: .line 422
      StackMap locals: sun.security.pkcs12.PKCS12KeyStore sun.security.util.ObjectIdentifier java.security.AlgorithmParameters byte[] sun.security.pkcs12.PKCS12KeyStore$Entry java.lang.String int char[] javax.crypto.SecretKey javax.crypto.Cipher byte[] sun.security.util.DerValue sun.security.util.DerInputStream sun.security.util.DerValue[] sun.security.x509.AlgorithmId java.lang.String java.security.KeyFactory java.security.spec.PKCS8EncodedKeySpec java.security.Key
      StackMap stack:
            aload 18 /* tmp */
            areturn
        end local 18 // java.security.Key tmp
        end local 17 // java.security.spec.PKCS8EncodedKeySpec kspec
        end local 16 // java.security.KeyFactory kfac
        22: .line 425
      StackMap locals:
      StackMap stack:
            aload 12 /* in */
            invokevirtual sun.security.util.DerInputStream.getOctetString:()[B
            astore 16 /* keyBytes */
        start local 16 // byte[] keyBytes
        23: .line 427
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 16 /* keyBytes */
            aload 15 /* keyAlgo */
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
        24: .line 426
            astore 17 /* secretKeySpec */
        start local 17 // javax.crypto.spec.SecretKeySpec secretKeySpec
        25: .line 431
            aload 15 /* keyAlgo */
            ldc "PBE"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 32
        26: .line 433
            aload 15 /* keyAlgo */
            invokestatic javax.crypto.SecretKeyFactory.getInstance:(Ljava/lang/String;)Ljavax/crypto/SecretKeyFactory;
        27: .line 432
            astore 19 /* sKeyFactory */
        start local 19 // javax.crypto.SecretKeyFactory sKeyFactory
        28: .line 435
            aload 19 /* sKeyFactory */
            aload 17 /* secretKeySpec */
            ldc Ljavax/crypto/spec/PBEKeySpec;
            invokevirtual javax.crypto.SecretKeyFactory.getKeySpec:(Ljavax/crypto/SecretKey;Ljava/lang/Class;)Ljava/security/spec/KeySpec;
        29: .line 434
            astore 20 /* pbeKeySpec */
        start local 20 // java.security.spec.KeySpec pbeKeySpec
        30: .line 436
            aload 19 /* sKeyFactory */
            aload 20 /* pbeKeySpec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            astore 18 /* tmp */
        end local 20 // java.security.spec.KeySpec pbeKeySpec
        end local 19 // javax.crypto.SecretKeyFactory sKeyFactory
        start local 18 // java.security.Key tmp
        31: .line 437
            goto 33
        end local 18 // java.security.Key tmp
        32: .line 438
      StackMap locals: byte[] javax.crypto.spec.SecretKeySpec
      StackMap stack:
            aload 17 /* secretKeySpec */
            astore 18 /* tmp */
        start local 18 // java.security.Key tmp
        33: .line 441
      StackMap locals: java.security.Key
      StackMap stack:
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 39
        34: .line 442
            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
        35: .line 443
            aload 5
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "' ("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        36: .line 444
            aload 1
            aload 2
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEParamsToAlgorithm:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        37: .line 445
            ldc " iterations: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 6
            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;
        38: .line 442
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        39: .line 447
      StackMap locals:
      StackMap stack:
            aload 18 /* tmp */
            areturn
        end local 18 // java.security.Key tmp
        end local 17 // javax.crypto.spec.SecretKeySpec secretKeySpec
        end local 16 // byte[] keyBytes
        end local 15 // java.lang.String keyAlgo
        end local 14 // sun.security.x509.AlgorithmId algId
        end local 13 // sun.security.util.DerValue[] value
        end local 12 // sun.security.util.DerInputStream in
        end local 11 // sun.security.util.DerValue val
        end local 10 // byte[] keyInfo
        end local 9 // javax.crypto.Cipher cipher
        end local 8 // javax.crypto.SecretKey skey
        end local 7 // char[] pass
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   40     0           this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   40     7           pass  [C
            1   40     8           skey  Ljavax/crypto/SecretKey;
            3   40     9         cipher  Ljavax/crypto/Cipher;
            5   40    10        keyInfo  [B
            6   40    11            val  Lsun/security/util/DerValue;
            7   40    12             in  Lsun/security/util/DerInputStream;
            9   40    13          value  [Lsun/security/util/DerValue;
           10   40    14          algId  Lsun/security/x509/AlgorithmId;
           11   40    15        keyAlgo  Ljava/lang/String;
           13   22    16           kfac  Ljava/security/KeyFactory;
           14   22    17          kspec  Ljava/security/spec/PKCS8EncodedKeySpec;
           15   22    18            tmp  Ljava/security/Key;
           23   40    16       keyBytes  [B
           25   40    17  secretKeySpec  Ljavax/crypto/spec/SecretKeySpec;
           31   32    18            tmp  Ljava/security/Key;
           33   40    18            tmp  Ljava/security/Key;
           28   31    19    sKeyFactory  Ljavax/crypto/SecretKeyFactory;
           30   31    20     pbeKeySpec  Ljava/security/spec/KeySpec;
    Exceptions:
      throws java.lang.Exception

  private java.lang.Object lambda$1(sun.security.util.ObjectIdentifier, java.security.AlgorithmParameters, byte[], char[]);
    descriptor: (Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;[B[C)Ljava/lang/Object;
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=5, locals=7, args_size=5
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 4 // char[] pass
         0: .line 2109
            aload 0 /* this */
            aload 4 /* pass */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 5 /* skey */
        start local 5 // javax.crypto.SecretKey skey
         1: .line 2111
            aload 1
            aload 2
            invokestatic sun.security.pkcs12.PKCS12KeyStore.mapPBEParamsToAlgorithm:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)Ljava/lang/String;
         2: .line 2110
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 6 /* cipher */
        start local 6 // javax.crypto.Cipher cipher
         3: .line 2112
            aload 6 /* cipher */
            iconst_2
            aload 5 /* skey */
            aload 2
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
         4: .line 2113
            aload 0 /* this */
            new sun.security.util.DerInputStream
            dup
            aload 6 /* cipher */
            aload 3
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.loadSafeContents:(Lsun/security/util/DerInputStream;)V
         5: .line 2114
            aconst_null
            areturn
        end local 6 // javax.crypto.Cipher cipher
        end local 5 // javax.crypto.SecretKey skey
        end local 4 // char[] pass
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lsun/security/pkcs12/PKCS12KeyStore;
            0    6     4    pass  [C
            1    6     5    skey  Ljavax/crypto/SecretKey;
            3    6     6  cipher  Ljavax/crypto/Cipher;
    Exceptions:
      throws java.lang.Exception

  private java.lang.Void lambda$2(javax.crypto.Mac, javax.crypto.spec.PBEParameterSpec, byte[], int, sun.security.pkcs12.MacData, char[]);
    descriptor: (Ljavax/crypto/Mac;Ljavax/crypto/spec/PBEParameterSpec;[BILsun/security/pkcs12/MacData;[C)Ljava/lang/Void;
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=4, locals=9, args_size=7
        start local 0 // sun.security.pkcs12.PKCS12KeyStore this
        start local 6 // char[] pass
         0: .line 2161
            aload 0 /* this */
            aload 6 /* pass */
            invokevirtual sun.security.pkcs12.PKCS12KeyStore.getPBEKey:([C)Ljavax/crypto/SecretKey;
            astore 7 /* key */
        start local 7 // javax.crypto.SecretKey key
         1: .line 2162
            aload 1
            aload 7 /* key */
            aload 2
            invokevirtual javax.crypto.Mac.init:(Ljava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
         2: .line 2163
            aload 1
            aload 3
            invokevirtual javax.crypto.Mac.update:([B)V
         3: .line 2164
            aload 1
            invokevirtual javax.crypto.Mac.doFinal:()[B
            astore 8 /* macResult */
        start local 8 // byte[] macResult
         4: .line 2166
            getstatic sun.security.pkcs12.PKCS12KeyStore.debug:Lsun/security/util/Debug;
            ifnull 8
         5: .line 2167
            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
         6: .line 2168
            aload 1
            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 4
            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;
         7: .line 2167
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         8: .line 2171
      StackMap locals: javax.crypto.SecretKey byte[]
      StackMap stack:
            aload 5
            invokevirtual sun.security.pkcs12.MacData.getDigest:()[B
            aload 8 /* macResult */
            invokestatic java.security.MessageDigest.isEqual:([B[B)Z
            ifne 10
         9: .line 2172
            new java.security.UnrecoverableKeyException
            dup
            ldc "Failed PKCS12 integrity checking"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 2175
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 8 // byte[] macResult
        end local 7 // javax.crypto.SecretKey key
        end local 6 // char[] pass
        end local 0 // sun.security.pkcs12.PKCS12KeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   11     0       this  Lsun/security/pkcs12/PKCS12KeyStore;
            0   11     6       pass  [C
            1   11     7        key  Ljavax/crypto/SecretKey;
            4   11     8  macResult  [B
    Exceptions:
      throws java.lang.Exception
}
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$RetryWithZero  sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  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 abstract RetryWithZero = sun.security.pkcs12.PKCS12KeyStore$RetryWithZero of sun.security.pkcs12.PKCS12KeyStore
  private SecretKeyEntry = sun.security.pkcs12.PKCS12KeyStore$SecretKeyEntry of sun.security.pkcs12.PKCS12KeyStore