class org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher implements org.bouncycastle.jce.provider.JCEBlockCipher$GenericBlockCipher
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher
  super_class: java.lang.Object
{
  private org.bouncycastle.crypto.modes.AEADBlockCipher cipher;
    descriptor: Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
    flags: (0x0002) ACC_PRIVATE

  void <init>(org.bouncycastle.crypto.modes.AEADBlockCipher);
    descriptor: (Lorg/bouncycastle/crypto/modes/AEADBlockCipher;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
        start local 1 // org.bouncycastle.crypto.modes.AEADBlockCipher cipher
         0: .line 1019
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 1021
            aload 0 /* this */
            aload 1 /* cipher */
            putfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
         2: .line 1022
            return
        end local 1 // org.bouncycastle.crypto.modes.AEADBlockCipher cipher
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;
            0    3     1  cipher  Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
    MethodParameters:
        Name  Flags
      cipher  

  public void init(boolean, org.bouncycastle.crypto.CipherParameters);
    descriptor: (ZLorg/bouncycastle/crypto/CipherParameters;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
        start local 1 // boolean forEncryption
        start local 2 // org.bouncycastle.crypto.CipherParameters params
         0: .line 1027
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            iload 1 /* forEncryption */
            aload 2 /* params */
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.init:(ZLorg/bouncycastle/crypto/CipherParameters;)V
         1: .line 1028
            return
        end local 2 // org.bouncycastle.crypto.CipherParameters params
        end local 1 // boolean forEncryption
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    2     0           this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;
            0    2     1  forEncryption  Z
            0    2     2         params  Lorg/bouncycastle/crypto/CipherParameters;
    Exceptions:
      throws java.lang.IllegalArgumentException
    MethodParameters:
               Name  Flags
      forEncryption  
      params         

  public java.lang.String getAlgorithmName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
         0: .line 1032
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            invokeinterface org.bouncycastle.crypto.BlockCipher.getAlgorithmName:()Ljava/lang/String;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;

  public boolean wrapOnNoPadding();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
         0: .line 1037
            iconst_0
            ireturn
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;

  public org.bouncycastle.crypto.BlockCipher getUnderlyingCipher();
    descriptor: ()Lorg/bouncycastle/crypto/BlockCipher;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
         0: .line 1042
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.getUnderlyingCipher:()Lorg/bouncycastle/crypto/BlockCipher;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;

  public int getOutputSize(int);
    descriptor: (I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
        start local 1 // int len
         0: .line 1047
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            iload 1 /* len */
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.getOutputSize:(I)I
            ireturn
        end local 1 // int len
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;
            0    1     1   len  I
    MethodParameters:
      Name  Flags
      len   

  public int getUpdateOutputSize(int);
    descriptor: (I)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
        start local 1 // int len
         0: .line 1052
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            iload 1 /* len */
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.getUpdateOutputSize:(I)I
            ireturn
        end local 1 // int len
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;
            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=4, locals=4, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
        start local 1 // byte in
        start local 2 // byte[] out
        start local 3 // int outOff
         0: .line 1057
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            iload 1 /* in */
            aload 2 /* out */
            iload 3 /* outOff */
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.processByte:(B[BI)I
            ireturn
        end local 3 // int outOff
        end local 2 // byte[] out
        end local 1 // byte in
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;
            0    1     1      in  B
            0    1     2     out  [B
            0    1     3  outOff  I
    Exceptions:
      throws org.bouncycastle.crypto.DataLengthException
    MethodParameters:
        Name  Flags
      in      
      out     
      outOff  

  public int processBytes(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=6
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher 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 1062
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            aload 1 /* in */
            iload 2 /* inOff */
            iload 3 /* len */
            aload 4 /* out */
            iload 5 /* outOff */
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.processBytes:([BII[BI)I
            ireturn
        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.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;
            0    1     1      in  [B
            0    1     2   inOff  I
            0    1     3     len  I
            0    1     4     out  [B
            0    1     5  outOff  I
    Exceptions:
      throws org.bouncycastle.crypto.DataLengthException
    MethodParameters:
        Name  Flags
      in      
      inOff   
      len     
      out     
      outOff  

  public int doFinal(byte[], int);
    descriptor: ([BI)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
        start local 1 // byte[] out
        start local 2 // int outOff
         0: .line 1067
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher.cipher:Lorg/bouncycastle/crypto/modes/AEADBlockCipher;
            aload 1 /* out */
            iload 2 /* outOff */
            invokeinterface org.bouncycastle.crypto.modes.AEADBlockCipher.doFinal:([BI)I
            ireturn
        end local 2 // int outOff
        end local 1 // byte[] out
        end local 0 // org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/bouncycastle/jce/provider/JCEBlockCipher$AEADGenericBlockCipher;
            0    1     1     out  [B
            0    1     2  outOff  I
    Exceptions:
      throws java.lang.IllegalStateException, org.bouncycastle.crypto.InvalidCipherTextException
    MethodParameters:
        Name  Flags
      out     
      outOff  
}
SourceFile: "JCEBlockCipher.java"
NestHost: org.bouncycastle.jce.provider.JCEBlockCipher
InnerClasses:
  private AEADGenericBlockCipher = org.bouncycastle.jce.provider.JCEBlockCipher$AEADGenericBlockCipher of org.bouncycastle.jce.provider.JCEBlockCipher
  private abstract GenericBlockCipher = org.bouncycastle.jce.provider.JCEBlockCipher$GenericBlockCipher of org.bouncycastle.jce.provider.JCEBlockCipher