public class javax.crypto.EncryptedPrivateKeyInfo
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: javax.crypto.EncryptedPrivateKeyInfo
  super_class: java.lang.Object
{
  private sun.security.x509.AlgorithmId algid;
    descriptor: Lsun/security/x509/AlgorithmId;
    flags: (0x0002) ACC_PRIVATE

  private byte[] encryptedData;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private byte[] encoded;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  public void <init>(byte[]);
    descriptor: ([B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // byte[] encoded
         0: .line 77
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 67
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         2: .line 79
            aload 1 /* encoded */
            ifnonnull 4
         3: .line 80
            new java.lang.NullPointerException
            dup
            ldc "the encoded parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 83
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo byte[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* encoded */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         5: .line 84
            new sun.security.util.DerValue
            dup
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 2 /* val */
        start local 2 // sun.security.util.DerValue val
         6: .line 86
            iconst_2
            anewarray sun.security.util.DerValue
            astore 3 /* seq */
        start local 3 // sun.security.util.DerValue[] seq
         7: .line 88
            aload 3 /* seq */
            iconst_0
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            aastore
         8: .line 89
            aload 3 /* seq */
            iconst_1
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            aastore
         9: .line 91
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 11
        10: .line 92
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "overrun, bytes = "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 95
      StackMap locals: sun.security.util.DerValue sun.security.util.DerValue[]
      StackMap stack:
            aload 0 /* this */
            aload 3 /* seq */
            iconst_0
            aaload
            invokestatic sun.security.x509.AlgorithmId.parse:(Lsun/security/util/DerValue;)Lsun/security/x509/AlgorithmId;
            putfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
        12: .line 96
            aload 3 /* seq */
            iconst_0
            aaload
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 14
        13: .line 97
            new java.io.IOException
            dup
            ldc "encryptionAlgorithm field overrun"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 100
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* seq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
        15: .line 101
            aload 3 /* seq */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 17
        16: .line 102
            new java.io.IOException
            dup
            ldc "encryptedData field overrun"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 104
      StackMap locals:
      StackMap stack:
            return
        end local 3 // sun.security.util.DerValue[] seq
        end local 2 // sun.security.util.DerValue val
        end local 1 // byte[] encoded
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   18     0     this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   18     1  encoded  [B
            6   18     2      val  Lsun/security/util/DerValue;
            7   18     3      seq  [Lsun/security/util/DerValue;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      encoded  

  public void <init>(java.lang.String, byte[]);
    descriptor: (Ljava/lang/String;[B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.lang.String algName
        start local 2 // byte[] encryptedData
         0: .line 131
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 67
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         2: .line 134
            aload 1 /* algName */
            ifnonnull 4
         3: .line 135
            new java.lang.NullPointerException
            dup
            ldc "the algName parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 137
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo java.lang.String byte[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* algName */
            invokestatic sun.security.x509.AlgorithmId.get:(Ljava/lang/String;)Lsun/security/x509/AlgorithmId;
            putfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
         5: .line 139
            aload 2 /* encryptedData */
            ifnonnull 7
         6: .line 140
            new java.lang.NullPointerException
            dup
            ldc "the encryptedData parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 142
      StackMap locals:
      StackMap stack:
            aload 2 /* encryptedData */
            arraylength
            ifne 9
         8: .line 143
            new java.lang.IllegalArgumentException
            dup
            ldc "the encryptedData parameter must not be empty"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 146
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* encryptedData */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
        10: .line 150
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
        11: .line 151
            return
        end local 2 // byte[] encryptedData
        end local 1 // java.lang.String algName
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   12     1        algName  Ljava/lang/String;
            0   12     2  encryptedData  [B
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
               Name  Flags
      algName        
      encryptedData  

  public void <init>(java.security.AlgorithmParameters, byte[]);
    descriptor: (Ljava/security/AlgorithmParameters;[B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.AlgorithmParameters algParams
        start local 2 // byte[] encryptedData
         0: .line 172
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 67
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         2: .line 175
            aload 1 /* algParams */
            ifnonnull 4
         3: .line 176
            new java.lang.NullPointerException
            dup
            ldc "algParams must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 178
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo java.security.AlgorithmParameters byte[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* algParams */
            invokestatic sun.security.x509.AlgorithmId.get:(Ljava/security/AlgorithmParameters;)Lsun/security/x509/AlgorithmId;
            putfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
         5: .line 180
            aload 2 /* encryptedData */
            ifnonnull 7
         6: .line 181
            new java.lang.NullPointerException
            dup
            ldc "encryptedData must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 182
      StackMap locals:
      StackMap stack:
            aload 2 /* encryptedData */
            arraylength
            ifne 9
         8: .line 183
            new java.lang.IllegalArgumentException
            dup
            ldc "the encryptedData parameter must not be empty"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 186
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* encryptedData */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
        10: .line 191
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
        11: .line 192
            return
        end local 2 // byte[] encryptedData
        end local 1 // java.security.AlgorithmParameters algParams
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   12     1      algParams  Ljava/security/AlgorithmParameters;
            0   12     2  encryptedData  [B
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
               Name  Flags
      algParams      
      encryptedData  

  public java.lang.String getAlgName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 208
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;

  public java.security.AlgorithmParameters getAlgParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 216
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getParameters:()Ljava/security/AlgorithmParameters;
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;

  public byte[] getEncryptedData();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 225
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(javax.crypto.Cipher);
    descriptor: (Ljavax/crypto/Cipher;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // javax.crypto.Cipher cipher
         0: .line 248
            aconst_null
            astore 2 /* encoded */
        start local 2 // byte[] encoded
         1: .line 250
            aload 1 /* cipher */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 2 /* encoded */
         2: .line 251
            aload 2 /* encoded */
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkPKCS8Encoding:([B)V
         3: .line 252
            goto 16
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo javax.crypto.Cipher byte[]
      StackMap stack: java.security.GeneralSecurityException
         4: astore 3 /* ex */
        start local 3 // java.security.GeneralSecurityException ex
         5: .line 253
            new java.security.spec.InvalidKeySpecException
            dup
         6: .line 254
            ldc "Cannot retrieve the PKCS8EncodedKeySpec"
            aload 3 /* ex */
         7: .line 253
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.security.GeneralSecurityException ex
         8: .line 255
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 3 /* ex */
        start local 3 // java.io.IOException ex
         9: .line 256
            new java.security.spec.InvalidKeySpecException
            dup
        10: .line 257
            ldc "Cannot retrieve the PKCS8EncodedKeySpec"
            aload 3 /* ex */
        11: .line 256
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.io.IOException ex
        12: .line 258
      StackMap locals:
      StackMap stack: java.lang.IllegalStateException
            astore 3 /* ex */
        start local 3 // java.lang.IllegalStateException ex
        13: .line 259
            new java.security.spec.InvalidKeySpecException
            dup
        14: .line 260
            ldc "Cannot retrieve the PKCS8EncodedKeySpec"
            aload 3 /* ex */
        15: .line 259
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.IllegalStateException ex
        16: .line 262
      StackMap locals:
      StackMap stack:
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 2 /* encoded */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            areturn
        end local 2 // byte[] encoded
        end local 1 // javax.crypto.Cipher cipher
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   17     0     this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   17     1   cipher  Ljavax/crypto/Cipher;
            1   17     2  encoded  [B
            5    8     3       ex  Ljava/security/GeneralSecurityException;
            9   12     3       ex  Ljava/io/IOException;
           13   16     3       ex  Ljava/lang/IllegalStateException;
      Exception table:
        from    to  target  type
           1     3       4  Class java.security.GeneralSecurityException
           1     3       8  Class java.io.IOException
           1     3      12  Class java.lang.IllegalStateException
    Exceptions:
      throws java.security.spec.InvalidKeySpecException
    MethodParameters:
        Name  Flags
      cipher  

  private java.security.spec.PKCS8EncodedKeySpec getKeySpecImpl(java.security.Key, java.security.Provider);
    descriptor: (Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
        start local 2 // java.security.Provider provider
         0: .line 268
            aconst_null
            astore 3 /* encoded */
        start local 3 // byte[] encoded
         1: .line 271
            aload 2 /* provider */
            ifnonnull 4
         2: .line 273
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 4 /* c */
        start local 4 // javax.crypto.Cipher c
         3: .line 274
            goto 5
        end local 4 // javax.crypto.Cipher c
         4: .line 275
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            aload 2 /* provider */
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/Cipher;
            astore 4 /* c */
        start local 4 // javax.crypto.Cipher c
         5: .line 277
      StackMap locals: javax.crypto.Cipher
      StackMap stack:
            aload 4 /* c */
            iconst_2
            aload 1 /* decryptKey */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getParameters:()Ljava/security/AlgorithmParameters;
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
         6: .line 278
            aload 4 /* c */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 3 /* encoded */
         7: .line 279
            aload 3 /* encoded */
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkPKCS8Encoding:([B)V
         8: .line 280
            goto 19
        end local 4 // javax.crypto.Cipher c
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo java.security.Key java.security.Provider byte[]
      StackMap stack: java.security.NoSuchAlgorithmException
         9: astore 5 /* nsae */
        start local 5 // java.security.NoSuchAlgorithmException nsae
        10: .line 282
            aload 5 /* nsae */
            athrow
        end local 5 // java.security.NoSuchAlgorithmException nsae
        11: .line 283
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 5 /* ex */
        start local 5 // java.security.GeneralSecurityException ex
        12: .line 284
            new java.security.InvalidKeyException
            dup
        13: .line 285
            ldc "Cannot retrieve the PKCS8EncodedKeySpec"
            aload 5 /* ex */
        14: .line 284
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.security.GeneralSecurityException ex
        15: .line 286
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 5 /* ex */
        start local 5 // java.io.IOException ex
        16: .line 287
            new java.security.InvalidKeyException
            dup
        17: .line 288
            ldc "Cannot retrieve the PKCS8EncodedKeySpec"
            aload 5 /* ex */
        18: .line 287
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.io.IOException ex
        start local 4 // javax.crypto.Cipher c
        19: .line 290
      StackMap locals: javax.crypto.Cipher
      StackMap stack:
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 3 /* encoded */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            areturn
        end local 4 // javax.crypto.Cipher c
        end local 3 // byte[] encoded
        end local 2 // java.security.Provider provider
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   20     0        this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   20     1  decryptKey  Ljava/security/Key;
            0   20     2    provider  Ljava/security/Provider;
            1   20     3     encoded  [B
            3    4     4           c  Ljavax/crypto/Cipher;
            5    9     4           c  Ljavax/crypto/Cipher;
           19   20     4           c  Ljavax/crypto/Cipher;
           10   11     5        nsae  Ljava/security/NoSuchAlgorithmException;
           12   15     5          ex  Ljava/security/GeneralSecurityException;
           16   19     5          ex  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           1     8       9  Class java.security.NoSuchAlgorithmException
           1     8      11  Class java.security.GeneralSecurityException
           1     8      15  Class java.io.IOException
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      decryptKey  
      provider    

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(java.security.Key);
    descriptor: (Ljava/security/Key;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
         0: .line 310
            aload 1 /* decryptKey */
            ifnonnull 2
         1: .line 311
            new java.lang.NullPointerException
            dup
            ldc "decryptKey is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 313
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* decryptKey */
            aconst_null
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.getKeySpecImpl:(Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
            areturn
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0    3     1  decryptKey  Ljava/security/Key;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      decryptKey  

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(java.security.Key, java.lang.String);
    descriptor: (Ljava/security/Key;Ljava/lang/String;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
        start local 2 // java.lang.String providerName
         0: .line 338
            aload 1 /* decryptKey */
            ifnonnull 2
         1: .line 339
            new java.lang.NullPointerException
            dup
            ldc "decryptKey is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 341
      StackMap locals:
      StackMap stack:
            aload 2 /* providerName */
            ifnonnull 4
         3: .line 342
            new java.lang.NullPointerException
            dup
            ldc "provider is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 344
      StackMap locals:
      StackMap stack:
            aload 2 /* providerName */
            invokestatic java.security.Security.getProvider:(Ljava/lang/String;)Ljava/security/Provider;
            astore 3 /* provider */
        start local 3 // java.security.Provider provider
         5: .line 345
            aload 3 /* provider */
            ifnonnull 9
         6: .line 346
            new java.security.NoSuchProviderException
            dup
            new java.lang.StringBuilder
            dup
            ldc "provider "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         7: .line 347
            aload 2 /* providerName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " not found"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 346
            invokespecial java.security.NoSuchProviderException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 349
      StackMap locals: java.security.Provider
      StackMap stack:
            aload 0 /* this */
            aload 1 /* decryptKey */
            aload 3 /* provider */
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.getKeySpecImpl:(Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
            areturn
        end local 3 // java.security.Provider provider
        end local 2 // java.lang.String providerName
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   10     0          this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   10     1    decryptKey  Ljava/security/Key;
            0   10     2  providerName  Ljava/lang/String;
            5   10     3      provider  Ljava/security/Provider;
    Exceptions:
      throws java.security.NoSuchProviderException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
              Name  Flags
      decryptKey    
      providerName  

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(java.security.Key, java.security.Provider);
    descriptor: (Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
        start local 2 // java.security.Provider provider
         0: .line 372
            aload 1 /* decryptKey */
            ifnonnull 2
         1: .line 373
            new java.lang.NullPointerException
            dup
            ldc "decryptKey is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 375
      StackMap locals:
      StackMap stack:
            aload 2 /* provider */
            ifnonnull 4
         3: .line 376
            new java.lang.NullPointerException
            dup
            ldc "provider is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 378
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* decryptKey */
            aload 2 /* provider */
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.getKeySpecImpl:(Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
            areturn
        end local 2 // java.security.Provider provider
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0    5     1  decryptKey  Ljava/security/Key;
            0    5     2    provider  Ljava/security/Provider;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      decryptKey  
      provider    

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 389
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
            ifnonnull 7
         1: .line 390
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 1 /* out */
        start local 1 // sun.security.util.DerOutputStream out
         2: .line 391
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* tmp */
        start local 2 // sun.security.util.DerOutputStream tmp
         3: .line 394
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            aload 2 /* tmp */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
         4: .line 397
            aload 2 /* tmp */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
         5: .line 400
            aload 1 /* out */
            bipush 48
            aload 2 /* tmp */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
         6: .line 401
            aload 0 /* this */
            aload 1 /* out */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
        end local 2 // sun.security.util.DerOutputStream tmp
        end local 1 // sun.security.util.DerOutputStream out
         7: .line 403
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            2    7     1   out  Lsun/security/util/DerOutputStream;
            3    7     2   tmp  Lsun/security/util/DerOutputStream;
    Exceptions:
      throws java.io.IOException

  private static void checkTag(sun.security.util.DerValue, byte, java.lang.String);
    descriptor: (Lsun/security/util/DerValue;BLjava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.util.DerValue val
        start local 1 // byte tag
        start local 2 // java.lang.String valName
         0: .line 408
            aload 0 /* val */
            invokevirtual sun.security.util.DerValue.getTag:()B
            iload 1 /* tag */
            if_icmpeq 4
         1: .line 409
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "invalid key encoding - wrong tag for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 410
            aload 2 /* valName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 409
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 412
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String valName
        end local 1 // byte tag
        end local 0 // sun.security.util.DerValue val
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0      val  Lsun/security/util/DerValue;
            0    5     1      tag  B
            0    5     2  valName  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      val      
      tag      
      valName  

  private static void checkPKCS8Encoding(byte[]);
    descriptor: ([B)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // byte[] encodedKey
         0: .line 417
            new sun.security.util.DerInputStream
            dup
            aload 0 /* encodedKey */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 1 /* in */
        start local 1 // sun.security.util.DerInputStream in
         1: .line 418
            aload 1 /* in */
            iconst_3
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 2 /* values */
        start local 2 // sun.security.util.DerValue[] values
         2: .line 420
            aload 2 /* values */
            arraylength
            tableswitch { // 3 - 4
                    3: 4
                    4: 3
              default: 11
          }
         3: .line 422
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 2 /* values */
            iconst_3
            aaload
            bipush -128
            ldc "attributes"
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkTag:(Lsun/security/util/DerValue;BLjava/lang/String;)V
         4: .line 425
      StackMap locals:
      StackMap stack:
            aload 2 /* values */
            iconst_0
            aaload
            iconst_2
            ldc "version"
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkTag:(Lsun/security/util/DerValue;BLjava/lang/String;)V
         5: .line 426
            aload 2 /* values */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.toDerInputStream:()Lsun/security/util/DerInputStream;
            astore 3 /* algid */
        start local 3 // sun.security.util.DerInputStream algid
         6: .line 427
            aload 3 /* algid */
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            pop
         7: .line 428
            aload 3 /* algid */
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 9
         8: .line 429
            aload 3 /* algid */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            pop
         9: .line 431
      StackMap locals: sun.security.util.DerInputStream
      StackMap stack:
            aload 2 /* values */
            iconst_2
            aaload
            iconst_4
            ldc "privateKey"
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkTag:(Lsun/security/util/DerValue;BLjava/lang/String;)V
        10: .line 432
            goto 12
        end local 3 // sun.security.util.DerInputStream algid
        11: .line 434
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            ldc "invalid key encoding"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 436
      StackMap locals:
      StackMap stack:
            return
        end local 2 // sun.security.util.DerValue[] values
        end local 1 // sun.security.util.DerInputStream in
        end local 0 // byte[] encodedKey
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   13     0  encodedKey  [B
            1   13     1          in  Lsun/security/util/DerInputStream;
            2   13     2      values  [Lsun/security/util/DerValue;
            6   11     3       algid  Lsun/security/util/DerInputStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
            Name  Flags
      encodedKey  
}
SourceFile: "EncryptedPrivateKeyInfo.java"