public class org.bouncycastle.jce.provider.JDKKeyStore extends java.security.KeyStoreSpi implements org.bouncycastle.jce.interfaces.BCKeyStore
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.jce.provider.JDKKeyStore
  super_class: java.security.KeyStoreSpi
{
  private static final int STORE_VERSION;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

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

  private static final java.lang.String STORE_CIPHER;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "PBEWithSHAAndTwofish-CBC"

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

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

  private static final java.lang.String KEY_CIPHER;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "PBEWithSHAAnd3-KeyTripleDES-CBC"

  static final int NULL;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  static final int CERTIFICATE;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  static final int KEY;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  static final int SECRET;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 3

  static final int SEALED;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  static final int KEY_PRIVATE;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  static final int KEY_PUBLIC;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  static final int KEY_SECRET;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  protected java.util.Hashtable table;
    descriptor: Ljava/util/Hashtable;
    flags: (0x0004) ACC_PROTECTED

  protected java.security.SecureRandom random;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0004) ACC_PROTECTED

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
         0: .line 87
            aload 0 /* this */
            invokespecial java.security.KeyStoreSpi.<init>:()V
         1: .line 83
            aload 0 /* this */
            new java.util.Hashtable
            dup
            invokespecial java.util.Hashtable.<init>:()V
            putfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
         2: .line 85
            aload 0 /* this */
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            putfield org.bouncycastle.jce.provider.JDKKeyStore.random:Ljava/security/SecureRandom;
         3: .line 89
            return
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore;

  private void encodeCertificate(java.security.cert.Certificate, java.io.DataOutputStream);
    descriptor: (Ljava/security/cert/Certificate;Ljava/io/DataOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.security.cert.Certificate cert
        start local 2 // java.io.DataOutputStream dOut
         0: .line 336
            aload 1 /* cert */
            invokevirtual java.security.cert.Certificate.getEncoded:()[B
            astore 3 /* cEnc */
        start local 3 // byte[] cEnc
         1: .line 338
            aload 2 /* dOut */
            aload 1 /* cert */
            invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
         2: .line 339
            aload 2 /* dOut */
            aload 3 /* cEnc */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
         3: .line 340
            aload 2 /* dOut */
            aload 3 /* cEnc */
            invokevirtual java.io.DataOutputStream.write:([B)V
        end local 3 // byte[] cEnc
         4: .line 341
            goto 7
         5: .line 342
      StackMap locals:
      StackMap stack: java.security.cert.CertificateEncodingException
            astore 3 /* ex */
        start local 3 // java.security.cert.CertificateEncodingException ex
         6: .line 344
            new java.io.IOException
            dup
            aload 3 /* ex */
            invokevirtual java.security.cert.CertificateEncodingException.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // java.security.cert.CertificateEncodingException ex
         7: .line 346
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.io.DataOutputStream dOut
        end local 1 // java.security.cert.Certificate cert
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    8     1  cert  Ljava/security/cert/Certificate;
            0    8     2  dOut  Ljava/io/DataOutputStream;
            1    4     3  cEnc  [B
            6    7     3    ex  Ljava/security/cert/CertificateEncodingException;
      Exception table:
        from    to  target  type
           0     4       5  Class java.security.cert.CertificateEncodingException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      cert  
      dOut  

  private java.security.cert.Certificate decodeCertificate(java.io.DataInputStream);
    descriptor: (Ljava/io/DataInputStream;)Ljava/security/cert/Certificate;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.io.DataInputStream dIn
         0: .line 352
            aload 1 /* dIn */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 2 /* type */
        start local 2 // java.lang.String type
         1: .line 353
            aload 1 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            newarray 8
            astore 3 /* cEnc */
        start local 3 // byte[] cEnc
         2: .line 355
            aload 1 /* dIn */
            aload 3 /* cEnc */
            invokevirtual java.io.DataInputStream.readFully:([B)V
         3: .line 359
            aload 2 /* type */
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic java.security.cert.CertificateFactory.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/cert/CertificateFactory;
            astore 4 /* cFact */
        start local 4 // java.security.cert.CertificateFactory cFact
         4: .line 360
            new java.io.ByteArrayInputStream
            dup
            aload 3 /* cEnc */
            invokespecial java.io.ByteArrayInputStream.<init>:([B)V
            astore 5 /* bIn */
        start local 5 // java.io.ByteArrayInputStream bIn
         5: .line 362
            aload 4 /* cFact */
            aload 5 /* bIn */
            invokevirtual java.security.cert.CertificateFactory.generateCertificate:(Ljava/io/InputStream;)Ljava/security/cert/Certificate;
         6: areturn
        end local 5 // java.io.ByteArrayInputStream bIn
        end local 4 // java.security.cert.CertificateFactory cFact
         7: .line 364
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore java.io.DataInputStream java.lang.String byte[]
      StackMap stack: java.security.NoSuchProviderException
            astore 4 /* ex */
        start local 4 // java.security.NoSuchProviderException ex
         8: .line 366
            new java.io.IOException
            dup
            aload 4 /* ex */
            invokevirtual java.security.NoSuchProviderException.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.NoSuchProviderException ex
         9: .line 368
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
            astore 4 /* ex */
        start local 4 // java.security.cert.CertificateException ex
        10: .line 370
            new java.io.IOException
            dup
            aload 4 /* ex */
            invokevirtual java.security.cert.CertificateException.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.cert.CertificateException ex
        end local 3 // byte[] cEnc
        end local 2 // java.lang.String type
        end local 1 // java.io.DataInputStream dIn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   11     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   11     1    dIn  Ljava/io/DataInputStream;
            1   11     2   type  Ljava/lang/String;
            2   11     3   cEnc  [B
            4    7     4  cFact  Ljava/security/cert/CertificateFactory;
            5    7     5    bIn  Ljava/io/ByteArrayInputStream;
            8    9     4     ex  Ljava/security/NoSuchProviderException;
           10   11     4     ex  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
           3     6       7  Class java.security.NoSuchProviderException
           3     6       9  Class java.security.cert.CertificateException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      dIn   

  private void encodeKey(java.security.Key, java.io.DataOutputStream);
    descriptor: (Ljava/security/Key;Ljava/io/DataOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.security.Key key
        start local 2 // java.io.DataOutputStream dOut
         0: .line 379
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 3 /* enc */
        start local 3 // byte[] enc
         1: .line 381
            aload 1 /* key */
            instanceof java.security.PrivateKey
            ifeq 4
         2: .line 383
            aload 2 /* dOut */
            iconst_0
            invokevirtual java.io.DataOutputStream.write:(I)V
         3: .line 384
            goto 8
         4: .line 385
      StackMap locals: byte[]
      StackMap stack:
            aload 1 /* key */
            instanceof java.security.PublicKey
            ifeq 7
         5: .line 387
            aload 2 /* dOut */
            iconst_1
            invokevirtual java.io.DataOutputStream.write:(I)V
         6: .line 388
            goto 8
         7: .line 391
      StackMap locals:
      StackMap stack:
            aload 2 /* dOut */
            iconst_2
            invokevirtual java.io.DataOutputStream.write:(I)V
         8: .line 394
      StackMap locals:
      StackMap stack:
            aload 2 /* dOut */
            aload 1 /* key */
            invokeinterface java.security.Key.getFormat:()Ljava/lang/String;
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
         9: .line 395
            aload 2 /* dOut */
            aload 1 /* key */
            invokeinterface java.security.Key.getAlgorithm:()Ljava/lang/String;
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
        10: .line 396
            aload 2 /* dOut */
            aload 3 /* enc */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        11: .line 397
            aload 2 /* dOut */
            aload 3 /* enc */
            invokevirtual java.io.DataOutputStream.write:([B)V
        12: .line 398
            return
        end local 3 // byte[] enc
        end local 2 // java.io.DataOutputStream dOut
        end local 1 // java.security.Key key
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   13     1   key  Ljava/security/Key;
            0   13     2  dOut  Ljava/io/DataOutputStream;
            1   13     3   enc  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      key   
      dOut  

  private java.security.Key decodeKey(java.io.DataInputStream);
    descriptor: (Ljava/io/DataInputStream;)Ljava/security/Key;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.io.DataInputStream dIn
         0: .line 404
            aload 1 /* dIn */
            invokevirtual java.io.DataInputStream.read:()I
            istore 2 /* keyType */
        start local 2 // int keyType
         1: .line 405
            aload 1 /* dIn */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 3 /* format */
        start local 3 // java.lang.String format
         2: .line 406
            aload 1 /* dIn */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 4 /* algorithm */
        start local 4 // java.lang.String algorithm
         3: .line 407
            aload 1 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            newarray 8
            astore 5 /* enc */
        start local 5 // byte[] enc
         4: .line 410
            aload 1 /* dIn */
            aload 5 /* enc */
            invokevirtual java.io.DataInputStream.readFully:([B)V
         5: .line 412
            aload 3 /* format */
            ldc "PKCS#8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
            aload 3 /* format */
            ldc "PKCS8"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 8
         6: .line 414
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore java.io.DataInputStream int java.lang.String java.lang.String byte[]
      StackMap stack:
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 5 /* enc */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            astore 6 /* spec */
        start local 6 // java.security.spec.KeySpec spec
         7: .line 415
            goto 14
        end local 6 // java.security.spec.KeySpec spec
         8: .line 416
      StackMap locals:
      StackMap stack:
            aload 3 /* format */
            ldc "X.509"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 9
            aload 3 /* format */
            ldc "X509"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 11
         9: .line 418
      StackMap locals:
      StackMap stack:
            new java.security.spec.X509EncodedKeySpec
            dup
            aload 5 /* enc */
            invokespecial java.security.spec.X509EncodedKeySpec.<init>:([B)V
            astore 6 /* spec */
        start local 6 // java.security.spec.KeySpec spec
        10: .line 419
            goto 14
        end local 6 // java.security.spec.KeySpec spec
        11: .line 420
      StackMap locals:
      StackMap stack:
            aload 3 /* format */
            ldc "RAW"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 13
        12: .line 422
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 5 /* enc */
            aload 4 /* algorithm */
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
            areturn
        13: .line 426
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Key format "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* format */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " not recognised!"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 6 // java.security.spec.KeySpec spec
        14: .line 431
      StackMap locals: java.security.spec.KeySpec
      StackMap stack:
            iload 2 /* keyType */
            tableswitch { // 0 - 2
                    0: 15
                    1: 17
                    2: 19
              default: 21
          }
        15: .line 434
      StackMap locals:
      StackMap stack:
            aload 4 /* algorithm */
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/KeyFactory;
            aload 6 /* spec */
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
        16: areturn
        17: .line 436
      StackMap locals:
      StackMap stack:
            aload 4 /* algorithm */
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/KeyFactory;
            aload 6 /* spec */
            invokevirtual java.security.KeyFactory.generatePublic:(Ljava/security/spec/KeySpec;)Ljava/security/PublicKey;
        18: areturn
        19: .line 438
      StackMap locals:
      StackMap stack:
            aload 4 /* algorithm */
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic javax.crypto.SecretKeyFactory.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljavax/crypto/SecretKeyFactory;
            aload 6 /* spec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
        20: areturn
        21: .line 440
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Key type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* keyType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " not recognised!"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        22: .line 443
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 7 /* e */
        start local 7 // java.lang.Exception e
        23: .line 445
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Exception creating key: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // java.lang.Exception e
        end local 6 // java.security.spec.KeySpec spec
        end local 5 // byte[] enc
        end local 4 // java.lang.String algorithm
        end local 3 // java.lang.String format
        end local 2 // int keyType
        end local 1 // java.io.DataInputStream dIn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   24     0       this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   24     1        dIn  Ljava/io/DataInputStream;
            1   24     2    keyType  I
            2   24     3     format  Ljava/lang/String;
            3   24     4  algorithm  Ljava/lang/String;
            4   24     5        enc  [B
            7    8     6       spec  Ljava/security/spec/KeySpec;
           10   11     6       spec  Ljava/security/spec/KeySpec;
           14   24     6       spec  Ljava/security/spec/KeySpec;
           23   24     7          e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          14    16      22  Class java.lang.Exception
          17    18      22  Class java.lang.Exception
          19    20      22  Class java.lang.Exception
          21    22      22  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      dIn   

  protected javax.crypto.Cipher makePBECipher(java.lang.String, int, char[], byte[], int);
    descriptor: (Ljava/lang/String;I[C[BI)Ljavax/crypto/Cipher;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=10, args_size=6
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String algorithm
        start local 2 // int mode
        start local 3 // char[] password
        start local 4 // byte[] salt
        start local 5 // int iterationCount
         0: .line 459
            new javax.crypto.spec.PBEKeySpec
            dup
            aload 3 /* password */
            invokespecial javax.crypto.spec.PBEKeySpec.<init>:([C)V
            astore 6 /* pbeSpec */
        start local 6 // javax.crypto.spec.PBEKeySpec pbeSpec
         1: .line 460
            aload 1 /* algorithm */
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic javax.crypto.SecretKeyFactory.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljavax/crypto/SecretKeyFactory;
            astore 7 /* keyFact */
        start local 7 // javax.crypto.SecretKeyFactory keyFact
         2: .line 461
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 4 /* salt */
            iload 5 /* iterationCount */
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
            astore 8 /* defParams */
        start local 8 // javax.crypto.spec.PBEParameterSpec defParams
         3: .line 463
            aload 1 /* algorithm */
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 9 /* cipher */
        start local 9 // javax.crypto.Cipher cipher
         4: .line 465
            aload 9 /* cipher */
            iload 2 /* mode */
            aload 7 /* keyFact */
            aload 6 /* pbeSpec */
            invokevirtual javax.crypto.SecretKeyFactory.generateSecret:(Ljava/security/spec/KeySpec;)Ljavax/crypto/SecretKey;
            aload 8 /* defParams */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
         5: .line 467
            aload 9 /* cipher */
         6: areturn
        end local 9 // javax.crypto.Cipher cipher
        end local 8 // javax.crypto.spec.PBEParameterSpec defParams
        end local 7 // javax.crypto.SecretKeyFactory keyFact
        end local 6 // javax.crypto.spec.PBEKeySpec pbeSpec
         7: .line 469
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 6 /* e */
        start local 6 // java.lang.Exception e
         8: .line 471
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Error initialising store of key store: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 6 // java.lang.Exception e
        end local 5 // int iterationCount
        end local 4 // byte[] salt
        end local 3 // char[] password
        end local 2 // int mode
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    9     0            this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    9     1       algorithm  Ljava/lang/String;
            0    9     2            mode  I
            0    9     3        password  [C
            0    9     4            salt  [B
            0    9     5  iterationCount  I
            1    7     6         pbeSpec  Ljavax/crypto/spec/PBEKeySpec;
            2    7     7         keyFact  Ljavax/crypto/SecretKeyFactory;
            3    7     8       defParams  Ljavax/crypto/spec/PBEParameterSpec;
            4    7     9          cipher  Ljavax/crypto/Cipher;
            8    9     6               e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0     6       7  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                Name  Flags
      algorithm       
      mode            
      password        
      salt            
      iterationCount  

  public void setRandom(java.security.SecureRandom);
    descriptor: (Ljava/security/SecureRandom;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.security.SecureRandom rand
         0: .line 478
            aload 0 /* this */
            aload 1 /* rand */
            putfield org.bouncycastle.jce.provider.JDKKeyStore.random:Ljava/security/SecureRandom;
         1: .line 479
            return
        end local 1 // java.security.SecureRandom rand
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    2     1  rand  Ljava/security/SecureRandom;
    MethodParameters:
      Name  Flags
      rand  

  public java.util.Enumeration engineAliases();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
         0: .line 483
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.keys:()Ljava/util/Enumeration;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore;

  public boolean engineContainsAlias(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
         0: .line 489
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnull 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    2     1  alias  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      alias  

  public void engineDeleteEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
         0: .line 496
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* entry */
        start local 2 // java.lang.Object entry
         1: .line 498
            aload 2 /* entry */
            ifnonnull 3
         2: .line 500
            new java.security.KeyStoreException
            dup
            new java.lang.StringBuilder
            dup
            ldc "no such entry as "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 503
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 504
            return
        end local 2 // java.lang.Object entry
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    5     1  alias  Ljava/lang/String;
            1    5     2  entry  Ljava/lang/Object;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  

  public java.security.cert.Certificate engineGetCertificate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
         0: .line 509
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 2 /* entry */
        start local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         1: .line 511
            aload 2 /* entry */
            ifnull 7
         2: .line 513
            aload 2 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getType:()I
            iconst_1
            if_icmpne 4
         3: .line 515
            aload 2 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getObject:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate
            areturn
         4: .line 519
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            aload 2 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
            astore 3 /* chain */
        start local 3 // java.security.cert.Certificate[] chain
         5: .line 521
            aload 3 /* chain */
            ifnull 7
         6: .line 523
            aload 3 /* chain */
            iconst_0
            aaload
            areturn
        end local 3 // java.security.cert.Certificate[] chain
         7: .line 528
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    8     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    8     1  alias  Ljava/lang/String;
            1    8     2  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            5    7     3  chain  [Ljava/security/cert/Certificate;
    MethodParameters:
       Name  Flags
      alias  

  public java.lang.String engineGetCertificateAlias(java.security.cert.Certificate);
    descriptor: (Ljava/security/cert/Certificate;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.security.cert.Certificate cert
         0: .line 534
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.elements:()Ljava/util/Enumeration;
            astore 2 /* e */
        start local 2 // java.util.Enumeration e
         1: .line 535
            goto 10
         2: .line 537
      StackMap locals: java.util.Enumeration
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 3 /* entry */
        start local 3 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         3: .line 539
            aload 3 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getObject:()Ljava/lang/Object;
            instanceof java.security.cert.Certificate
            ifeq 7
         4: .line 541
            aload 3 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getObject:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate
            astore 4 /* c */
        start local 4 // java.security.cert.Certificate c
         5: .line 543
            aload 4 /* c */
            aload 1 /* cert */
            invokevirtual java.security.cert.Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 10
         6: .line 545
            aload 3 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getAlias:()Ljava/lang/String;
            areturn
        end local 4 // java.security.cert.Certificate c
         7: .line 550
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            aload 3 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
            astore 4 /* chain */
        start local 4 // java.security.cert.Certificate[] chain
         8: .line 552
            aload 4 /* chain */
            ifnull 10
            aload 4 /* chain */
            iconst_0
            aaload
            aload 1 /* cert */
            invokevirtual java.security.cert.Certificate.equals:(Ljava/lang/Object;)Z
            ifeq 10
         9: .line 554
            aload 3 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getAlias:()Ljava/lang/String;
            areturn
        end local 4 // java.security.cert.Certificate[] chain
        end local 3 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        10: .line 535
      StackMap locals:
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 2
        11: .line 559
            aconst_null
            areturn
        end local 2 // java.util.Enumeration e
        end local 1 // java.security.cert.Certificate cert
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   12     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   12     1   cert  Ljava/security/cert/Certificate;
            1   12     2      e  Ljava/util/Enumeration;
            3   10     3  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            5    7     4      c  Ljava/security/cert/Certificate;
            8   10     4  chain  [Ljava/security/cert/Certificate;
    MethodParameters:
      Name  Flags
      cert  

  public java.security.cert.Certificate[] engineGetCertificateChain(java.lang.String);
    descriptor: (Ljava/lang/String;)[Ljava/security/cert/Certificate;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
         0: .line 565
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 2 /* entry */
        start local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         1: .line 567
            aload 2 /* entry */
            ifnull 3
         2: .line 569
            aload 2 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
            areturn
         3: .line 572
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            aconst_null
            areturn
        end local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
    MethodParameters:
       Name  Flags
      alias  

  public java.util.Date engineGetCreationDate(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/Date;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
         0: .line 577
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 2 /* entry */
        start local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         1: .line 579
            aload 2 /* entry */
            ifnull 3
         2: .line 581
            aload 2 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getDate:()Ljava/util/Date;
            areturn
         3: .line 584
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            aconst_null
            areturn
        end local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
    MethodParameters:
       Name  Flags
      alias  

  public java.security.Key engineGetKey(java.lang.String, char[]);
    descriptor: (Ljava/lang/String;[C)Ljava/security/Key;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
        start local 2 // char[] password
         0: .line 592
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 3 /* entry */
        start local 3 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         1: .line 594
            aload 3 /* entry */
            ifnull 2
            aload 3 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getType:()I
            iconst_1
            if_icmpne 3
         2: .line 596
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            aconst_null
            areturn
         3: .line 599
      StackMap locals:
      StackMap stack:
            aload 3 /* entry */
            aload 2 /* password */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getObject:([C)Ljava/lang/Object;
            checkcast java.security.Key
            areturn
        end local 3 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        end local 2 // char[] password
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    4     1     alias  Ljava/lang/String;
            0    4     2  password  [C
            1    4     3     entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
          Name  Flags
      alias     
      password  

  public boolean engineIsCertificateEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
         0: .line 605
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 2 /* entry */
        start local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         1: .line 607
            aload 2 /* entry */
            ifnull 3
            aload 2 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getType:()I
            iconst_1
            if_icmpne 3
         2: .line 609
            iconst_1
            ireturn
         3: .line 612
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
    MethodParameters:
       Name  Flags
      alias  

  public boolean engineIsKeyEntry(java.lang.String);
    descriptor: (Ljava/lang/String;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
         0: .line 618
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 2 /* entry */
        start local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         1: .line 620
            aload 2 /* entry */
            ifnull 3
            aload 2 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getType:()I
            iconst_1
            if_icmpeq 3
         2: .line 622
            iconst_1
            ireturn
         3: .line 625
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    4     1  alias  Ljava/lang/String;
            1    4     2  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
    MethodParameters:
       Name  Flags
      alias  

  public void engineSetCertificateEntry(java.lang.String, java.security.cert.Certificate);
    descriptor: (Ljava/lang/String;Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
        start local 2 // java.security.cert.Certificate cert
         0: .line 633
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 3 /* entry */
        start local 3 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         1: .line 635
            aload 3 /* entry */
            ifnull 3
            aload 3 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getType:()I
            iconst_1
            if_icmpeq 3
         2: .line 637
            new java.security.KeyStoreException
            dup
            new java.lang.StringBuilder
            dup
            ldc "key store already has a key entry with alias "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* alias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 640
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            new org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            dup
            aload 0 /* this */
            aload 1 /* alias */
            aload 2 /* cert */
            invokespecial org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.<init>:(Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/security/cert/Certificate;)V
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 641
            return
        end local 3 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        end local 2 // java.security.cert.Certificate cert
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    5     1  alias  Ljava/lang/String;
            0    5     2   cert  Ljava/security/cert/Certificate;
            1    5     3  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      cert   

  public void engineSetKeyEntry(java.lang.String, byte[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;[B[Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=4, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.lang.String alias
        start local 2 // byte[] key
        start local 3 // java.security.cert.Certificate[] chain
         0: .line 649
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            new org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            dup
            aload 0 /* this */
            aload 1 /* alias */
            aload 2 /* key */
            aload 3 /* chain */
            invokespecial org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.<init>:(Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;[B[Ljava/security/cert/Certificate;)V
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 650
            return
        end local 3 // java.security.cert.Certificate[] chain
        end local 2 // byte[] key
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    2     1  alias  Ljava/lang/String;
            0    2     2    key  [B
            0    2     3  chain  [Ljava/security/cert/Certificate;
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
       Name  Flags
      alias  
      key    
      chain  

  public void engineSetKeyEntry(java.lang.String, java.security.Key, char[], java.security.cert.Certificate[]);
    descriptor: (Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=6, args_size=5
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore 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 659
            aload 2 /* key */
            instanceof java.security.PrivateKey
            ifeq 2
            aload 4 /* chain */
            ifnonnull 2
         1: .line 661
            new java.security.KeyStoreException
            dup
            ldc "no certificate chain for private key"
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 666
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 1 /* alias */
            new org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            dup
            aload 0 /* this */
            aload 1 /* alias */
            aload 2 /* key */
            aload 3 /* password */
            aload 4 /* chain */
            invokespecial org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.<init>:(Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/security/Key;[C[Ljava/security/cert/Certificate;)V
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 667
            goto 6
         4: .line 668
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 5 /* e */
        start local 5 // java.lang.Exception e
         5: .line 670
            new java.security.KeyStoreException
            dup
            aload 5 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokespecial java.security.KeyStoreException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.lang.Exception e
         6: .line 672
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.security.cert.Certificate[] chain
        end local 3 // char[] password
        end local 2 // java.security.Key key
        end local 1 // java.lang.String alias
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0    7     1     alias  Ljava/lang/String;
            0    7     2       key  Ljava/security/Key;
            0    7     3  password  [C
            0    7     4     chain  [Ljava/security/cert/Certificate;
            5    6     5         e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.Exception
    Exceptions:
      throws java.security.KeyStoreException
    MethodParameters:
          Name  Flags
      alias     
      key       
      password  
      chain     

  public int engineSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
         0: .line 676
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.size:()I
            ireturn
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JDKKeyStore;

  protected void loadStore(java.io.InputStream);
    descriptor: (Ljava/io/InputStream;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=10, locals=11, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.io.InputStream in
         0: .line 683
            new java.io.DataInputStream
            dup
            aload 1 /* in */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 2 /* dIn */
        start local 2 // java.io.DataInputStream dIn
         1: .line 684
            aload 2 /* dIn */
            invokevirtual java.io.DataInputStream.read:()I
            istore 3 /* type */
        start local 3 // int type
         2: .line 686
            goto 27
         3: .line 688
      StackMap locals: java.io.DataInputStream int
      StackMap stack:
            aload 2 /* dIn */
            invokevirtual java.io.DataInputStream.readUTF:()Ljava/lang/String;
            astore 4 /* alias */
        start local 4 // java.lang.String alias
         4: .line 689
            new java.util.Date
            dup
            aload 2 /* dIn */
            invokevirtual java.io.DataInputStream.readLong:()J
            invokespecial java.util.Date.<init>:(J)V
            astore 5 /* date */
        start local 5 // java.util.Date date
         5: .line 690
            aload 2 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 6 /* chainLength */
        start local 6 // int chainLength
         6: .line 691
            aconst_null
            astore 7 /* chain */
        start local 7 // java.security.cert.Certificate[] chain
         7: .line 693
            iload 6 /* chainLength */
            ifeq 14
         8: .line 695
            iload 6 /* chainLength */
            anewarray java.security.cert.Certificate
            astore 7 /* chain */
         9: .line 697
            iconst_0
            istore 8 /* i */
        start local 8 // int i
        10: goto 13
        11: .line 699
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore java.io.InputStream java.io.DataInputStream int java.lang.String java.util.Date int java.security.cert.Certificate[] int
      StackMap stack:
            aload 7 /* chain */
            iload 8 /* i */
            aload 0 /* this */
            aload 2 /* dIn */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.decodeCertificate:(Ljava/io/DataInputStream;)Ljava/security/cert/Certificate;
            aastore
        12: .line 697
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 8 /* i */
            iload 6 /* chainLength */
            if_icmpne 11
        end local 8 // int i
        14: .line 703
      StackMap locals:
      StackMap stack:
            iload 3 /* type */
            tableswitch { // 1 - 4
                    1: 15
                    2: 18
                    3: 21
                    4: 21
              default: 25
          }
        15: .line 706
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* dIn */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.decodeCertificate:(Ljava/io/DataInputStream;)Ljava/security/cert/Certificate;
            astore 8 /* cert */
        start local 8 // java.security.cert.Certificate cert
        16: .line 708
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 4 /* alias */
            new org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            dup
            aload 0 /* this */
            aload 4 /* alias */
            aload 5 /* date */
            iconst_1
            aload 8 /* cert */
            invokespecial org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.<init>:(Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/util/Date;ILjava/lang/Object;)V
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        17: .line 709
            goto 26
        end local 8 // java.security.cert.Certificate cert
        18: .line 711
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* dIn */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.decodeKey:(Ljava/io/DataInputStream;)Ljava/security/Key;
            astore 9 /* key */
        start local 9 // java.security.Key key
        19: .line 712
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 4 /* alias */
            new org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            dup
            aload 0 /* this */
            aload 4 /* alias */
            aload 5 /* date */
            iconst_2
            aload 9 /* key */
            aload 7 /* chain */
            invokespecial org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.<init>:(Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/util/Date;ILjava/lang/Object;[Ljava/security/cert/Certificate;)V
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        20: .line 713
            goto 26
        end local 9 // java.security.Key key
        21: .line 716
      StackMap locals:
      StackMap stack:
            aload 2 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            newarray 8
            astore 10 /* b */
        start local 10 // byte[] b
        22: .line 718
            aload 2 /* dIn */
            aload 10 /* b */
            invokevirtual java.io.DataInputStream.readFully:([B)V
        23: .line 719
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            aload 4 /* alias */
            new org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            dup
            aload 0 /* this */
            aload 4 /* alias */
            aload 5 /* date */
            iload 3 /* type */
            aload 10 /* b */
            aload 7 /* chain */
            invokespecial org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.<init>:(Lorg/bouncycastle/jce/provider/JDKKeyStore;Ljava/lang/String;Ljava/util/Date;ILjava/lang/Object;[Ljava/security/cert/Certificate;)V
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        24: .line 720
            goto 26
        end local 10 // byte[] b
        25: .line 722
      StackMap locals:
      StackMap stack:
            new java.lang.RuntimeException
            dup
            ldc "Unknown object type in store."
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        26: .line 725
      StackMap locals:
      StackMap stack:
            aload 2 /* dIn */
            invokevirtual java.io.DataInputStream.read:()I
            istore 3 /* type */
        end local 7 // java.security.cert.Certificate[] chain
        end local 6 // int chainLength
        end local 5 // java.util.Date date
        end local 4 // java.lang.String alias
        27: .line 686
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore java.io.InputStream java.io.DataInputStream int
      StackMap stack:
            iload 3 /* type */
            ifgt 3
        28: .line 727
            return
        end local 3 // int type
        end local 2 // java.io.DataInputStream dIn
        end local 1 // java.io.InputStream in
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   29     0         this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   29     1           in  Ljava/io/InputStream;
            1   29     2          dIn  Ljava/io/DataInputStream;
            2   29     3         type  I
            4   27     4        alias  Ljava/lang/String;
            5   27     5         date  Ljava/util/Date;
            6   27     6  chainLength  I
            7   27     7        chain  [Ljava/security/cert/Certificate;
           10   14     8            i  I
           16   18     8         cert  Ljava/security/cert/Certificate;
           19   21     9          key  Ljava/security/Key;
           22   25    10            b  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      in    

  protected void saveStore(java.io.OutputStream);
    descriptor: (Ljava/io/OutputStream;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.io.OutputStream out
         0: .line 733
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.elements:()Ljava/util/Enumeration;
            astore 2 /* e */
        start local 2 // java.util.Enumeration e
         1: .line 734
            new java.io.DataOutputStream
            dup
            aload 1 /* out */
            invokespecial java.io.DataOutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* dOut */
        start local 3 // java.io.DataOutputStream dOut
         2: .line 736
            goto 27
         3: .line 738
      StackMap locals: java.util.Enumeration java.io.DataOutputStream
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Enumeration.nextElement:()Ljava/lang/Object;
            checkcast org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
            astore 4 /* entry */
        start local 4 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
         4: .line 740
            aload 3 /* dOut */
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getType:()I
            invokevirtual java.io.DataOutputStream.write:(I)V
         5: .line 741
            aload 3 /* dOut */
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getAlias:()Ljava/lang/String;
            invokevirtual java.io.DataOutputStream.writeUTF:(Ljava/lang/String;)V
         6: .line 742
            aload 3 /* dOut */
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getDate:()Ljava/util/Date;
            invokevirtual java.util.Date.getTime:()J
            invokevirtual java.io.DataOutputStream.writeLong:(J)V
         7: .line 744
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getCertificateChain:()[Ljava/security/cert/Certificate;
            astore 5 /* chain */
        start local 5 // java.security.cert.Certificate[] chain
         8: .line 745
            aload 5 /* chain */
            ifnonnull 11
         9: .line 747
            aload 3 /* dOut */
            iconst_0
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        10: .line 748
            goto 17
        11: .line 751
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry java.security.cert.Certificate[]
      StackMap stack:
            aload 3 /* dOut */
            aload 5 /* chain */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        12: .line 752
            iconst_0
            istore 6 /* i */
        start local 6 // int i
        13: goto 16
        14: .line 754
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            aload 5 /* chain */
            iload 6 /* i */
            aaload
            aload 3 /* dOut */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.encodeCertificate:(Ljava/security/cert/Certificate;Ljava/io/DataOutputStream;)V
        15: .line 752
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        16: iload 6 /* i */
            aload 5 /* chain */
            arraylength
            if_icmpne 14
        end local 6 // int i
        17: .line 758
      StackMap locals:
      StackMap stack:
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getType:()I
            tableswitch { // 1 - 4
                    1: 18
                    2: 20
                    3: 22
                    4: 22
              default: 26
          }
        18: .line 761
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getObject:()Ljava/lang/Object;
            checkcast java.security.cert.Certificate
            aload 3 /* dOut */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.encodeCertificate:(Ljava/security/cert/Certificate;Ljava/io/DataOutputStream;)V
        19: .line 762
            goto 27
        20: .line 764
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getObject:()Ljava/lang/Object;
            checkcast java.security.Key
            aload 3 /* dOut */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.encodeKey:(Ljava/security/Key;Ljava/io/DataOutputStream;)V
        21: .line 765
            goto 27
        22: .line 768
      StackMap locals:
      StackMap stack:
            aload 4 /* entry */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry.getObject:()Ljava/lang/Object;
            checkcast byte[]
            astore 6 /* b */
        start local 6 // byte[] b
        23: .line 770
            aload 3 /* dOut */
            aload 6 /* b */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
        24: .line 771
            aload 3 /* dOut */
            aload 6 /* b */
            invokevirtual java.io.DataOutputStream.write:([B)V
        25: .line 772
            goto 27
        end local 6 // byte[] b
        26: .line 774
      StackMap locals:
      StackMap stack:
            new java.lang.RuntimeException
            dup
            ldc "Unknown object type in store."
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.security.cert.Certificate[] chain
        end local 4 // org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry entry
        27: .line 736
      StackMap locals:
      StackMap stack:
            aload 2 /* e */
            invokeinterface java.util.Enumeration.hasMoreElements:()Z
            ifne 3
        28: .line 778
            aload 3 /* dOut */
            iconst_0
            invokevirtual java.io.DataOutputStream.write:(I)V
        29: .line 779
            return
        end local 3 // java.io.DataOutputStream dOut
        end local 2 // java.util.Enumeration e
        end local 1 // java.io.OutputStream out
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   30     0   this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   30     1    out  Ljava/io/OutputStream;
            1   30     2      e  Ljava/util/Enumeration;
            2   30     3   dOut  Ljava/io/DataOutputStream;
            4   27     4  entry  Lorg/bouncycastle/jce/provider/JDKKeyStore$StoreEntry;
            8   27     5  chain  [Ljava/security/cert/Certificate;
           13   17     6      i  I
           23   26     6      b  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      out   

  public void engineLoad(java.io.InputStream, char[]);
    descriptor: (Ljava/io/InputStream;[C)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=14, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.io.InputStream stream
        start local 2 // char[] password
         0: .line 786
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.clear:()V
         1: .line 788
            aload 1 /* stream */
            ifnonnull 3
         2: .line 790
            return
         3: .line 793
      StackMap locals:
      StackMap stack:
            new java.io.DataInputStream
            dup
            aload 1 /* stream */
            invokespecial java.io.DataInputStream.<init>:(Ljava/io/InputStream;)V
            astore 3 /* dIn */
        start local 3 // java.io.DataInputStream dIn
         4: .line 794
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 4 /* version */
        start local 4 // int version
         5: .line 796
            iload 4 /* version */
            iconst_1
            if_icmpeq 8
         6: .line 798
            iload 4 /* version */
            ifeq 8
         7: .line 800
            new java.io.IOException
            dup
            ldc "Wrong version of key store."
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 804
      StackMap locals: java.io.DataInputStream int
      StackMap stack:
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            newarray 8
            astore 5 /* salt */
        start local 5 // byte[] salt
         9: .line 806
            aload 3 /* dIn */
            aload 5 /* salt */
            invokevirtual java.io.DataInputStream.readFully:([B)V
        10: .line 808
            aload 3 /* dIn */
            invokevirtual java.io.DataInputStream.readInt:()I
            istore 6 /* iterationCount */
        start local 6 // int iterationCount
        11: .line 813
            new org.bouncycastle.crypto.macs.HMac
            dup
            new org.bouncycastle.crypto.digests.SHA1Digest
            dup
            invokespecial org.bouncycastle.crypto.digests.SHA1Digest.<init>:()V
            invokespecial org.bouncycastle.crypto.macs.HMac.<init>:(Lorg/bouncycastle/crypto/Digest;)V
            astore 7 /* hMac */
        start local 7 // org.bouncycastle.crypto.macs.HMac hMac
        12: .line 814
            aload 2 /* password */
            ifnull 28
            aload 2 /* password */
            arraylength
            ifeq 28
        13: .line 816
            aload 2 /* password */
            invokestatic org.bouncycastle.crypto.PBEParametersGenerator.PKCS12PasswordToBytes:([C)[B
            astore 8 /* passKey */
        start local 8 // byte[] passKey
        14: .line 818
            new org.bouncycastle.crypto.generators.PKCS12ParametersGenerator
            dup
            new org.bouncycastle.crypto.digests.SHA1Digest
            dup
            invokespecial org.bouncycastle.crypto.digests.SHA1Digest.<init>:()V
            invokespecial org.bouncycastle.crypto.generators.PKCS12ParametersGenerator.<init>:(Lorg/bouncycastle/crypto/Digest;)V
            astore 9 /* pbeGen */
        start local 9 // org.bouncycastle.crypto.PBEParametersGenerator pbeGen
        15: .line 819
            aload 9 /* pbeGen */
            aload 8 /* passKey */
            aload 5 /* salt */
            iload 6 /* iterationCount */
            invokevirtual org.bouncycastle.crypto.PBEParametersGenerator.init:([B[BI)V
        16: .line 820
            aload 9 /* pbeGen */
            aload 7 /* hMac */
            invokevirtual org.bouncycastle.crypto.macs.HMac.getMacSize:()I
            invokevirtual org.bouncycastle.crypto.PBEParametersGenerator.generateDerivedMacParameters:(I)Lorg/bouncycastle/crypto/CipherParameters;
            astore 10 /* macParams */
        start local 10 // org.bouncycastle.crypto.CipherParameters macParams
        17: .line 821
            aload 8 /* passKey */
            iconst_0
            invokestatic org.bouncycastle.util.Arrays.fill:([BB)V
        18: .line 823
            aload 7 /* hMac */
            aload 10 /* macParams */
            invokevirtual org.bouncycastle.crypto.macs.HMac.init:(Lorg/bouncycastle/crypto/CipherParameters;)V
        19: .line 824
            new org.bouncycastle.crypto.io.MacInputStream
            dup
            aload 3 /* dIn */
            aload 7 /* hMac */
            invokespecial org.bouncycastle.crypto.io.MacInputStream.<init>:(Ljava/io/InputStream;Lorg/bouncycastle/crypto/Mac;)V
            astore 11 /* mIn */
        start local 11 // org.bouncycastle.crypto.io.MacInputStream mIn
        20: .line 826
            aload 0 /* this */
            aload 11 /* mIn */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.loadStore:(Ljava/io/InputStream;)V
        21: .line 829
            aload 7 /* hMac */
            invokevirtual org.bouncycastle.crypto.macs.HMac.getMacSize:()I
            newarray 8
            astore 12 /* mac */
        start local 12 // byte[] mac
        22: .line 830
            aload 7 /* hMac */
            aload 12 /* mac */
            iconst_0
            invokevirtual org.bouncycastle.crypto.macs.HMac.doFinal:([BI)I
            pop
        23: .line 834
            aload 7 /* hMac */
            invokevirtual org.bouncycastle.crypto.macs.HMac.getMacSize:()I
            newarray 8
            astore 13 /* oldMac */
        start local 13 // byte[] oldMac
        24: .line 835
            aload 3 /* dIn */
            aload 13 /* oldMac */
            invokevirtual java.io.DataInputStream.readFully:([B)V
        25: .line 837
            aload 12 /* mac */
            aload 13 /* oldMac */
            invokestatic org.bouncycastle.util.Arrays.constantTimeAreEqual:([B[B)Z
            ifne 31
        26: .line 839
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.table:Ljava/util/Hashtable;
            invokevirtual java.util.Hashtable.clear:()V
        27: .line 840
            new java.io.IOException
            dup
            ldc "KeyStore integrity check failed."
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 13 // byte[] oldMac
        end local 12 // byte[] mac
        end local 11 // org.bouncycastle.crypto.io.MacInputStream mIn
        end local 10 // org.bouncycastle.crypto.CipherParameters macParams
        end local 9 // org.bouncycastle.crypto.PBEParametersGenerator pbeGen
        end local 8 // byte[] passKey
        28: .line 845
      StackMap locals: byte[] int org.bouncycastle.crypto.macs.HMac
      StackMap stack:
            aload 0 /* this */
            aload 3 /* dIn */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.loadStore:(Ljava/io/InputStream;)V
        29: .line 849
            aload 7 /* hMac */
            invokevirtual org.bouncycastle.crypto.macs.HMac.getMacSize:()I
            newarray 8
            astore 8 /* oldMac */
        start local 8 // byte[] oldMac
        30: .line 850
            aload 3 /* dIn */
            aload 8 /* oldMac */
            invokevirtual java.io.DataInputStream.readFully:([B)V
        end local 8 // byte[] oldMac
        31: .line 852
      StackMap locals:
      StackMap stack:
            return
        end local 7 // org.bouncycastle.crypto.macs.HMac hMac
        end local 6 // int iterationCount
        end local 5 // byte[] salt
        end local 4 // int version
        end local 3 // java.io.DataInputStream dIn
        end local 2 // char[] password
        end local 1 // java.io.InputStream stream
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   32     0            this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   32     1          stream  Ljava/io/InputStream;
            0   32     2        password  [C
            4   32     3             dIn  Ljava/io/DataInputStream;
            5   32     4         version  I
            9   32     5            salt  [B
           11   32     6  iterationCount  I
           12   32     7            hMac  Lorg/bouncycastle/crypto/macs/HMac;
           14   28     8         passKey  [B
           15   28     9          pbeGen  Lorg/bouncycastle/crypto/PBEParametersGenerator;
           17   28    10       macParams  Lorg/bouncycastle/crypto/CipherParameters;
           20   28    11             mIn  Lorg/bouncycastle/crypto/io/MacInputStream;
           22   28    12             mac  [B
           24   28    13          oldMac  [B
           30   31     8          oldMac  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
          Name  Flags
      stream    
      password  

  public void engineStore(java.io.OutputStream, char[]);
    descriptor: (Ljava/io/OutputStream;[C)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=11, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
        start local 1 // java.io.OutputStream stream
        start local 2 // char[] password
         0: .line 858
            new java.io.DataOutputStream
            dup
            aload 1 /* stream */
            invokespecial java.io.DataOutputStream.<init>:(Ljava/io/OutputStream;)V
            astore 3 /* dOut */
        start local 3 // java.io.DataOutputStream dOut
         1: .line 859
            bipush 20
            newarray 8
            astore 4 /* salt */
        start local 4 // byte[] salt
         2: .line 860
            sipush 1024
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.random:Ljava/security/SecureRandom;
            invokevirtual java.security.SecureRandom.nextInt:()I
            sipush 1023
            iand
            iadd
            istore 5 /* iterationCount */
        start local 5 // int iterationCount
         3: .line 862
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JDKKeyStore.random:Ljava/security/SecureRandom;
            aload 4 /* salt */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         4: .line 864
            aload 3 /* dOut */
            iconst_1
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
         5: .line 865
            aload 3 /* dOut */
            aload 4 /* salt */
            arraylength
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
         6: .line 866
            aload 3 /* dOut */
            aload 4 /* salt */
            invokevirtual java.io.DataOutputStream.write:([B)V
         7: .line 867
            aload 3 /* dOut */
            iload 5 /* iterationCount */
            invokevirtual java.io.DataOutputStream.writeInt:(I)V
         8: .line 869
            new org.bouncycastle.crypto.macs.HMac
            dup
            new org.bouncycastle.crypto.digests.SHA1Digest
            dup
            invokespecial org.bouncycastle.crypto.digests.SHA1Digest.<init>:()V
            invokespecial org.bouncycastle.crypto.macs.HMac.<init>:(Lorg/bouncycastle/crypto/Digest;)V
            astore 6 /* hMac */
        start local 6 // org.bouncycastle.crypto.macs.HMac hMac
         9: .line 870
            new org.bouncycastle.crypto.io.MacOutputStream
            dup
            aload 3 /* dOut */
            aload 6 /* hMac */
            invokespecial org.bouncycastle.crypto.io.MacOutputStream.<init>:(Ljava/io/OutputStream;Lorg/bouncycastle/crypto/Mac;)V
            astore 7 /* mOut */
        start local 7 // org.bouncycastle.crypto.io.MacOutputStream mOut
        10: .line 871
            new org.bouncycastle.crypto.generators.PKCS12ParametersGenerator
            dup
            new org.bouncycastle.crypto.digests.SHA1Digest
            dup
            invokespecial org.bouncycastle.crypto.digests.SHA1Digest.<init>:()V
            invokespecial org.bouncycastle.crypto.generators.PKCS12ParametersGenerator.<init>:(Lorg/bouncycastle/crypto/Digest;)V
            astore 8 /* pbeGen */
        start local 8 // org.bouncycastle.crypto.PBEParametersGenerator pbeGen
        11: .line 872
            aload 2 /* password */
            invokestatic org.bouncycastle.crypto.PBEParametersGenerator.PKCS12PasswordToBytes:([C)[B
            astore 9 /* passKey */
        start local 9 // byte[] passKey
        12: .line 874
            aload 8 /* pbeGen */
            aload 9 /* passKey */
            aload 4 /* salt */
            iload 5 /* iterationCount */
            invokevirtual org.bouncycastle.crypto.PBEParametersGenerator.init:([B[BI)V
        13: .line 876
            aload 6 /* hMac */
            aload 8 /* pbeGen */
            aload 6 /* hMac */
            invokevirtual org.bouncycastle.crypto.macs.HMac.getMacSize:()I
            invokevirtual org.bouncycastle.crypto.PBEParametersGenerator.generateDerivedMacParameters:(I)Lorg/bouncycastle/crypto/CipherParameters;
            invokevirtual org.bouncycastle.crypto.macs.HMac.init:(Lorg/bouncycastle/crypto/CipherParameters;)V
        14: .line 878
            iconst_0
            istore 10 /* i */
        start local 10 // int i
        15: goto 18
        16: .line 880
      StackMap locals: org.bouncycastle.jce.provider.JDKKeyStore java.io.OutputStream char[] java.io.DataOutputStream byte[] int org.bouncycastle.crypto.macs.HMac org.bouncycastle.crypto.io.MacOutputStream org.bouncycastle.crypto.PBEParametersGenerator byte[] int
      StackMap stack:
            aload 9 /* passKey */
            iload 10 /* i */
            iconst_0
            bastore
        17: .line 878
            iinc 10 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 10 /* i */
            aload 9 /* passKey */
            arraylength
            if_icmpne 16
        end local 10 // int i
        19: .line 883
            aload 0 /* this */
            aload 7 /* mOut */
            invokevirtual org.bouncycastle.jce.provider.JDKKeyStore.saveStore:(Ljava/io/OutputStream;)V
        20: .line 885
            aload 6 /* hMac */
            invokevirtual org.bouncycastle.crypto.macs.HMac.getMacSize:()I
            newarray 8
            astore 10 /* mac */
        start local 10 // byte[] mac
        21: .line 887
            aload 6 /* hMac */
            aload 10 /* mac */
            iconst_0
            invokevirtual org.bouncycastle.crypto.macs.HMac.doFinal:([BI)I
            pop
        22: .line 889
            aload 3 /* dOut */
            aload 10 /* mac */
            invokevirtual java.io.DataOutputStream.write:([B)V
        23: .line 891
            aload 3 /* dOut */
            invokevirtual java.io.DataOutputStream.close:()V
        24: .line 892
            return
        end local 10 // byte[] mac
        end local 9 // byte[] passKey
        end local 8 // org.bouncycastle.crypto.PBEParametersGenerator pbeGen
        end local 7 // org.bouncycastle.crypto.io.MacOutputStream mOut
        end local 6 // org.bouncycastle.crypto.macs.HMac hMac
        end local 5 // int iterationCount
        end local 4 // byte[] salt
        end local 3 // java.io.DataOutputStream dOut
        end local 2 // char[] password
        end local 1 // java.io.OutputStream stream
        end local 0 // org.bouncycastle.jce.provider.JDKKeyStore this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   25     0            this  Lorg/bouncycastle/jce/provider/JDKKeyStore;
            0   25     1          stream  Ljava/io/OutputStream;
            0   25     2        password  [C
            1   25     3            dOut  Ljava/io/DataOutputStream;
            2   25     4            salt  [B
            3   25     5  iterationCount  I
            9   25     6            hMac  Lorg/bouncycastle/crypto/macs/HMac;
           10   25     7            mOut  Lorg/bouncycastle/crypto/io/MacOutputStream;
           11   25     8          pbeGen  Lorg/bouncycastle/crypto/PBEParametersGenerator;
           12   25     9         passKey  [B
           15   19    10               i  I
           21   25    10             mac  [B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
          Name  Flags
      stream    
      password  
}
SourceFile: "JDKKeyStore.java"
NestMembers:
  org.bouncycastle.jce.provider.JDKKeyStore$BouncyCastleStore  org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry
InnerClasses:
  public BouncyCastleStore = org.bouncycastle.jce.provider.JDKKeyStore$BouncyCastleStore of org.bouncycastle.jce.provider.JDKKeyStore
  private StoreEntry = org.bouncycastle.jce.provider.JDKKeyStore$StoreEntry of org.bouncycastle.jce.provider.JDKKeyStore