public class org.bouncycastle.crypto.modes.CTSBlockCipher extends org.bouncycastle.crypto.BufferedBlockCipher
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.crypto.modes.CTSBlockCipher
  super_class: org.bouncycastle.crypto.BufferedBlockCipher
{
  private int blockSize;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  public void <init>(org.bouncycastle.crypto.BlockCipher);
    descriptor: (Lorg/bouncycastle/crypto/BlockCipher;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
        start local 1 // org.bouncycastle.crypto.BlockCipher cipher
         0: .line 22
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.BufferedBlockCipher.<init>:()V
         1: .line 25
            aload 1 /* cipher */
            instanceof org.bouncycastle.crypto.modes.OFBBlockCipher
            ifne 2
            aload 1 /* cipher */
            instanceof org.bouncycastle.crypto.modes.CFBBlockCipher
            ifeq 3
         2: .line 27
      StackMap locals: org.bouncycastle.crypto.modes.CTSBlockCipher org.bouncycastle.crypto.BlockCipher
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            ldc "CTSBlockCipher can only accept ECB, or CBC ciphers"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 30
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* cipher */
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
         4: .line 32
            aload 0 /* this */
            aload 1 /* cipher */
            invokeinterface org.bouncycastle.crypto.BlockCipher.getBlockSize:()I
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.blockSize:I
         5: .line 34
            aload 0 /* this */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.blockSize:I
            iconst_2
            imul
            newarray 8
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
         6: .line 35
            aload 0 /* this */
            iconst_0
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
         7: .line 36
            return
        end local 1 // org.bouncycastle.crypto.BlockCipher cipher
        end local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    this  Lorg/bouncycastle/crypto/modes/CTSBlockCipher;
            0    8     1  cipher  Lorg/bouncycastle/crypto/BlockCipher;
    MethodParameters:
        Name  Flags
      cipher  

  public int getUpdateOutputSize(int);
    descriptor: (I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
        start local 1 // int len
         0: .line 49
            iload 1 /* len */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iadd
            istore 2 /* total */
        start local 2 // int total
         1: .line 50
            iload 2 /* total */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            arraylength
            irem
            istore 3 /* leftOver */
        start local 3 // int leftOver
         2: .line 52
            iload 3 /* leftOver */
            ifne 4
         3: .line 54
            iload 2 /* total */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            arraylength
            isub
            ireturn
         4: .line 57
      StackMap locals: int int
      StackMap stack:
            iload 2 /* total */
            iload 3 /* leftOver */
            isub
            ireturn
        end local 3 // int leftOver
        end local 2 // int total
        end local 1 // int len
        end local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lorg/bouncycastle/crypto/modes/CTSBlockCipher;
            0    5     1       len  I
            1    5     2     total  I
            2    5     3  leftOver  I
    MethodParameters:
      Name  Flags
      len   

  public int getOutputSize(int);
    descriptor: (I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
        start local 1 // int len
         0: .line 71
            iload 1 /* len */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iadd
            ireturn
        end local 1 // int len
        end local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/modes/CTSBlockCipher;
            0    1     1   len  I
    MethodParameters:
      Name  Flags
      len   

  public int processByte(byte, byte[], int);
    descriptor: (B[BI)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
        start local 1 // byte in
        start local 2 // byte[] out
        start local 3 // int outOff
         0: .line 90
            iconst_0
            istore 4 /* resultLen */
        start local 4 // int resultLen
         1: .line 92
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            arraylength
            if_icmpne 5
         2: .line 94
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            aload 2 /* out */
            iload 3 /* outOff */
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            istore 4 /* resultLen */
         3: .line 95
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.blockSize:I
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.blockSize:I
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         4: .line 97
            aload 0 /* this */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.blockSize:I
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
         5: .line 100
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            aload 0 /* this */
            dup
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            dup_x1
            iconst_1
            iadd
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 1 /* in */
            bastore
         6: .line 102
            iload 4 /* resultLen */
            ireturn
        end local 4 // int resultLen
        end local 3 // int outOff
        end local 2 // byte[] out
        end local 1 // byte in
        end local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lorg/bouncycastle/crypto/modes/CTSBlockCipher;
            0    7     1         in  B
            0    7     2        out  [B
            0    7     3     outOff  I
            1    7     4  resultLen  I
    Exceptions:
      throws org.bouncycastle.crypto.DataLengthException, java.lang.IllegalStateException
    MethodParameters:
        Name  Flags
      in      
      out     
      outOff  

  public int processBytes(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=10, args_size=6
        start local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
        start local 1 // byte[] in
        start local 2 // int inOff
        start local 3 // int len
        start local 4 // byte[] out
        start local 5 // int outOff
         0: .line 125
            iload 3 /* len */
            ifge 2
         1: .line 127
            new java.lang.IllegalArgumentException
            dup
            ldc "Can't have a negative input length!"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 130
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.modes.CTSBlockCipher.getBlockSize:()I
            istore 6 /* blockSize */
        start local 6 // int blockSize
         3: .line 131
            aload 0 /* this */
            iload 3 /* len */
            invokevirtual org.bouncycastle.crypto.modes.CTSBlockCipher.getUpdateOutputSize:(I)I
            istore 7 /* length */
        start local 7 // int length
         4: .line 133
            iload 7 /* length */
            ifle 7
         5: .line 135
            iload 5 /* outOff */
            iload 7 /* length */
            iadd
            aload 4 /* out */
            arraylength
            if_icmple 7
         6: .line 137
            new org.bouncycastle.crypto.DataLengthException
            dup
            ldc "output buffer too short"
            invokespecial org.bouncycastle.crypto.DataLengthException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 141
      StackMap locals: int int
      StackMap stack:
            iconst_0
            istore 8 /* resultLen */
        start local 8 // int resultLen
         8: .line 142
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            arraylength
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            isub
            istore 9 /* gapLen */
        start local 9 // int gapLen
         9: .line 144
            iload 3 /* len */
            iload 9 /* gapLen */
            if_icmple 23
        10: .line 146
            aload 1 /* in */
            iload 2 /* inOff */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 9 /* gapLen */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        11: .line 148
            iload 8 /* resultLen */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            aload 4 /* out */
            iload 5 /* outOff */
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            iadd
            istore 8 /* resultLen */
        12: .line 149
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 6 /* blockSize */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            iload 6 /* blockSize */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        13: .line 151
            aload 0 /* this */
            iload 6 /* blockSize */
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
        14: .line 153
            iload 3 /* len */
            iload 9 /* gapLen */
            isub
            istore 3 /* len */
        15: .line 154
            iload 2 /* inOff */
            iload 9 /* gapLen */
            iadd
            istore 2 /* inOff */
        16: .line 156
            goto 22
        17: .line 158
      StackMap locals: int int
      StackMap stack:
            aload 1 /* in */
            iload 2 /* inOff */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 6 /* blockSize */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        18: .line 159
            iload 8 /* resultLen */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            aload 4 /* out */
            iload 5 /* outOff */
            iload 8 /* resultLen */
            iadd
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            iadd
            istore 8 /* resultLen */
        19: .line 160
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 6 /* blockSize */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            iload 6 /* blockSize */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        20: .line 162
            iload 3 /* len */
            iload 6 /* blockSize */
            isub
            istore 3 /* len */
        21: .line 163
            iload 2 /* inOff */
            iload 6 /* blockSize */
            iadd
            istore 2 /* inOff */
        22: .line 156
      StackMap locals:
      StackMap stack:
            iload 3 /* len */
            iload 6 /* blockSize */
            if_icmpgt 17
        23: .line 167
      StackMap locals:
      StackMap stack:
            aload 1 /* in */
            iload 2 /* inOff */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 3 /* len */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        24: .line 169
            aload 0 /* this */
            dup
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 3 /* len */
            iadd
            putfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
        25: .line 171
            iload 8 /* resultLen */
            ireturn
        end local 9 // int gapLen
        end local 8 // int resultLen
        end local 7 // int length
        end local 6 // int blockSize
        end local 5 // int outOff
        end local 4 // byte[] out
        end local 3 // int len
        end local 2 // int inOff
        end local 1 // byte[] in
        end local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   26     0       this  Lorg/bouncycastle/crypto/modes/CTSBlockCipher;
            0   26     1         in  [B
            0   26     2      inOff  I
            0   26     3        len  I
            0   26     4        out  [B
            0   26     5     outOff  I
            3   26     6  blockSize  I
            4   26     7     length  I
            8   26     8  resultLen  I
            9   26     9     gapLen  I
    Exceptions:
      throws org.bouncycastle.crypto.DataLengthException, java.lang.IllegalStateException
    MethodParameters:
        Name  Flags
      in      
      inOff   
      len     
      out     
      outOff  

  public int doFinal(byte[], int);
    descriptor: ([BI)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=8, args_size=3
        start local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
        start local 1 // byte[] out
        start local 2 // int outOff
         0: .line 192
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 2 /* outOff */
            iadd
            aload 1 /* out */
            arraylength
            if_icmple 2
         1: .line 194
            new org.bouncycastle.crypto.DataLengthException
            dup
            ldc "output buffer to small in doFinal"
            invokespecial org.bouncycastle.crypto.DataLengthException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 197
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            invokeinterface org.bouncycastle.crypto.BlockCipher.getBlockSize:()I
            istore 3 /* blockSize */
        start local 3 // int blockSize
         3: .line 198
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 3 /* blockSize */
            isub
            istore 4 /* len */
        start local 4 // int len
         4: .line 199
            iload 3 /* blockSize */
            newarray 8
            astore 5 /* block */
        start local 5 // byte[] block
         5: .line 201
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.forEncryption:Z
            ifeq 26
         6: .line 203
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            aload 5 /* block */
            iconst_0
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            pop
         7: .line 205
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            iload 3 /* blockSize */
            if_icmpge 9
         8: .line 207
            new org.bouncycastle.crypto.DataLengthException
            dup
            ldc "need at least one block of input for CTS"
            invokespecial org.bouncycastle.crypto.DataLengthException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 210
      StackMap locals: int int byte[]
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            istore 6 /* i */
        start local 6 // int i
        10: goto 13
        11: .line 212
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 6 /* i */
            aload 5 /* block */
            iload 6 /* i */
            iload 3 /* blockSize */
            isub
            baload
            bastore
        12: .line 210
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 6 /* i */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            arraylength
            if_icmpne 11
        end local 6 // int i
        14: .line 215
            iload 3 /* blockSize */
            istore 6 /* i */
        start local 6 // int i
        15: goto 18
        16: .line 217
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 6 /* i */
            dup2
            baload
            aload 5 /* block */
            iload 6 /* i */
            iload 3 /* blockSize */
            isub
            baload
            ixor
            i2b
            bastore
        17: .line 215
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        18: iload 6 /* i */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            if_icmpne 16
        end local 6 // int i
        19: .line 220
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            instanceof org.bouncycastle.crypto.modes.CBCBlockCipher
            ifeq 23
        20: .line 222
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            checkcast org.bouncycastle.crypto.modes.CBCBlockCipher
            invokevirtual org.bouncycastle.crypto.modes.CBCBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            astore 6 /* c */
        start local 6 // org.bouncycastle.crypto.BlockCipher c
        21: .line 224
            aload 6 /* c */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 3 /* blockSize */
            aload 1 /* out */
            iload 2 /* outOff */
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            pop
        end local 6 // org.bouncycastle.crypto.BlockCipher c
        22: .line 225
            goto 24
        23: .line 228
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 3 /* blockSize */
            aload 1 /* out */
            iload 2 /* outOff */
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            pop
        24: .line 231
      StackMap locals:
      StackMap stack:
            aload 5 /* block */
            iconst_0
            aload 1 /* out */
            iload 2 /* outOff */
            iload 3 /* blockSize */
            iadd
            iload 4 /* len */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        25: .line 232
            goto 40
        26: .line 235
      StackMap locals:
      StackMap stack:
            iload 3 /* blockSize */
            newarray 8
            astore 6 /* lastBlock */
        start local 6 // byte[] lastBlock
        27: .line 237
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            instanceof org.bouncycastle.crypto.modes.CBCBlockCipher
            ifeq 31
        28: .line 239
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            checkcast org.bouncycastle.crypto.modes.CBCBlockCipher
            invokevirtual org.bouncycastle.crypto.modes.CBCBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            astore 7 /* c */
        start local 7 // org.bouncycastle.crypto.BlockCipher c
        29: .line 241
            aload 7 /* c */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            aload 5 /* block */
            iconst_0
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            pop
        end local 7 // org.bouncycastle.crypto.BlockCipher c
        30: .line 242
            goto 32
        31: .line 245
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iconst_0
            aload 5 /* block */
            iconst_0
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            pop
        32: .line 248
      StackMap locals:
      StackMap stack:
            iload 3 /* blockSize */
            istore 7 /* i */
        start local 7 // int i
        33: goto 36
        34: .line 250
      StackMap locals: int
      StackMap stack:
            aload 6 /* lastBlock */
            iload 7 /* i */
            iload 3 /* blockSize */
            isub
            aload 5 /* block */
            iload 7 /* i */
            iload 3 /* blockSize */
            isub
            baload
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 7 /* i */
            baload
            ixor
            i2b
            bastore
        35: .line 248
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        36: iload 7 /* i */
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            if_icmpne 34
        end local 7 // int i
        37: .line 253
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.buf:[B
            iload 3 /* blockSize */
            aload 5 /* block */
            iconst_0
            iload 4 /* len */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        38: .line 255
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.cipher:Lorg/bouncycastle/crypto/BlockCipher;
            aload 5 /* block */
            iconst_0
            aload 1 /* out */
            iload 2 /* outOff */
            invokeinterface org.bouncycastle.crypto.BlockCipher.processBlock:([BI[BI)I
            pop
        39: .line 256
            aload 6 /* lastBlock */
            iconst_0
            aload 1 /* out */
            iload 2 /* outOff */
            iload 3 /* blockSize */
            iadd
            iload 4 /* len */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        end local 6 // byte[] lastBlock
        40: .line 259
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.crypto.modes.CTSBlockCipher.bufOff:I
            istore 6 /* offset */
        start local 6 // int offset
        41: .line 261
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.modes.CTSBlockCipher.reset:()V
        42: .line 263
            iload 6 /* offset */
            ireturn
        end local 6 // int offset
        end local 5 // byte[] block
        end local 4 // int len
        end local 3 // int blockSize
        end local 2 // int outOff
        end local 1 // byte[] out
        end local 0 // org.bouncycastle.crypto.modes.CTSBlockCipher this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   43     0       this  Lorg/bouncycastle/crypto/modes/CTSBlockCipher;
            0   43     1        out  [B
            0   43     2     outOff  I
            3   43     3  blockSize  I
            4   43     4        len  I
            5   43     5      block  [B
           10   14     6          i  I
           15   19     6          i  I
           21   22     6          c  Lorg/bouncycastle/crypto/BlockCipher;
           27   40     6  lastBlock  [B
           29   30     7          c  Lorg/bouncycastle/crypto/BlockCipher;
           33   37     7          i  I
           41   43     6     offset  I
    Exceptions:
      throws org.bouncycastle.crypto.DataLengthException, java.lang.IllegalStateException, org.bouncycastle.crypto.InvalidCipherTextException
    MethodParameters:
        Name  Flags
      out     
      outOff  
}
SourceFile: "CTSBlockCipher.java"