public class org.bouncycastle.crypto.digests.SHA384Digest extends org.bouncycastle.crypto.digests.LongDigest
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.crypto.digests.SHA384Digest
  super_class: org.bouncycastle.crypto.digests.LongDigest
{
  private static final int DIGEST_LENGTH;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 48

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
         0: .line 26
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.<init>:()V
         1: .line 28
            return
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/bouncycastle/crypto/digests/SHA384Digest;

  public void <init>(org.bouncycastle.crypto.digests.SHA384Digest);
    descriptor: (Lorg/bouncycastle/crypto/digests/SHA384Digest;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
        start local 1 // org.bouncycastle.crypto.digests.SHA384Digest t
         0: .line 36
            aload 0 /* this */
            aload 1 /* t */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.<init>:(Lorg/bouncycastle/crypto/digests/LongDigest;)V
         1: .line 37
            return
        end local 1 // org.bouncycastle.crypto.digests.SHA384Digest t
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/bouncycastle/crypto/digests/SHA384Digest;
            0    2     1     t  Lorg/bouncycastle/crypto/digests/SHA384Digest;
    MethodParameters:
      Name  Flags
      t     

  public void <init>(byte[]);
    descriptor: ([B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
        start local 1 // byte[] encodedState
         0: .line 44
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.<init>:()V
         1: .line 46
            aload 0 /* this */
            aload 1 /* encodedState */
            invokevirtual org.bouncycastle.crypto.digests.SHA384Digest.restoreState:([B)V
         2: .line 47
            return
        end local 1 // byte[] encodedState
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    3     0          this  Lorg/bouncycastle/crypto/digests/SHA384Digest;
            0    3     1  encodedState  [B
    MethodParameters:
              Name  Flags
      encodedState  

  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.crypto.digests.SHA384Digest this
         0: .line 51
            ldc "SHA-384"
            areturn
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/digests/SHA384Digest;

  public int getDigestSize();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
         0: .line 56
            bipush 48
            ireturn
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/digests/SHA384Digest;

  public int doFinal(byte[], int);
    descriptor: ([BI)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
        start local 1 // byte[] out
        start local 2 // int outOff
         0: .line 63
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.digests.SHA384Digest.finish:()V
         1: .line 65
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA384Digest.H1:J
            aload 1 /* out */
            iload 2 /* outOff */
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         2: .line 66
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA384Digest.H2:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 8
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         3: .line 67
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA384Digest.H3:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 16
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         4: .line 68
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA384Digest.H4:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 24
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         5: .line 69
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA384Digest.H5:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 32
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         6: .line 70
            aload 0 /* this */
            getfield org.bouncycastle.crypto.digests.SHA384Digest.H6:J
            aload 1 /* out */
            iload 2 /* outOff */
            bipush 40
            iadd
            invokestatic org.bouncycastle.util.Pack.longToBigEndian:(J[BI)V
         7: .line 72
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.digests.SHA384Digest.reset:()V
         8: .line 74
            bipush 48
            ireturn
        end local 2 // int outOff
        end local 1 // byte[] out
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lorg/bouncycastle/crypto/digests/SHA384Digest;
            0    9     1     out  [B
            0    9     2  outOff  I
    MethodParameters:
        Name  Flags
      out     
      outOff  

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
         0: .line 82
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.reset:()V
         1: .line 88
            aload 0 /* this */
            ldc -3766243637369397544
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H1:J
         2: .line 89
            aload 0 /* this */
            ldc 7105036623409894663
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H2:J
         3: .line 90
            aload 0 /* this */
            ldc -7973340178411365097
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H3:J
         4: .line 91
            aload 0 /* this */
            ldc 1526699215303891257
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H4:J
         5: .line 92
            aload 0 /* this */
            ldc 7436329637833083697
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H5:J
         6: .line 93
            aload 0 /* this */
            ldc -8163818279084223215
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H6:J
         7: .line 94
            aload 0 /* this */
            ldc -2662702644619276377
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H7:J
         8: .line 95
            aload 0 /* this */
            ldc 5167115440072839076
            putfield org.bouncycastle.crypto.digests.SHA384Digest.H8:J
         9: .line 96
            return
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lorg/bouncycastle/crypto/digests/SHA384Digest;

  public org.bouncycastle.util.Memoable copy();
    descriptor: ()Lorg/bouncycastle/util/Memoable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
         0: .line 100
            new org.bouncycastle.crypto.digests.SHA384Digest
            dup
            aload 0 /* this */
            invokespecial org.bouncycastle.crypto.digests.SHA384Digest.<init>:(Lorg/bouncycastle/crypto/digests/SHA384Digest;)V
            areturn
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/digests/SHA384Digest;

  public void reset(org.bouncycastle.util.Memoable);
    descriptor: (Lorg/bouncycastle/util/Memoable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
        start local 1 // org.bouncycastle.util.Memoable other
         0: .line 105
            aload 1 /* other */
            checkcast org.bouncycastle.crypto.digests.SHA384Digest
            astore 2 /* d */
        start local 2 // org.bouncycastle.crypto.digests.SHA384Digest d
         1: .line 107
            aload 0 /* this */
            aload 2 /* d */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.copyIn:(Lorg/bouncycastle/crypto/digests/LongDigest;)V
         2: .line 108
            return
        end local 2 // org.bouncycastle.crypto.digests.SHA384Digest d
        end local 1 // org.bouncycastle.util.Memoable other
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lorg/bouncycastle/crypto/digests/SHA384Digest;
            0    3     1  other  Lorg/bouncycastle/util/Memoable;
            1    3     2      d  Lorg/bouncycastle/crypto/digests/SHA384Digest;
    MethodParameters:
       Name  Flags
      other  

  public byte[] getEncodedState();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
         0: .line 112
            aload 0 /* this */
            invokevirtual org.bouncycastle.crypto.digests.SHA384Digest.getEncodedStateSize:()I
            newarray 8
            astore 1 /* encoded */
        start local 1 // byte[] encoded
         1: .line 113
            aload 0 /* this */
            aload 1 /* encoded */
            invokespecial org.bouncycastle.crypto.digests.LongDigest.populateState:([B)V
         2: .line 114
            aload 1 /* encoded */
            areturn
        end local 1 // byte[] encoded
        end local 0 // org.bouncycastle.crypto.digests.SHA384Digest this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lorg/bouncycastle/crypto/digests/SHA384Digest;
            1    3     1  encoded  [B
}
SourceFile: "SHA384Digest.java"