public class org.bouncycastle.jce.provider.JCERSACipher extends org.bouncycastle.jce.provider.WrapCipherSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.jce.provider.JCERSACipher
  super_class: org.bouncycastle.jce.provider.WrapCipherSpi
{
  private org.bouncycastle.crypto.AsymmetricBlockCipher cipher;
    descriptor: Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
    flags: (0x0002) ACC_PRIVATE

  private java.security.spec.AlgorithmParameterSpec paramSpec;
    descriptor: Ljava/security/spec/AlgorithmParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  private java.security.AlgorithmParameters engineParams;
    descriptor: Ljava/security/AlgorithmParameters;
    flags: (0x0002) ACC_PRIVATE

  private boolean publicKeyOnly;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private boolean privateKeyOnly;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private java.io.ByteArrayOutputStream bOut;
    descriptor: Ljava/io/ByteArrayOutputStream;
    flags: (0x0002) ACC_PRIVATE

  public void <init>(org.bouncycastle.crypto.AsymmetricBlockCipher);
    descriptor: (Lorg/bouncycastle/crypto/AsymmetricBlockCipher;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // org.bouncycastle.crypto.AsymmetricBlockCipher engine
         0: .line 45
            aload 0 /* this */
            invokespecial org.bouncycastle.jce.provider.WrapCipherSpi.<init>:()V
         1: .line 41
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.publicKeyOnly:Z
         2: .line 42
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.privateKeyOnly:Z
         3: .line 43
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
         4: .line 48
            aload 0 /* this */
            aload 1 /* engine */
            putfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
         5: .line 49
            return
        end local 1 // org.bouncycastle.crypto.AsymmetricBlockCipher engine
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    6     1  engine  Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
    MethodParameters:
        Name  Flags
      engine  

  public void <init>(javax.crypto.spec.OAEPParameterSpec);
    descriptor: (Ljavax/crypto/spec/OAEPParameterSpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // javax.crypto.spec.OAEPParameterSpec pSpec
         0: .line 51
            aload 0 /* this */
            invokespecial org.bouncycastle.jce.provider.WrapCipherSpi.<init>:()V
         1: .line 41
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.publicKeyOnly:Z
         2: .line 42
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.privateKeyOnly:Z
         3: .line 43
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
         4: .line 56
            aload 0 /* this */
            aload 1 /* pSpec */
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
         5: .line 57
            goto 8
         6: .line 58
      StackMap locals: org.bouncycastle.jce.provider.JCERSACipher javax.crypto.spec.OAEPParameterSpec
      StackMap stack: javax.crypto.NoSuchPaddingException
            astore 2 /* e */
        start local 2 // javax.crypto.NoSuchPaddingException e
         7: .line 60
            new java.lang.IllegalArgumentException
            dup
            aload 2 /* e */
            invokevirtual javax.crypto.NoSuchPaddingException.getMessage:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // javax.crypto.NoSuchPaddingException e
         8: .line 62
      StackMap locals:
      StackMap stack:
            return
        end local 1 // javax.crypto.spec.OAEPParameterSpec pSpec
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    9     0   this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    9     1  pSpec  Ljavax/crypto/spec/OAEPParameterSpec;
            7    8     2      e  Ljavax/crypto/NoSuchPaddingException;
      Exception table:
        from    to  target  type
           4     5       6  Class javax.crypto.NoSuchPaddingException
    MethodParameters:
       Name  Flags
      pSpec  

  public void <init>(boolean, boolean, org.bouncycastle.crypto.AsymmetricBlockCipher);
    descriptor: (ZZLorg/bouncycastle/crypto/AsymmetricBlockCipher;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // boolean publicKeyOnly
        start local 2 // boolean privateKeyOnly
        start local 3 // org.bouncycastle.crypto.AsymmetricBlockCipher engine
         0: .line 64
            aload 0 /* this */
            invokespecial org.bouncycastle.jce.provider.WrapCipherSpi.<init>:()V
         1: .line 41
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.publicKeyOnly:Z
         2: .line 42
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.privateKeyOnly:Z
         3: .line 43
            aload 0 /* this */
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            putfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
         4: .line 69
            aload 0 /* this */
            iload 1 /* publicKeyOnly */
            putfield org.bouncycastle.jce.provider.JCERSACipher.publicKeyOnly:Z
         5: .line 70
            aload 0 /* this */
            iload 2 /* privateKeyOnly */
            putfield org.bouncycastle.jce.provider.JCERSACipher.privateKeyOnly:Z
         6: .line 71
            aload 0 /* this */
            aload 3 /* engine */
            putfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
         7: .line 72
            return
        end local 3 // org.bouncycastle.crypto.AsymmetricBlockCipher engine
        end local 2 // boolean privateKeyOnly
        end local 1 // boolean publicKeyOnly
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    8     0            this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    8     1   publicKeyOnly  Z
            0    8     2  privateKeyOnly  Z
            0    8     3          engine  Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
    MethodParameters:
                Name  Flags
      publicKeyOnly   
      privateKeyOnly  
      engine          

  private void initFromSpec(javax.crypto.spec.OAEPParameterSpec);
    descriptor: (Ljavax/crypto/spec/OAEPParameterSpec;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=4, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // javax.crypto.spec.OAEPParameterSpec pSpec
         0: .line 78
            aload 1 /* pSpec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getMGFParameters:()Ljava/security/spec/AlgorithmParameterSpec;
            checkcast java.security.spec.MGF1ParameterSpec
            astore 2 /* mgfParams */
        start local 2 // java.security.spec.MGF1ParameterSpec mgfParams
         1: .line 79
            aload 2 /* mgfParams */
            invokevirtual java.security.spec.MGF1ParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            invokestatic org.bouncycastle.jce.provider.JCEDigestUtil.getDigest:(Ljava/lang/String;)Lorg/bouncycastle/crypto/Digest;
            astore 3 /* digest */
        start local 3 // org.bouncycastle.crypto.Digest digest
         2: .line 81
            aload 3 /* digest */
            ifnonnull 4
         3: .line 83
            new javax.crypto.NoSuchPaddingException
            dup
            new java.lang.StringBuilder
            dup
            ldc "no match on OAEP constructor for digest algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* mgfParams */
            invokevirtual java.security.spec.MGF1ParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 86
      StackMap locals: java.security.spec.MGF1ParameterSpec org.bouncycastle.crypto.Digest
      StackMap stack:
            aload 0 /* this */
            new org.bouncycastle.crypto.encodings.OAEPEncoding
            dup
            new org.bouncycastle.crypto.engines.RSABlindedEngine
            dup
            invokespecial org.bouncycastle.crypto.engines.RSABlindedEngine.<init>:()V
            aload 3 /* digest */
            aload 1 /* pSpec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getPSource:()Ljavax/crypto/spec/PSource;
            checkcast javax.crypto.spec.PSource$PSpecified
            invokevirtual javax.crypto.spec.PSource$PSpecified.getValue:()[B
            invokespecial org.bouncycastle.crypto.encodings.OAEPEncoding.<init>:(Lorg/bouncycastle/crypto/AsymmetricBlockCipher;Lorg/bouncycastle/crypto/Digest;[B)V
            putfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
         5: .line 87
            aload 0 /* this */
            aload 1 /* pSpec */
            putfield org.bouncycastle.jce.provider.JCERSACipher.paramSpec:Ljava/security/spec/AlgorithmParameterSpec;
         6: .line 88
            return
        end local 3 // org.bouncycastle.crypto.Digest digest
        end local 2 // java.security.spec.MGF1ParameterSpec mgfParams
        end local 1 // javax.crypto.spec.OAEPParameterSpec pSpec
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    7     1      pSpec  Ljavax/crypto/spec/OAEPParameterSpec;
            1    7     2  mgfParams  Ljava/security/spec/MGF1ParameterSpec;
            2    7     3     digest  Lorg/bouncycastle/crypto/Digest;
    Exceptions:
      throws javax.crypto.NoSuchPaddingException
    MethodParameters:
       Name  Flags
      pSpec  

  protected int engineGetBlockSize();
    descriptor: ()I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
         0: .line 94
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
         1: ireturn
         2: .line 96
      StackMap locals:
      StackMap stack: java.lang.NullPointerException
            pop
         3: .line 98
            new java.lang.IllegalStateException
            dup
            ldc "RSA Cipher not initialised"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JCERSACipher;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.NullPointerException

  protected byte[] engineGetIV();
    descriptor: ()[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
         0: .line 104
            aconst_null
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCERSACipher;

  protected int engineGetKeySize(java.security.Key);
    descriptor: (Ljava/security/Key;)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // java.security.Key key
         0: .line 110
            aload 1 /* key */
            instanceof java.security.interfaces.RSAPrivateKey
            ifeq 3
         1: .line 112
            aload 1 /* key */
            checkcast java.security.interfaces.RSAPrivateKey
            astore 2 /* k */
        start local 2 // java.security.interfaces.RSAPrivateKey k
         2: .line 114
            aload 2 /* k */
            invokeinterface java.security.interfaces.RSAPrivateKey.getModulus:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            ireturn
        end local 2 // java.security.interfaces.RSAPrivateKey k
         3: .line 116
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 6
         4: .line 118
            aload 1 /* key */
            checkcast java.security.interfaces.RSAPublicKey
            astore 2 /* k */
        start local 2 // java.security.interfaces.RSAPublicKey k
         5: .line 120
            aload 2 /* k */
            invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            ireturn
        end local 2 // java.security.interfaces.RSAPublicKey k
         6: .line 123
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            ldc "not an RSA key!"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.security.Key key
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    7     1   key  Ljava/security/Key;
            2    3     2     k  Ljava/security/interfaces/RSAPrivateKey;
            5    6     2     k  Ljava/security/interfaces/RSAPublicKey;
    MethodParameters:
      Name  Flags
      key   

  protected int engineGetOutputSize(int);
    descriptor: (I)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // int inputLen
         0: .line 131
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getOutputBlockSize:()I
         1: ireturn
         2: .line 133
      StackMap locals:
      StackMap stack: java.lang.NullPointerException
            pop
         3: .line 135
            new java.lang.IllegalStateException
            dup
            ldc "RSA Cipher not initialised"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // int inputLen
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    4     1  inputLen  I
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.NullPointerException
    MethodParameters:
          Name  Flags
      inputLen  

  protected java.security.AlgorithmParameters engineGetParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
         0: .line 141
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.engineParams:Ljava/security/AlgorithmParameters;
            ifnonnull 7
         1: .line 143
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.paramSpec:Ljava/security/spec/AlgorithmParameterSpec;
            ifnull 7
         2: .line 147
            aload 0 /* this */
            ldc "OAEP"
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            putfield org.bouncycastle.jce.provider.JCERSACipher.engineParams:Ljava/security/AlgorithmParameters;
         3: .line 148
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.engineParams:Ljava/security/AlgorithmParameters;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.paramSpec:Ljava/security/spec/AlgorithmParameterSpec;
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
         4: .line 149
            goto 7
         5: .line 150
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
         6: .line 152
            new java.lang.RuntimeException
            dup
            aload 1 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.Exception e
         7: .line 157
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.engineParams:Ljava/security/AlgorithmParameters;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            6    7     1     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2     4       5  Class java.lang.Exception

  protected void engineSetMode(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // java.lang.String mode
         0: .line 164
            aload 1 /* mode */
            invokestatic org.bouncycastle.util.Strings.toUpperCase:(Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* md */
        start local 2 // java.lang.String md
         1: .line 166
            aload 2 /* md */
            ldc "NONE"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 2
            aload 2 /* md */
            ldc "ECB"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 3
         2: .line 168
      StackMap locals: java.lang.String
      StackMap stack:
            return
         3: .line 171
      StackMap locals:
      StackMap stack:
            aload 2 /* md */
            ldc "1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 7
         4: .line 173
            aload 0 /* this */
            iconst_1
            putfield org.bouncycastle.jce.provider.JCERSACipher.privateKeyOnly:Z
         5: .line 174
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.publicKeyOnly:Z
         6: .line 175
            return
         7: .line 177
      StackMap locals:
      StackMap stack:
            aload 2 /* md */
            ldc "2"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 11
         8: .line 179
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.JCERSACipher.privateKeyOnly:Z
         9: .line 180
            aload 0 /* this */
            iconst_1
            putfield org.bouncycastle.jce.provider.JCERSACipher.publicKeyOnly:Z
        10: .line 181
            return
        11: .line 184
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "can't support mode "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* mode */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.String md
        end local 1 // java.lang.String mode
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0   12     1  mode  Ljava/lang/String;
            1   12     2    md  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
      Name  Flags
      mode  

  protected void engineSetPadding(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=8, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // java.lang.String padding
         0: .line 191
            aload 1 /* padding */
            invokestatic org.bouncycastle.util.Strings.toUpperCase:(Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* pad */
        start local 2 // java.lang.String pad
         1: .line 193
            aload 2 /* pad */
            ldc "NOPADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 4
         2: .line 195
            aload 0 /* this */
            new org.bouncycastle.crypto.engines.RSABlindedEngine
            dup
            invokespecial org.bouncycastle.crypto.engines.RSABlindedEngine.<init>:()V
            putfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
         3: .line 196
            goto 32
         4: .line 197
      StackMap locals: java.lang.String
      StackMap stack:
            aload 2 /* pad */
            ldc "PKCS1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 7
         5: .line 199
            aload 0 /* this */
            new org.bouncycastle.crypto.encodings.PKCS1Encoding
            dup
            new org.bouncycastle.crypto.engines.RSABlindedEngine
            dup
            invokespecial org.bouncycastle.crypto.engines.RSABlindedEngine.<init>:()V
            invokespecial org.bouncycastle.crypto.encodings.PKCS1Encoding.<init>:(Lorg/bouncycastle/crypto/AsymmetricBlockCipher;)V
            putfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
         6: .line 200
            goto 32
         7: .line 201
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "ISO9796-1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 10
         8: .line 203
            aload 0 /* this */
            new org.bouncycastle.crypto.encodings.ISO9796d1Encoding
            dup
            new org.bouncycastle.crypto.engines.RSABlindedEngine
            dup
            invokespecial org.bouncycastle.crypto.engines.RSABlindedEngine.<init>:()V
            invokespecial org.bouncycastle.crypto.encodings.ISO9796d1Encoding.<init>:(Lorg/bouncycastle/crypto/AsymmetricBlockCipher;)V
            putfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
         9: .line 204
            goto 32
        10: .line 205
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "OAEPWITHMD5ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 13
        11: .line 207
            aload 0 /* this */
            new javax.crypto.spec.OAEPParameterSpec
            dup
            ldc "MD5"
            ldc "MGF1"
            new java.security.spec.MGF1ParameterSpec
            dup
            ldc "MD5"
            invokespecial java.security.spec.MGF1ParameterSpec.<init>:(Ljava/lang/String;)V
            getstatic javax.crypto.spec.PSource$PSpecified.DEFAULT:Ljavax/crypto/spec/PSource$PSpecified;
            invokespecial javax.crypto.spec.OAEPParameterSpec.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/security/spec/AlgorithmParameterSpec;Ljavax/crypto/spec/PSource;)V
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
        12: .line 208
            goto 32
        13: .line 209
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "OAEPPADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 16
        14: .line 211
            aload 0 /* this */
            getstatic javax.crypto.spec.OAEPParameterSpec.DEFAULT:Ljavax/crypto/spec/OAEPParameterSpec;
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
        15: .line 212
            goto 32
        16: .line 213
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "OAEPWITHSHA1ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 17
            aload 2 /* pad */
            ldc "OAEPWITHSHA-1ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 19
        17: .line 215
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic javax.crypto.spec.OAEPParameterSpec.DEFAULT:Ljavax/crypto/spec/OAEPParameterSpec;
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
        18: .line 216
            goto 32
        19: .line 217
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "OAEPWITHSHA224ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 20
            aload 2 /* pad */
            ldc "OAEPWITHSHA-224ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 22
        20: .line 219
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new javax.crypto.spec.OAEPParameterSpec
            dup
            ldc "SHA-224"
            ldc "MGF1"
            new java.security.spec.MGF1ParameterSpec
            dup
            ldc "SHA-224"
            invokespecial java.security.spec.MGF1ParameterSpec.<init>:(Ljava/lang/String;)V
            getstatic javax.crypto.spec.PSource$PSpecified.DEFAULT:Ljavax/crypto/spec/PSource$PSpecified;
            invokespecial javax.crypto.spec.OAEPParameterSpec.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/security/spec/AlgorithmParameterSpec;Ljavax/crypto/spec/PSource;)V
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
        21: .line 220
            goto 32
        22: .line 221
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "OAEPWITHSHA256ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 23
            aload 2 /* pad */
            ldc "OAEPWITHSHA-256ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 25
        23: .line 223
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new javax.crypto.spec.OAEPParameterSpec
            dup
            ldc "SHA-256"
            ldc "MGF1"
            getstatic java.security.spec.MGF1ParameterSpec.SHA256:Ljava/security/spec/MGF1ParameterSpec;
            getstatic javax.crypto.spec.PSource$PSpecified.DEFAULT:Ljavax/crypto/spec/PSource$PSpecified;
            invokespecial javax.crypto.spec.OAEPParameterSpec.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/security/spec/AlgorithmParameterSpec;Ljavax/crypto/spec/PSource;)V
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
        24: .line 224
            goto 32
        25: .line 225
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "OAEPWITHSHA384ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 26
            aload 2 /* pad */
            ldc "OAEPWITHSHA-384ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 28
        26: .line 227
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new javax.crypto.spec.OAEPParameterSpec
            dup
            ldc "SHA-384"
            ldc "MGF1"
            getstatic java.security.spec.MGF1ParameterSpec.SHA384:Ljava/security/spec/MGF1ParameterSpec;
            getstatic javax.crypto.spec.PSource$PSpecified.DEFAULT:Ljavax/crypto/spec/PSource$PSpecified;
            invokespecial javax.crypto.spec.OAEPParameterSpec.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/security/spec/AlgorithmParameterSpec;Ljavax/crypto/spec/PSource;)V
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
        27: .line 228
            goto 32
        28: .line 229
      StackMap locals:
      StackMap stack:
            aload 2 /* pad */
            ldc "OAEPWITHSHA512ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 29
            aload 2 /* pad */
            ldc "OAEPWITHSHA-512ANDMGF1PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 31
        29: .line 231
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new javax.crypto.spec.OAEPParameterSpec
            dup
            ldc "SHA-512"
            ldc "MGF1"
            getstatic java.security.spec.MGF1ParameterSpec.SHA512:Ljava/security/spec/MGF1ParameterSpec;
            getstatic javax.crypto.spec.PSource$PSpecified.DEFAULT:Ljavax/crypto/spec/PSource$PSpecified;
            invokespecial javax.crypto.spec.OAEPParameterSpec.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/security/spec/AlgorithmParameterSpec;Ljavax/crypto/spec/PSource;)V
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.initFromSpec:(Ljavax/crypto/spec/OAEPParameterSpec;)V
        30: .line 232
            goto 32
        31: .line 235
      StackMap locals:
      StackMap stack:
            new javax.crypto.NoSuchPaddingException
            dup
            new java.lang.StringBuilder
            dup
            aload 1 /* padding */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " unavailable with RSA."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 237
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String pad
        end local 1 // java.lang.String padding
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   33     0     this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0   33     1  padding  Ljava/lang/String;
            1   33     2      pad  Ljava/lang/String;
    Exceptions:
      throws javax.crypto.NoSuchPaddingException
    MethodParameters:
         Name  Flags
      padding  

  protected void engineInit(int, java.security.Key, java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=7, locals=10, args_size=5
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.spec.AlgorithmParameterSpec params
        start local 4 // java.security.SecureRandom random
         0: .line 248
            aload 3 /* params */
            ifnull 1
            aload 3 /* params */
            instanceof javax.crypto.spec.OAEPParameterSpec
            ifeq 32
         1: .line 250
      StackMap locals:
      StackMap stack:
            aload 2 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 8
         2: .line 252
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.privateKeyOnly:Z
            ifeq 6
         3: .line 254
            new java.security.InvalidKeyException
            dup
         4: .line 255
            ldc "mode 1 requires RSAPrivateKey"
         5: .line 254
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 258
      StackMap locals:
      StackMap stack:
            aload 2 /* key */
            checkcast java.security.interfaces.RSAPublicKey
            invokestatic org.bouncycastle.jce.provider.RSAUtil.generatePublicKeyParameter:(Ljava/security/interfaces/RSAPublicKey;)Lorg/bouncycastle/crypto/params/RSAKeyParameters;
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
         7: .line 259
            goto 16
        end local 5 // org.bouncycastle.crypto.CipherParameters param
         8: .line 260
      StackMap locals:
      StackMap stack:
            aload 2 /* key */
            instanceof java.security.interfaces.RSAPrivateKey
            ifeq 15
         9: .line 262
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.publicKeyOnly:Z
            ifeq 13
        10: .line 264
            new java.security.InvalidKeyException
            dup
        11: .line 265
            ldc "mode 2 requires RSAPublicKey"
        12: .line 264
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 268
      StackMap locals:
      StackMap stack:
            aload 2 /* key */
            checkcast java.security.interfaces.RSAPrivateKey
            invokestatic org.bouncycastle.jce.provider.RSAUtil.generatePrivateKeyParameter:(Ljava/security/interfaces/RSAPrivateKey;)Lorg/bouncycastle/crypto/params/RSAKeyParameters;
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        14: .line 269
            goto 16
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        15: .line 272
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "unknown key type passed to RSA"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        16: .line 275
      StackMap locals: org.bouncycastle.crypto.CipherParameters
      StackMap stack:
            aload 3 /* params */
            ifnull 33
        17: .line 277
            aload 3 /* params */
            checkcast javax.crypto.spec.OAEPParameterSpec
            astore 6 /* spec */
        start local 6 // javax.crypto.spec.OAEPParameterSpec spec
        18: .line 279
            aload 0 /* this */
            aload 3 /* params */
            putfield org.bouncycastle.jce.provider.JCERSACipher.paramSpec:Ljava/security/spec/AlgorithmParameterSpec;
        19: .line 281
            aload 6 /* spec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getMGFAlgorithm:()Ljava/lang/String;
            ldc "MGF1"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 21
            aload 6 /* spec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getMGFAlgorithm:()Ljava/lang/String;
            getstatic org.bouncycastle.asn1.pkcs.PKCSObjectIdentifiers.id_mgf1:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.ASN1ObjectIdentifier.getId:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 21
        20: .line 283
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "unknown mask generation function specified"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 286
      StackMap locals: javax.crypto.spec.OAEPParameterSpec
      StackMap stack:
            aload 6 /* spec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getMGFParameters:()Ljava/security/spec/AlgorithmParameterSpec;
            instanceof java.security.spec.MGF1ParameterSpec
            ifne 23
        22: .line 288
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "unkown MGF parameters"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        23: .line 291
      StackMap locals:
      StackMap stack:
            aload 6 /* spec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            invokestatic org.bouncycastle.jce.provider.JCEDigestUtil.getDigest:(Ljava/lang/String;)Lorg/bouncycastle/crypto/Digest;
            astore 7 /* digest */
        start local 7 // org.bouncycastle.crypto.Digest digest
        24: .line 293
            aload 7 /* digest */
            ifnonnull 26
        25: .line 295
            new java.security.InvalidAlgorithmParameterException
            dup
            new java.lang.StringBuilder
            dup
            ldc "no match on digest algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* spec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        26: .line 298
      StackMap locals: org.bouncycastle.crypto.Digest
      StackMap stack:
            aload 6 /* spec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getMGFParameters:()Ljava/security/spec/AlgorithmParameterSpec;
            checkcast java.security.spec.MGF1ParameterSpec
            astore 8 /* mgfParams */
        start local 8 // java.security.spec.MGF1ParameterSpec mgfParams
        27: .line 299
            aload 8 /* mgfParams */
            invokevirtual java.security.spec.MGF1ParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            invokestatic org.bouncycastle.jce.provider.JCEDigestUtil.getDigest:(Ljava/lang/String;)Lorg/bouncycastle/crypto/Digest;
            astore 9 /* mgfDigest */
        start local 9 // org.bouncycastle.crypto.Digest mgfDigest
        28: .line 301
            aload 9 /* mgfDigest */
            ifnonnull 30
        29: .line 303
            new java.security.InvalidAlgorithmParameterException
            dup
            new java.lang.StringBuilder
            dup
            ldc "no match on MGF digest algorithm: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* mgfParams */
            invokevirtual java.security.spec.MGF1ParameterSpec.getDigestAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 306
      StackMap locals: java.security.spec.MGF1ParameterSpec org.bouncycastle.crypto.Digest
      StackMap stack:
            aload 0 /* this */
            new org.bouncycastle.crypto.encodings.OAEPEncoding
            dup
            new org.bouncycastle.crypto.engines.RSABlindedEngine
            dup
            invokespecial org.bouncycastle.crypto.engines.RSABlindedEngine.<init>:()V
            aload 7 /* digest */
            aload 9 /* mgfDigest */
            aload 6 /* spec */
            invokevirtual javax.crypto.spec.OAEPParameterSpec.getPSource:()Ljavax/crypto/spec/PSource;
            checkcast javax.crypto.spec.PSource$PSpecified
            invokevirtual javax.crypto.spec.PSource$PSpecified.getValue:()[B
            invokespecial org.bouncycastle.crypto.encodings.OAEPEncoding.<init>:(Lorg/bouncycastle/crypto/AsymmetricBlockCipher;Lorg/bouncycastle/crypto/Digest;Lorg/bouncycastle/crypto/Digest;[B)V
            putfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
        end local 9 // org.bouncycastle.crypto.Digest mgfDigest
        end local 8 // java.security.spec.MGF1ParameterSpec mgfParams
        end local 7 // org.bouncycastle.crypto.Digest digest
        end local 6 // javax.crypto.spec.OAEPParameterSpec spec
        31: .line 308
            goto 33
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        32: .line 311
      StackMap locals: org.bouncycastle.jce.provider.JCERSACipher int java.security.Key java.security.spec.AlgorithmParameterSpec java.security.SecureRandom
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            ldc "unknown parameter type."
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        33: .line 314
      StackMap locals: org.bouncycastle.crypto.CipherParameters
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            instanceof org.bouncycastle.crypto.engines.RSABlindedEngine
            ifne 38
        34: .line 316
            aload 4 /* random */
            ifnull 37
        35: .line 318
            new org.bouncycastle.crypto.params.ParametersWithRandom
            dup
            aload 5 /* param */
            aload 4 /* random */
            invokespecial org.bouncycastle.crypto.params.ParametersWithRandom.<init>:(Lorg/bouncycastle/crypto/CipherParameters;Ljava/security/SecureRandom;)V
            astore 5 /* param */
        36: .line 319
            goto 38
        37: .line 322
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.crypto.params.ParametersWithRandom
            dup
            aload 5 /* param */
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            invokespecial org.bouncycastle.crypto.params.ParametersWithRandom.<init>:(Lorg/bouncycastle/crypto/CipherParameters;Ljava/security/SecureRandom;)V
            astore 5 /* param */
        38: .line 326
      StackMap locals:
      StackMap stack:
            iload 1 /* opmode */
            tableswitch { // 1 - 4
                    1: 39
                    2: 41
                    3: 39
                    4: 41
              default: 43
          }
        39: .line 330
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            iconst_1
            aload 5 /* param */
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
        40: .line 331
            goto 44
        41: .line 334
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            iconst_0
            aload 5 /* param */
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
        42: .line 335
            goto 44
        43: .line 337
      StackMap locals:
      StackMap stack:
            new java.security.InvalidParameterException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unknown opmode "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 1 /* opmode */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " passed to RSA"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidParameterException.<init>:(Ljava/lang/String;)V
            athrow
        44: .line 339
      StackMap locals:
      StackMap stack:
            return
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        end local 4 // java.security.SecureRandom random
        end local 3 // java.security.spec.AlgorithmParameterSpec params
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   45     0       this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0   45     1     opmode  I
            0   45     2        key  Ljava/security/Key;
            0   45     3     params  Ljava/security/spec/AlgorithmParameterSpec;
            0   45     4     random  Ljava/security/SecureRandom;
            7    8     5      param  Lorg/bouncycastle/crypto/CipherParameters;
           14   15     5      param  Lorg/bouncycastle/crypto/CipherParameters;
           16   32     5      param  Lorg/bouncycastle/crypto/CipherParameters;
           33   45     5      param  Lorg/bouncycastle/crypto/CipherParameters;
           18   31     6       spec  Ljavax/crypto/spec/OAEPParameterSpec;
           24   31     7     digest  Lorg/bouncycastle/crypto/Digest;
           27   31     8  mgfParams  Ljava/security/spec/MGF1ParameterSpec;
           28   31     9  mgfDigest  Lorg/bouncycastle/crypto/Digest;
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  protected void engineInit(int, java.security.Key, java.security.AlgorithmParameters, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=7, args_size=5
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.AlgorithmParameters params
        start local 4 // java.security.SecureRandom random
         0: .line 348
            aconst_null
            astore 5 /* paramSpec */
        start local 5 // java.security.spec.AlgorithmParameterSpec paramSpec
         1: .line 350
            aload 3 /* params */
            ifnull 6
         2: .line 354
            aload 3 /* params */
            ldc Ljavax/crypto/spec/OAEPParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            astore 5 /* paramSpec */
         3: .line 355
            goto 6
         4: .line 356
      StackMap locals: org.bouncycastle.jce.provider.JCERSACipher int java.security.Key java.security.AlgorithmParameters java.security.SecureRandom java.security.spec.AlgorithmParameterSpec
      StackMap stack: java.security.spec.InvalidParameterSpecException
            astore 6 /* e */
        start local 6 // java.security.spec.InvalidParameterSpecException e
         5: .line 358
            new java.security.InvalidAlgorithmParameterException
            dup
            new java.lang.StringBuilder
            dup
            ldc "cannot recognise parameters: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* e */
            invokevirtual java.security.spec.InvalidParameterSpecException.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 6 /* e */
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.security.spec.InvalidParameterSpecException e
         6: .line 362
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* params */
            putfield org.bouncycastle.jce.provider.JCERSACipher.engineParams:Ljava/security/AlgorithmParameters;
         7: .line 363
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aload 5 /* paramSpec */
            aload 4 /* random */
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
         8: .line 364
            return
        end local 5 // java.security.spec.AlgorithmParameterSpec paramSpec
        end local 4 // java.security.SecureRandom random
        end local 3 // java.security.AlgorithmParameters params
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0       this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    9     1     opmode  I
            0    9     2        key  Ljava/security/Key;
            0    9     3     params  Ljava/security/AlgorithmParameters;
            0    9     4     random  Ljava/security/SecureRandom;
            1    9     5  paramSpec  Ljava/security/spec/AlgorithmParameterSpec;
            5    6     6          e  Ljava/security/spec/InvalidParameterSpecException;
      Exception table:
        from    to  target  type
           2     3       4  Class java.security.spec.InvalidParameterSpecException
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  protected void engineInit(int, java.security.Key, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.SecureRandom random
         0: .line 374
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aconst_null
            aload 3 /* random */
            invokevirtual org.bouncycastle.jce.provider.JCERSACipher.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
         1: .line 375
            goto 4
         2: .line 376
      StackMap locals:
      StackMap stack: java.security.InvalidAlgorithmParameterException
            astore 4 /* e */
        start local 4 // java.security.InvalidAlgorithmParameterException e
         3: .line 379
            new java.lang.RuntimeException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Eeeek! "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* e */
            invokevirtual java.security.InvalidAlgorithmParameterException.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 4 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.security.InvalidAlgorithmParameterException e
         4: .line 381
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.security.SecureRandom random
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    5     1  opmode  I
            0    5     2     key  Ljava/security/Key;
            0    5     3  random  Ljava/security/SecureRandom;
            3    4     4       e  Ljava/security/InvalidAlgorithmParameterException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.security.InvalidAlgorithmParameterException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      random  

  protected byte[] engineUpdate(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 388
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
         1: .line 390
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            instanceof org.bouncycastle.crypto.engines.RSABlindedEngine
            ifeq 4
         2: .line 392
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            iconst_1
            iadd
            if_icmple 6
         3: .line 394
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 399
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            if_icmple 6
         5: .line 401
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 405
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    7     1        input  [B
            0    7     2  inputOffset  I
            0    7     3     inputLen  I
    MethodParameters:
             Name  Flags
      input        
      inputOffset  
      inputLen     

  protected int engineUpdate(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=6, args_size=6
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
        start local 4 // byte[] output
        start local 5 // int outputOffset
         0: .line 415
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
         1: .line 417
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            instanceof org.bouncycastle.crypto.engines.RSABlindedEngine
            ifeq 4
         2: .line 419
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            iconst_1
            iadd
            if_icmple 6
         3: .line 421
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 426
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            if_icmple 6
         5: .line 428
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 432
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 5 // int outputOffset
        end local 4 // byte[] output
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    7     0          this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0    7     1         input  [B
            0    7     2   inputOffset  I
            0    7     3      inputLen  I
            0    7     4        output  [B
            0    7     5  outputOffset  I
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  

  protected byte[] engineDoFinal(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=5, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 441
            aload 1 /* input */
            ifnull 2
         1: .line 443
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
         2: .line 446
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            instanceof org.bouncycastle.crypto.engines.RSABlindedEngine
            ifeq 5
         3: .line 448
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            iconst_1
            iadd
            if_icmple 7
         4: .line 450
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 455
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            if_icmple 7
         6: .line 457
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 463
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            astore 4 /* bytes */
        start local 4 // byte[] bytes
         8: .line 465
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
         9: .line 467
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            aload 4 /* bytes */
            iconst_0
            aload 4 /* bytes */
            arraylength
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.processBlock:([BII)[B
        10: areturn
        end local 4 // byte[] bytes
        11: .line 469
      StackMap locals:
      StackMap stack: org.bouncycastle.crypto.InvalidCipherTextException
            astore 4 /* e */
        start local 4 // org.bouncycastle.crypto.InvalidCipherTextException e
        12: .line 471
            new javax.crypto.BadPaddingException
            dup
            aload 4 /* e */
            invokevirtual org.bouncycastle.crypto.InvalidCipherTextException.getMessage:()Ljava/lang/String;
            invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // org.bouncycastle.crypto.InvalidCipherTextException e
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   13     0         this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0   13     1        input  [B
            0   13     2  inputOffset  I
            0   13     3     inputLen  I
            8   11     4        bytes  [B
           12   13     4            e  Lorg/bouncycastle/crypto/InvalidCipherTextException;
      Exception table:
        from    to  target  type
           7    10      11  Class org.bouncycastle.crypto.InvalidCipherTextException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
             Name  Flags
      input        
      inputOffset  
      inputLen     

  protected int engineDoFinal(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=8, args_size=6
        start local 0 // org.bouncycastle.jce.provider.JCERSACipher this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
        start local 4 // byte[] output
        start local 5 // int outputOffset
         0: .line 483
            aload 1 /* input */
            ifnull 2
         1: .line 485
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
         2: .line 488
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            instanceof org.bouncycastle.crypto.engines.RSABlindedEngine
            ifeq 5
         3: .line 490
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            iconst_1
            iadd
            if_icmple 7
         4: .line 492
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 497
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.getInputBlockSize:()I
            if_icmple 7
         6: .line 499
            new java.lang.ArrayIndexOutOfBoundsException
            dup
            ldc "too much data for RSA block"
            invokespecial java.lang.ArrayIndexOutOfBoundsException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 507
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            astore 7 /* bytes */
        start local 7 // byte[] bytes
         8: .line 508
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.bOut:Ljava/io/ByteArrayOutputStream;
            invokevirtual java.io.ByteArrayOutputStream.reset:()V
         9: .line 510
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCERSACipher.cipher:Lorg/bouncycastle/crypto/AsymmetricBlockCipher;
            aload 7 /* bytes */
            iconst_0
            aload 7 /* bytes */
            arraylength
            invokeinterface org.bouncycastle.crypto.AsymmetricBlockCipher.processBlock:([BII)[B
            astore 6 /* out */
        end local 7 // byte[] bytes
        start local 6 // byte[] out
        10: .line 511
            goto 13
        end local 6 // byte[] out
        11: .line 512
      StackMap locals:
      StackMap stack: org.bouncycastle.crypto.InvalidCipherTextException
            astore 7 /* e */
        start local 7 // org.bouncycastle.crypto.InvalidCipherTextException e
        12: .line 514
            new javax.crypto.BadPaddingException
            dup
            aload 7 /* e */
            invokevirtual org.bouncycastle.crypto.InvalidCipherTextException.getMessage:()Ljava/lang/String;
            invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // org.bouncycastle.crypto.InvalidCipherTextException e
        start local 6 // byte[] out
        13: .line 517
      StackMap locals: byte[]
      StackMap stack:
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        14: goto 17
        15: .line 519
      StackMap locals: int
      StackMap stack:
            aload 4 /* output */
            iload 5 /* outputOffset */
            iload 7 /* i */
            iadd
            aload 6 /* out */
            iload 7 /* i */
            baload
            bastore
        16: .line 517
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        17: iload 7 /* i */
            aload 6 /* out */
            arraylength
            if_icmpne 15
        end local 7 // int i
        18: .line 522
            aload 6 /* out */
            arraylength
            ireturn
        end local 6 // byte[] out
        end local 5 // int outputOffset
        end local 4 // byte[] output
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // org.bouncycastle.jce.provider.JCERSACipher this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   19     0          this  Lorg/bouncycastle/jce/provider/JCERSACipher;
            0   19     1         input  [B
            0   19     2   inputOffset  I
            0   19     3      inputLen  I
            0   19     4        output  [B
            0   19     5  outputOffset  I
           10   11     6           out  [B
           13   19     6           out  [B
            8   10     7         bytes  [B
           12   13     7             e  Lorg/bouncycastle/crypto/InvalidCipherTextException;
           14   18     7             i  I
      Exception table:
        from    to  target  type
           7    10      11  Class org.bouncycastle.crypto.InvalidCipherTextException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  
}
SourceFile: "JCERSACipher.java"
NestMembers:
  org.bouncycastle.jce.provider.JCERSACipher$ISO9796d1Padding  org.bouncycastle.jce.provider.JCERSACipher$NoPadding  org.bouncycastle.jce.provider.JCERSACipher$OAEPPadding  org.bouncycastle.jce.provider.JCERSACipher$PKCS1v1_5Padding  org.bouncycastle.jce.provider.JCERSACipher$PKCS1v1_5Padding_PrivateOnly  org.bouncycastle.jce.provider.JCERSACipher$PKCS1v1_5Padding_PublicOnly
InnerClasses:
  public final PSpecified = javax.crypto.spec.PSource$PSpecified of javax.crypto.spec.PSource
  public ISO9796d1Padding = org.bouncycastle.jce.provider.JCERSACipher$ISO9796d1Padding of org.bouncycastle.jce.provider.JCERSACipher
  public NoPadding = org.bouncycastle.jce.provider.JCERSACipher$NoPadding of org.bouncycastle.jce.provider.JCERSACipher
  public OAEPPadding = org.bouncycastle.jce.provider.JCERSACipher$OAEPPadding of org.bouncycastle.jce.provider.JCERSACipher
  public PKCS1v1_5Padding = org.bouncycastle.jce.provider.JCERSACipher$PKCS1v1_5Padding of org.bouncycastle.jce.provider.JCERSACipher
  public PKCS1v1_5Padding_PrivateOnly = org.bouncycastle.jce.provider.JCERSACipher$PKCS1v1_5Padding_PrivateOnly of org.bouncycastle.jce.provider.JCERSACipher
  public PKCS1v1_5Padding_PublicOnly = org.bouncycastle.jce.provider.JCERSACipher$PKCS1v1_5Padding_PublicOnly of org.bouncycastle.jce.provider.JCERSACipher