public class org.bouncycastle.jce.provider.BrokenJCEBlockCipher implements org.bouncycastle.jce.provider.BrokenPBE
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.jce.provider.BrokenJCEBlockCipher
  super_class: java.lang.Object
{
  private java.lang.Class[] availableSpecs;
    descriptor: [Ljava/lang/Class;
    flags: (0x0002) ACC_PRIVATE

  private org.bouncycastle.crypto.BufferedBlockCipher cipher;
    descriptor: Lorg/bouncycastle/crypto/BufferedBlockCipher;
    flags: (0x0002) ACC_PRIVATE

  private org.bouncycastle.crypto.params.ParametersWithIV ivParam;
    descriptor: Lorg/bouncycastle/crypto/params/ParametersWithIV;
    flags: (0x0002) ACC_PRIVATE

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

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

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

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

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

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

  protected void <init>(org.bouncycastle.crypto.BlockCipher);
    descriptor: (Lorg/bouncycastle/crypto/BlockCipher;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // org.bouncycastle.crypto.BlockCipher engine
         0: .line 71
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 51
            aload 0 /* this */
         2: .line 52
            iconst_4
            anewarray java.lang.Class
            dup
            iconst_0
         3: .line 53
            ldc Ljavax/crypto/spec/IvParameterSpec;
            aastore
            dup
            iconst_1
         4: .line 54
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            aastore
            dup
            iconst_2
         5: .line 55
            ldc Ljavax/crypto/spec/RC2ParameterSpec;
            aastore
            dup
            iconst_3
         6: .line 56
            ldc Ljavax/crypto/spec/RC5ParameterSpec;
            aastore
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.availableSpecs:[Ljava/lang/Class;
         7: .line 62
            aload 0 /* this */
            iconst_2
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeType:I
         8: .line 63
            aload 0 /* this */
            iconst_1
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeHash:I
         9: .line 67
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
        10: .line 69
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineParams:Ljava/security/AlgorithmParameters;
        11: .line 74
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
            aload 1 /* engine */
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
        12: .line 75
            return
        end local 1 // org.bouncycastle.crypto.BlockCipher engine
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   13     0    this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   13     1  engine  Lorg/bouncycastle/crypto/BlockCipher;
    MethodParameters:
        Name  Flags
      engine  

  protected void <init>(org.bouncycastle.crypto.BlockCipher, int, int, int, int);
    descriptor: (Lorg/bouncycastle/crypto/BlockCipher;IIII)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=6, args_size=6
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // org.bouncycastle.crypto.BlockCipher engine
        start local 2 // int pbeType
        start local 3 // int pbeHash
        start local 4 // int pbeKeySize
        start local 5 // int pbeIvSize
         0: .line 77
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 51
            aload 0 /* this */
         2: .line 52
            iconst_4
            anewarray java.lang.Class
            dup
            iconst_0
         3: .line 53
            ldc Ljavax/crypto/spec/IvParameterSpec;
            aastore
            dup
            iconst_1
         4: .line 54
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            aastore
            dup
            iconst_2
         5: .line 55
            ldc Ljavax/crypto/spec/RC2ParameterSpec;
            aastore
            dup
            iconst_3
         6: .line 56
            ldc Ljavax/crypto/spec/RC5ParameterSpec;
            aastore
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.availableSpecs:[Ljava/lang/Class;
         7: .line 62
            aload 0 /* this */
            iconst_2
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeType:I
         8: .line 63
            aload 0 /* this */
            iconst_1
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeHash:I
         9: .line 67
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
        10: .line 69
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineParams:Ljava/security/AlgorithmParameters;
        11: .line 84
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
            aload 1 /* engine */
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
        12: .line 86
            aload 0 /* this */
            iload 2 /* pbeType */
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeType:I
        13: .line 87
            aload 0 /* this */
            iload 3 /* pbeHash */
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeHash:I
        14: .line 88
            aload 0 /* this */
            iload 4 /* pbeKeySize */
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeKeySize:I
        15: .line 89
            aload 0 /* this */
            iload 5 /* pbeIvSize */
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeIvSize:I
        16: .line 90
            return
        end local 5 // int pbeIvSize
        end local 4 // int pbeKeySize
        end local 3 // int pbeHash
        end local 2 // int pbeType
        end local 1 // org.bouncycastle.crypto.BlockCipher engine
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   17     0        this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   17     1      engine  Lorg/bouncycastle/crypto/BlockCipher;
            0   17     2     pbeType  I
            0   17     3     pbeHash  I
            0   17     4  pbeKeySize  I
            0   17     5   pbeIvSize  I
    MethodParameters:
            Name  Flags
      engine      
      pbeType     
      pbeHash     
      pbeKeySize  
      pbeIvSize   

  protected int engineGetBlockSize();
    descriptor: ()I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
         0: .line 94
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getBlockSize:()I
            ireturn
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;

  protected byte[] engineGetIV();
    descriptor: ()[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
         0: .line 99
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
            ifnull 1
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
            invokevirtual org.bouncycastle.crypto.params.ParametersWithIV.getIV:()[B
            goto 2
      StackMap locals:
      StackMap stack:
         1: aconst_null
      StackMap locals:
      StackMap stack: byte[]
         2: areturn
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;

  protected int engineGetKeySize(java.security.Key);
    descriptor: (Ljava/security/Key;)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // java.security.Key key
         0: .line 105
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            arraylength
            ireturn
        end local 1 // java.security.Key key
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0    1     1   key  Ljava/security/Key;
    MethodParameters:
      Name  Flags
      key   

  protected int engineGetOutputSize(int);
    descriptor: (I)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // int inputLen
         0: .line 111
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            iload 1 /* inputLen */
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getOutputSize:(I)I
            ireturn
        end local 1 // int inputLen
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0    1     1  inputLen  I
    MethodParameters:
          Name  Flags
      inputLen  

  protected java.security.AlgorithmParameters engineGetParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
         0: .line 116
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineParams:Ljava/security/AlgorithmParameters;
            ifnonnull 10
         1: .line 118
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
            ifnull 10
         2: .line 120
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokeinterface org.bouncycastle.crypto.BlockCipher.getAlgorithmName:()Ljava/lang/String;
            astore 1 /* name */
        start local 1 // java.lang.String name
         3: .line 122
            aload 1 /* name */
            bipush 47
            invokevirtual java.lang.String.indexOf:(I)I
            iflt 5
         4: .line 124
            aload 1 /* name */
            iconst_0
            aload 1 /* name */
            bipush 47
            invokevirtual java.lang.String.indexOf:(I)I
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 1 /* name */
         5: .line 129
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            aload 1 /* name */
            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.BrokenJCEBlockCipher.engineParams:Ljava/security/AlgorithmParameters;
         6: .line 130
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineParams:Ljava/security/AlgorithmParameters;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
            invokevirtual org.bouncycastle.crypto.params.ParametersWithIV.getIV:()[B
            invokevirtual java.security.AlgorithmParameters.init:([B)V
         7: .line 131
            goto 10
         8: .line 132
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 2 /* e */
        start local 2 // java.lang.Exception e
         9: .line 134
            new java.lang.RuntimeException
            dup
            aload 2 /* e */
            invokevirtual java.lang.Exception.toString:()Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // java.lang.Exception e
        end local 1 // java.lang.String name
        10: .line 139
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineParams:Ljava/security/AlgorithmParameters;
            areturn
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            3   10     1  name  Ljava/lang/String;
            9   10     2     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           5     7       8  Class java.lang.Exception

  protected void engineSetMode(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=8, locals=4, args_size=2
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // java.lang.String mode
         0: .line 145
            aload 1 /* mode */
            invokestatic org.bouncycastle.util.Strings.toUpperCase:(Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* modeName */
        start local 2 // java.lang.String modeName
         1: .line 147
            aload 2 /* modeName */
            ldc "ECB"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 5
         2: .line 149
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
         3: .line 150
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
         4: .line 151
            goto 36
         5: .line 152
      StackMap locals: java.lang.String
      StackMap stack:
            aload 2 /* modeName */
            ldc "CBC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 11
         6: .line 154
            aload 0 /* this */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokeinterface org.bouncycastle.crypto.BlockCipher.getBlockSize:()I
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
         7: .line 155
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
         8: .line 156
            new org.bouncycastle.crypto.modes.CBCBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokespecial org.bouncycastle.crypto.modes.CBCBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
         9: .line 155
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
        10: .line 157
            goto 36
        11: .line 158
      StackMap locals:
      StackMap stack:
            aload 2 /* modeName */
            ldc "OFB"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 23
        12: .line 160
            aload 0 /* this */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokeinterface org.bouncycastle.crypto.BlockCipher.getBlockSize:()I
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
        13: .line 161
            aload 2 /* modeName */
            invokevirtual java.lang.String.length:()I
            iconst_3
            if_icmpeq 19
        14: .line 163
            aload 2 /* modeName */
            iconst_3
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            istore 3 /* wordSize */
        start local 3 // int wordSize
        15: .line 165
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
        16: .line 166
            new org.bouncycastle.crypto.modes.OFBBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            iload 3 /* wordSize */
            invokespecial org.bouncycastle.crypto.modes.OFBBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;I)V
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
        17: .line 165
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
        end local 3 // int wordSize
        18: .line 167
            goto 36
        19: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
        20: .line 171
            new org.bouncycastle.crypto.modes.OFBBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            bipush 8
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getBlockSize:()I
            imul
            invokespecial org.bouncycastle.crypto.modes.OFBBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;I)V
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
        21: .line 170
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
        22: .line 173
            goto 36
        23: .line 174
      StackMap locals:
      StackMap stack:
            aload 2 /* modeName */
            ldc "CFB"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 35
        24: .line 176
            aload 0 /* this */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokeinterface org.bouncycastle.crypto.BlockCipher.getBlockSize:()I
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
        25: .line 177
            aload 2 /* modeName */
            invokevirtual java.lang.String.length:()I
            iconst_3
            if_icmpeq 31
        26: .line 179
            aload 2 /* modeName */
            iconst_3
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            istore 3 /* wordSize */
        start local 3 // int wordSize
        27: .line 181
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
        28: .line 182
            new org.bouncycastle.crypto.modes.CFBBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            iload 3 /* wordSize */
            invokespecial org.bouncycastle.crypto.modes.CFBBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;I)V
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
        29: .line 181
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
        end local 3 // int wordSize
        30: .line 183
            goto 36
        31: .line 186
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
        32: .line 187
            new org.bouncycastle.crypto.modes.CFBBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            bipush 8
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getBlockSize:()I
            imul
            invokespecial org.bouncycastle.crypto.modes.CFBBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;I)V
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
        33: .line 186
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
        34: .line 189
            goto 36
        35: .line 192
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            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.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        36: .line 194
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String modeName
        end local 1 // java.lang.String mode
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   37     0      this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   37     1      mode  Ljava/lang/String;
            1   37     2  modeName  Ljava/lang/String;
           15   18     3  wordSize  I
           27   30     3  wordSize  I
    MethodParameters:
      Name  Flags
      mode  

  protected void engineSetPadding(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.BrokenJCEBlockCipher this
        start local 1 // java.lang.String padding
         0: .line 200
            aload 1 /* padding */
            invokestatic org.bouncycastle.util.Strings.toUpperCase:(Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* paddingName */
        start local 2 // java.lang.String paddingName
         1: .line 202
            aload 2 /* paddingName */
            ldc "NOPADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 4
         2: .line 204
            aload 0 /* this */
            new org.bouncycastle.crypto.BufferedBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokespecial org.bouncycastle.crypto.BufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
         3: .line 205
            goto 11
         4: .line 206
      StackMap locals: java.lang.String
      StackMap stack:
            aload 2 /* paddingName */
            ldc "PKCS5PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 5
            aload 2 /* paddingName */
            ldc "PKCS7PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 5
            aload 2 /* paddingName */
            ldc "ISO10126PADDING"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 7
         5: .line 208
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokespecial org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
         6: .line 209
            goto 11
         7: .line 210
      StackMap locals:
      StackMap stack:
            aload 2 /* paddingName */
            ldc "WITHCTS"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 10
         8: .line 212
            aload 0 /* this */
            new org.bouncycastle.crypto.modes.CTSBlockCipher
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokespecial org.bouncycastle.crypto.modes.CTSBlockCipher.<init>:(Lorg/bouncycastle/crypto/BlockCipher;)V
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
         9: .line 213
            goto 11
        10: .line 216
      StackMap locals:
      StackMap stack:
            new javax.crypto.NoSuchPaddingException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Padding "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* padding */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " unknown."
            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
        11: .line 218
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String paddingName
        end local 1 // java.lang.String padding
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   12     0         this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   12     1      padding  Ljava/lang/String;
            1   12     2  paddingName  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=7, args_size=5
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher 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 232
            aload 2 /* key */
            instanceof org.bouncycastle.jce.provider.JCEPBEKey
            ifeq 7
         1: .line 234
            aload 2 /* key */
            checkcast org.bouncycastle.jce.provider.JCEPBEKey
            aload 3 /* params */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeType:I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeHash:I
         2: .line 235
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokeinterface org.bouncycastle.crypto.BlockCipher.getAlgorithmName:()Ljava/lang/String;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeKeySize:I
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeIvSize:I
         3: .line 234
            invokestatic org.bouncycastle.jce.provider.BrokenPBE$Util.makePBEParameters:(Lorg/bouncycastle/jce/provider/JCEPBEKey;Ljava/security/spec/AlgorithmParameterSpec;IILjava/lang/String;II)Lorg/bouncycastle/crypto/CipherParameters;
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
         4: .line 237
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.pbeIvSize:I
            ifeq 34
         5: .line 239
            aload 0 /* this */
            aload 5 /* param */
            checkcast org.bouncycastle.crypto.params.ParametersWithIV
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
         6: .line 241
            goto 34
        end local 5 // org.bouncycastle.crypto.CipherParameters param
         7: .line 242
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            ifnonnull 10
         8: .line 244
            new org.bouncycastle.crypto.params.KeyParameter
            dup
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            invokespecial org.bouncycastle.crypto.params.KeyParameter.<init>:([B)V
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
         9: .line 245
            goto 34
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        10: .line 246
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            instanceof javax.crypto.spec.IvParameterSpec
            ifeq 17
        11: .line 248
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
            ifeq 15
        12: .line 250
            new org.bouncycastle.crypto.params.ParametersWithIV
            dup
            new org.bouncycastle.crypto.params.KeyParameter
            dup
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            invokespecial org.bouncycastle.crypto.params.KeyParameter.<init>:([B)V
            aload 3 /* params */
            checkcast javax.crypto.spec.IvParameterSpec
            invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
            invokespecial org.bouncycastle.crypto.params.ParametersWithIV.<init>:(Lorg/bouncycastle/crypto/CipherParameters;[B)V
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        13: .line 251
            aload 0 /* this */
            aload 5 /* param */
            checkcast org.bouncycastle.crypto.params.ParametersWithIV
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
        14: .line 252
            goto 34
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        15: .line 255
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.crypto.params.KeyParameter
            dup
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            invokespecial org.bouncycastle.crypto.params.KeyParameter.<init>:([B)V
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        16: .line 257
            goto 34
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        17: .line 258
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            instanceof javax.crypto.spec.RC2ParameterSpec
            ifeq 24
        18: .line 260
            aload 3 /* params */
            checkcast javax.crypto.spec.RC2ParameterSpec
            astore 6 /* rc2Param */
        start local 6 // javax.crypto.spec.RC2ParameterSpec rc2Param
        19: .line 262
            new org.bouncycastle.crypto.params.RC2Parameters
            dup
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            aload 3 /* params */
            checkcast javax.crypto.spec.RC2ParameterSpec
            invokevirtual javax.crypto.spec.RC2ParameterSpec.getEffectiveKeyBits:()I
            invokespecial org.bouncycastle.crypto.params.RC2Parameters.<init>:([BI)V
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        20: .line 264
            aload 6 /* rc2Param */
            invokevirtual javax.crypto.spec.RC2ParameterSpec.getIV:()[B
            ifnull 34
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
            ifeq 34
        21: .line 266
            new org.bouncycastle.crypto.params.ParametersWithIV
            dup
            aload 5 /* param */
            aload 6 /* rc2Param */
            invokevirtual javax.crypto.spec.RC2ParameterSpec.getIV:()[B
            invokespecial org.bouncycastle.crypto.params.ParametersWithIV.<init>:(Lorg/bouncycastle/crypto/CipherParameters;[B)V
            astore 5 /* param */
        22: .line 267
            aload 0 /* this */
            aload 5 /* param */
            checkcast org.bouncycastle.crypto.params.ParametersWithIV
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
        end local 6 // javax.crypto.spec.RC2ParameterSpec rc2Param
        23: .line 269
            goto 34
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        24: .line 270
      StackMap locals:
      StackMap stack:
            aload 3 /* params */
            instanceof javax.crypto.spec.RC5ParameterSpec
            ifeq 33
        25: .line 272
            aload 3 /* params */
            checkcast javax.crypto.spec.RC5ParameterSpec
            astore 6 /* rc5Param */
        start local 6 // javax.crypto.spec.RC5ParameterSpec rc5Param
        26: .line 274
            new org.bouncycastle.crypto.params.RC5Parameters
            dup
            aload 2 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            aload 3 /* params */
            checkcast javax.crypto.spec.RC5ParameterSpec
            invokevirtual javax.crypto.spec.RC5ParameterSpec.getRounds:()I
            invokespecial org.bouncycastle.crypto.params.RC5Parameters.<init>:([BI)V
            astore 5 /* param */
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        27: .line 275
            aload 6 /* rc5Param */
            invokevirtual javax.crypto.spec.RC5ParameterSpec.getWordSize:()I
            bipush 32
            if_icmpeq 29
        28: .line 277
            new java.lang.IllegalArgumentException
            dup
            ldc "can only accept RC5 word size 32 (at the moment...)"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        29: .line 279
      StackMap locals: org.bouncycastle.crypto.CipherParameters javax.crypto.spec.RC5ParameterSpec
      StackMap stack:
            aload 6 /* rc5Param */
            invokevirtual javax.crypto.spec.RC5ParameterSpec.getIV:()[B
            ifnull 34
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
            ifeq 34
        30: .line 281
            new org.bouncycastle.crypto.params.ParametersWithIV
            dup
            aload 5 /* param */
            aload 6 /* rc5Param */
            invokevirtual javax.crypto.spec.RC5ParameterSpec.getIV:()[B
            invokespecial org.bouncycastle.crypto.params.ParametersWithIV.<init>:(Lorg/bouncycastle/crypto/CipherParameters;[B)V
            astore 5 /* param */
        31: .line 282
            aload 0 /* this */
            aload 5 /* param */
            checkcast org.bouncycastle.crypto.params.ParametersWithIV
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
        end local 6 // javax.crypto.spec.RC5ParameterSpec rc5Param
        32: .line 284
            goto 34
        end local 5 // org.bouncycastle.crypto.CipherParameters param
        33: .line 287
      StackMap locals:
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "unknown parameter type."
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        start local 5 // org.bouncycastle.crypto.CipherParameters param
        34: .line 290
      StackMap locals: org.bouncycastle.crypto.CipherParameters
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
            ifeq 44
            aload 5 /* param */
            instanceof org.bouncycastle.crypto.params.ParametersWithIV
            ifne 44
        35: .line 292
            aload 4 /* random */
            ifnonnull 37
        36: .line 294
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            astore 4 /* random */
        37: .line 297
      StackMap locals:
      StackMap stack:
            iload 1 /* opmode */
            iconst_1
            if_icmpeq 38
            iload 1 /* opmode */
            iconst_3
            if_icmpne 43
        38: .line 299
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivLength:I
            newarray 8
            astore 6 /* iv */
        start local 6 // byte[] iv
        39: .line 301
            aload 4 /* random */
            aload 6 /* iv */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
        40: .line 302
            new org.bouncycastle.crypto.params.ParametersWithIV
            dup
            aload 5 /* param */
            aload 6 /* iv */
            invokespecial org.bouncycastle.crypto.params.ParametersWithIV.<init>:(Lorg/bouncycastle/crypto/CipherParameters;[B)V
            astore 5 /* param */
        41: .line 303
            aload 0 /* this */
            aload 5 /* param */
            checkcast org.bouncycastle.crypto.params.ParametersWithIV
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.ivParam:Lorg/bouncycastle/crypto/params/ParametersWithIV;
        end local 6 // byte[] iv
        42: .line 304
            goto 44
        43: .line 307
      StackMap locals:
      StackMap stack:
            new java.security.InvalidAlgorithmParameterException
            dup
            ldc "no IV set when one expected"
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        44: .line 311
      StackMap locals:
      StackMap stack:
            iload 1 /* opmode */
            tableswitch { // 1 - 4
                    1: 45
                    2: 47
                    3: 45
                    4: 47
              default: 49
          }
        45: .line 315
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            iconst_1
            aload 5 /* param */
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
        46: .line 316
            goto 50
        47: .line 319
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            iconst_0
            aload 5 /* param */
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
        48: .line 320
            goto 50
        49: .line 322
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "eeek!"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        50: .line 324
      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.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   51     0      this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   51     1    opmode  I
            0   51     2       key  Ljava/security/Key;
            0   51     3    params  Ljava/security/spec/AlgorithmParameterSpec;
            0   51     4    random  Ljava/security/SecureRandom;
            4    7     5     param  Lorg/bouncycastle/crypto/CipherParameters;
            9   10     5     param  Lorg/bouncycastle/crypto/CipherParameters;
           13   15     5     param  Lorg/bouncycastle/crypto/CipherParameters;
           16   17     5     param  Lorg/bouncycastle/crypto/CipherParameters;
           20   24     5     param  Lorg/bouncycastle/crypto/CipherParameters;
           27   33     5     param  Lorg/bouncycastle/crypto/CipherParameters;
           34   51     5     param  Lorg/bouncycastle/crypto/CipherParameters;
           19   23     6  rc2Param  Ljavax/crypto/spec/RC2ParameterSpec;
           26   32     6  rc5Param  Ljavax/crypto/spec/RC5ParameterSpec;
           39   42     6        iv  [B
    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.BrokenJCEBlockCipher 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 333
            aconst_null
            astore 5 /* paramSpec */
        start local 5 // java.security.spec.AlgorithmParameterSpec paramSpec
         1: .line 335
            aload 3 /* params */
            ifnull 11
         2: .line 337
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         3: goto 8
         4: .line 341
      StackMap locals: java.security.spec.AlgorithmParameterSpec int
      StackMap stack:
            aload 3 /* params */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.availableSpecs:[Ljava/lang/Class;
            iload 6 /* i */
            aaload
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            astore 5 /* paramSpec */
         5: .line 342
            goto 9
         6: .line 344
      StackMap locals:
      StackMap stack: java.lang.Exception
            pop
         7: .line 337
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 6 /* i */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.availableSpecs:[Ljava/lang/Class;
            arraylength
            if_icmpne 4
        end local 6 // int i
         9: .line 350
      StackMap locals:
      StackMap stack:
            aload 5 /* paramSpec */
            ifnonnull 11
        10: .line 352
            new java.security.InvalidAlgorithmParameterException
            dup
            new java.lang.StringBuilder
            dup
            ldc "can't handle parameter "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* params */
            invokevirtual java.security.AlgorithmParameters.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 356
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* params */
            putfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineParams:Ljava/security/AlgorithmParameters;
        12: .line 357
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aload 5 /* paramSpec */
            aload 4 /* random */
            invokevirtual org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
        13: .line 358
            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.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   14     0       this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   14     1     opmode  I
            0   14     2        key  Ljava/security/Key;
            0   14     3     params  Ljava/security/AlgorithmParameters;
            0   14     4     random  Ljava/security/SecureRandom;
            1   14     5  paramSpec  Ljava/security/spec/AlgorithmParameterSpec;
            3    9     6          i  I
      Exception table:
        from    to  target  type
           4     5       6  Class java.lang.Exception
    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.BrokenJCEBlockCipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.SecureRandom random
         0: .line 368
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            aconst_null
            aload 3 /* random */
            invokevirtual org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
         1: .line 369
            goto 4
         2: .line 370
      StackMap locals:
      StackMap stack: java.security.InvalidAlgorithmParameterException
            astore 4 /* e */
        start local 4 // java.security.InvalidAlgorithmParameterException e
         3: .line 372
            new java.lang.IllegalArgumentException
            dup
            aload 4 /* e */
            invokevirtual java.security.InvalidAlgorithmParameterException.getMessage:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.InvalidAlgorithmParameterException e
         4: .line 374
      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.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            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=6, locals=6, args_size=4
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 381
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            iload 3 /* inputLen */
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.getUpdateOutputSize:(I)I
            istore 4 /* length */
        start local 4 // int length
         1: .line 383
            iload 4 /* length */
            ifle 5
         2: .line 385
            iload 4 /* length */
            newarray 8
            astore 5 /* out */
        start local 5 // byte[] out
         3: .line 387
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 5 /* out */
            iconst_0
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.processBytes:([BII[BI)I
            pop
         4: .line 388
            aload 5 /* out */
            areturn
        end local 5 // byte[] out
         5: .line 391
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aconst_null
            iconst_0
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.processBytes:([BII[BI)I
            pop
         6: .line 393
            aconst_null
            areturn
        end local 4 // int length
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0    7     1        input  [B
            0    7     2  inputOffset  I
            0    7     3     inputLen  I
            1    7     4       length  I
            3    5     5          out  [B
    MethodParameters:
             Name  Flags
      input        
      inputOffset  
      inputLen     

  protected int engineUpdate(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=6, args_size=6
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher 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 403
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 4 /* output */
            iload 5 /* outputOffset */
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.processBytes:([BII[BI)I
            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.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0    1     1         input  [B
            0    1     2   inputOffset  I
            0    1     3      inputLen  I
            0    1     4        output  [B
            0    1     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=6, locals=7, args_size=4
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // byte[] input
        start local 2 // int inputOffset
        start local 3 // int inputLen
         0: .line 412
            iconst_0
            istore 4 /* len */
        start local 4 // int len
         1: .line 413
            aload 0 /* this */
            iload 3 /* inputLen */
            invokevirtual org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineGetOutputSize:(I)I
            newarray 8
            astore 5 /* tmp */
        start local 5 // byte[] tmp
         2: .line 415
            iload 3 /* inputLen */
            ifeq 4
         3: .line 417
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 5 /* tmp */
            iconst_0
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.processBytes:([BII[BI)I
            istore 4 /* len */
         4: .line 422
      StackMap locals: int byte[]
      StackMap stack:
            iload 4 /* len */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            aload 5 /* tmp */
            iload 4 /* len */
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.doFinal:([BI)I
            iadd
            istore 4 /* len */
         5: .line 423
            goto 10
         6: .line 424
      StackMap locals:
      StackMap stack: org.bouncycastle.crypto.DataLengthException
            astore 6 /* e */
        start local 6 // org.bouncycastle.crypto.DataLengthException e
         7: .line 426
            new javax.crypto.IllegalBlockSizeException
            dup
            aload 6 /* e */
            invokevirtual org.bouncycastle.crypto.DataLengthException.getMessage:()Ljava/lang/String;
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 6 // org.bouncycastle.crypto.DataLengthException e
         8: .line 428
      StackMap locals:
      StackMap stack: org.bouncycastle.crypto.InvalidCipherTextException
            astore 6 /* e */
        start local 6 // org.bouncycastle.crypto.InvalidCipherTextException e
         9: .line 430
            new javax.crypto.BadPaddingException
            dup
            aload 6 /* e */
            invokevirtual org.bouncycastle.crypto.InvalidCipherTextException.getMessage:()Ljava/lang/String;
            invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
            athrow
        end local 6 // org.bouncycastle.crypto.InvalidCipherTextException e
        10: .line 433
      StackMap locals:
      StackMap stack:
            iload 4 /* len */
            newarray 8
            astore 6 /* out */
        start local 6 // byte[] out
        11: .line 435
            aload 5 /* tmp */
            iconst_0
            aload 6 /* out */
            iconst_0
            iload 4 /* len */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        12: .line 437
            aload 6 /* out */
            areturn
        end local 6 // byte[] out
        end local 5 // byte[] tmp
        end local 4 // int len
        end local 3 // int inputLen
        end local 2 // int inputOffset
        end local 1 // byte[] input
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   13     0         this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   13     1        input  [B
            0   13     2  inputOffset  I
            0   13     3     inputLen  I
            1   13     4          len  I
            2   13     5          tmp  [B
            7    8     6            e  Lorg/bouncycastle/crypto/DataLengthException;
            9   10     6            e  Lorg/bouncycastle/crypto/InvalidCipherTextException;
           11   13     6          out  [B
      Exception table:
        from    to  target  type
           4     5       6  Class org.bouncycastle.crypto.DataLengthException
           4     5       8  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=6, locals=8, args_size=6
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher 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 448
            iconst_0
            istore 6 /* len */
        start local 6 // int len
         1: .line 450
            iload 3 /* inputLen */
            ifeq 3
         2: .line 452
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            aload 1 /* input */
            iload 2 /* inputOffset */
            iload 3 /* inputLen */
            aload 4 /* output */
            iload 5 /* outputOffset */
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.processBytes:([BII[BI)I
            istore 6 /* len */
         3: .line 457
      StackMap locals: int
      StackMap stack:
            iload 6 /* len */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.BrokenJCEBlockCipher.cipher:Lorg/bouncycastle/crypto/BufferedBlockCipher;
            aload 4 /* output */
            iload 5 /* outputOffset */
            iload 6 /* len */
            iadd
            invokevirtual org.bouncycastle.crypto.BufferedBlockCipher.doFinal:([BI)I
            iadd
         4: ireturn
         5: .line 459
      StackMap locals:
      StackMap stack: org.bouncycastle.crypto.DataLengthException
            astore 7 /* e */
        start local 7 // org.bouncycastle.crypto.DataLengthException e
         6: .line 461
            new javax.crypto.IllegalBlockSizeException
            dup
            aload 7 /* e */
            invokevirtual org.bouncycastle.crypto.DataLengthException.getMessage:()Ljava/lang/String;
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // org.bouncycastle.crypto.DataLengthException e
         7: .line 463
      StackMap locals:
      StackMap stack: org.bouncycastle.crypto.InvalidCipherTextException
            astore 7 /* e */
        start local 7 // org.bouncycastle.crypto.InvalidCipherTextException e
         8: .line 465
            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
        end local 6 // int len
        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.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    9     0          this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0    9     1         input  [B
            0    9     2   inputOffset  I
            0    9     3      inputLen  I
            0    9     4        output  [B
            0    9     5  outputOffset  I
            1    9     6           len  I
            6    7     7             e  Lorg/bouncycastle/crypto/DataLengthException;
            8    9     7             e  Lorg/bouncycastle/crypto/InvalidCipherTextException;
      Exception table:
        from    to  target  type
           3     4       5  Class org.bouncycastle.crypto.DataLengthException
           3     4       7  Class org.bouncycastle.crypto.InvalidCipherTextException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, javax.crypto.BadPaddingException
    MethodParameters:
              Name  Flags
      input         
      inputOffset   
      inputLen      
      output        
      outputOffset  

  protected byte[] engineWrap(java.security.Key);
    descriptor: (Ljava/security/Key;)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // java.security.Key key
         0: .line 473
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 2 /* encoded */
        start local 2 // byte[] encoded
         1: .line 474
            aload 2 /* encoded */
            ifnonnull 3
         2: .line 476
            new java.security.InvalidKeyException
            dup
            ldc "Cannot wrap key, null encoding."
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 481
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            aload 2 /* encoded */
            iconst_0
            aload 2 /* encoded */
            arraylength
            invokevirtual org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineDoFinal:([BII)[B
         4: areturn
         5: .line 483
      StackMap locals:
      StackMap stack: javax.crypto.BadPaddingException
            astore 3 /* e */
        start local 3 // javax.crypto.BadPaddingException e
         6: .line 485
            new javax.crypto.IllegalBlockSizeException
            dup
            aload 3 /* e */
            invokevirtual javax.crypto.BadPaddingException.getMessage:()Ljava/lang/String;
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // javax.crypto.BadPaddingException e
        end local 2 // byte[] encoded
        end local 1 // java.security.Key key
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0    7     1      key  Ljava/security/Key;
            1    7     2  encoded  [B
            6    7     3        e  Ljavax/crypto/BadPaddingException;
      Exception table:
        from    to  target  type
           3     4       5  Class javax.crypto.BadPaddingException
    Exceptions:
      throws javax.crypto.IllegalBlockSizeException, java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  protected java.security.Key engineUnwrap(byte[], java.lang.String, int);
    descriptor: ([BLjava/lang/String;I)Ljava/security/Key;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
        start local 1 // byte[] wrappedKey
        start local 2 // java.lang.String wrappedKeyAlgorithm
        start local 3 // int wrappedKeyType
         0: .line 495
            aconst_null
            astore 4 /* encoded */
        start local 4 // byte[] encoded
         1: .line 498
            aload 0 /* this */
            aload 1 /* wrappedKey */
            iconst_0
            aload 1 /* wrappedKey */
            arraylength
            invokevirtual org.bouncycastle.jce.provider.BrokenJCEBlockCipher.engineDoFinal:([BII)[B
            astore 4 /* encoded */
         2: .line 499
            goto 7
         3: .line 500
      StackMap locals: org.bouncycastle.jce.provider.BrokenJCEBlockCipher byte[] java.lang.String int byte[]
      StackMap stack: javax.crypto.BadPaddingException
            astore 5 /* e */
        start local 5 // javax.crypto.BadPaddingException e
         4: .line 502
            new java.security.InvalidKeyException
            dup
            aload 5 /* e */
            invokevirtual javax.crypto.BadPaddingException.getMessage:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // javax.crypto.BadPaddingException e
         5: .line 504
      StackMap locals:
      StackMap stack: javax.crypto.IllegalBlockSizeException
            astore 5 /* e2 */
        start local 5 // javax.crypto.IllegalBlockSizeException e2
         6: .line 506
            new java.security.InvalidKeyException
            dup
            aload 5 /* e2 */
            invokevirtual javax.crypto.IllegalBlockSizeException.getMessage:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // javax.crypto.IllegalBlockSizeException e2
         7: .line 509
      StackMap locals:
      StackMap stack:
            iload 3 /* wrappedKeyType */
            iconst_3
            if_icmpne 9
         8: .line 511
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 4 /* encoded */
            aload 2 /* wrappedKeyAlgorithm */
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
            areturn
         9: .line 517
      StackMap locals:
      StackMap stack:
            aload 2 /* wrappedKeyAlgorithm */
            getstatic org.bouncycastle.jce.provider.BouncyCastleProvider.PROVIDER_NAME:Ljava/lang/String;
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 5 /* kf */
        start local 5 // java.security.KeyFactory kf
        10: .line 519
            iload 3 /* wrappedKeyType */
            iconst_1
            if_icmpne 13
        11: .line 521
            aload 5 /* kf */
            new java.security.spec.X509EncodedKeySpec
            dup
            aload 4 /* encoded */
            invokespecial java.security.spec.X509EncodedKeySpec.<init>:([B)V
            invokevirtual java.security.KeyFactory.generatePublic:(Ljava/security/spec/KeySpec;)Ljava/security/PublicKey;
        12: areturn
        13: .line 523
      StackMap locals: java.security.KeyFactory
      StackMap stack:
            iload 3 /* wrappedKeyType */
            iconst_2
            if_icmpne 22
        14: .line 525
            aload 5 /* kf */
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 4 /* encoded */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
        15: areturn
        end local 5 // java.security.KeyFactory kf
        16: .line 528
      StackMap locals: org.bouncycastle.jce.provider.BrokenJCEBlockCipher byte[] java.lang.String int byte[]
      StackMap stack: java.security.NoSuchProviderException
            astore 5 /* e */
        start local 5 // java.security.NoSuchProviderException e
        17: .line 530
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown key type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* e */
            invokevirtual java.security.NoSuchProviderException.getMessage:()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.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.security.NoSuchProviderException e
        18: .line 532
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 5 /* e */
        start local 5 // java.security.NoSuchAlgorithmException e
        19: .line 534
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown key type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* e */
            invokevirtual java.security.NoSuchAlgorithmException.getMessage:()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.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.security.NoSuchAlgorithmException e
        20: .line 536
      StackMap locals:
      StackMap stack: java.security.spec.InvalidKeySpecException
            astore 5 /* e2 */
        start local 5 // java.security.spec.InvalidKeySpecException e2
        21: .line 538
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown key type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* e2 */
            invokevirtual java.security.spec.InvalidKeySpecException.getMessage:()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.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 5 // java.security.spec.InvalidKeySpecException e2
        22: .line 541
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown key type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 3 /* wrappedKeyType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // byte[] encoded
        end local 3 // int wrappedKeyType
        end local 2 // java.lang.String wrappedKeyAlgorithm
        end local 1 // byte[] wrappedKey
        end local 0 // org.bouncycastle.jce.provider.BrokenJCEBlockCipher this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   23     0                 this  Lorg/bouncycastle/jce/provider/BrokenJCEBlockCipher;
            0   23     1           wrappedKey  [B
            0   23     2  wrappedKeyAlgorithm  Ljava/lang/String;
            0   23     3       wrappedKeyType  I
            1   23     4              encoded  [B
            4    5     5                    e  Ljavax/crypto/BadPaddingException;
            6    7     5                   e2  Ljavax/crypto/IllegalBlockSizeException;
           10   16     5                   kf  Ljava/security/KeyFactory;
           17   18     5                    e  Ljava/security/NoSuchProviderException;
           19   20     5                    e  Ljava/security/NoSuchAlgorithmException;
           21   22     5                   e2  Ljava/security/spec/InvalidKeySpecException;
      Exception table:
        from    to  target  type
           1     2       3  Class javax.crypto.BadPaddingException
           1     2       5  Class javax.crypto.IllegalBlockSizeException
           9    12      16  Class java.security.NoSuchProviderException
          13    15      16  Class java.security.NoSuchProviderException
           9    12      18  Class java.security.NoSuchAlgorithmException
          13    15      18  Class java.security.NoSuchAlgorithmException
           9    12      20  Class java.security.spec.InvalidKeySpecException
          13    15      20  Class java.security.spec.InvalidKeySpecException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
                     Name  Flags
      wrappedKey           
      wrappedKeyAlgorithm  
      wrappedKeyType       
}
SourceFile: "BrokenJCEBlockCipher.java"
NestMembers:
  org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithMD5AndDES  org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithSHA1AndDES  org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithSHAAndDES2Key  org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithSHAAndDES3Key  org.bouncycastle.jce.provider.BrokenJCEBlockCipher$OldPBEWithSHAAndDES3Key  org.bouncycastle.jce.provider.BrokenJCEBlockCipher$OldPBEWithSHAAndTwofish
InnerClasses:
  public BrokePBEWithMD5AndDES = org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithMD5AndDES of org.bouncycastle.jce.provider.BrokenJCEBlockCipher
  public BrokePBEWithSHA1AndDES = org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithSHA1AndDES of org.bouncycastle.jce.provider.BrokenJCEBlockCipher
  public BrokePBEWithSHAAndDES2Key = org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithSHAAndDES2Key of org.bouncycastle.jce.provider.BrokenJCEBlockCipher
  public BrokePBEWithSHAAndDES3Key = org.bouncycastle.jce.provider.BrokenJCEBlockCipher$BrokePBEWithSHAAndDES3Key of org.bouncycastle.jce.provider.BrokenJCEBlockCipher
  public OldPBEWithSHAAndDES3Key = org.bouncycastle.jce.provider.BrokenJCEBlockCipher$OldPBEWithSHAAndDES3Key of org.bouncycastle.jce.provider.BrokenJCEBlockCipher
  public OldPBEWithSHAAndTwofish = org.bouncycastle.jce.provider.BrokenJCEBlockCipher$OldPBEWithSHAAndTwofish of org.bouncycastle.jce.provider.BrokenJCEBlockCipher
  public Util = org.bouncycastle.jce.provider.BrokenPBE$Util of org.bouncycastle.jce.provider.BrokenPBE