final class sun.security.ssl.HandshakeHash$T12HandshakeHash implements sun.security.ssl.HandshakeHash$TranscriptHash
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.HandshakeHash$T12HandshakeHash
super_class: java.lang.Object
{
private final sun.security.ssl.HandshakeHash$TranscriptHash transcriptHash;
descriptor: Lsun/security/ssl/HandshakeHash$TranscriptHash;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.io.ByteArrayOutputStream baos;
descriptor: Ljava/io/ByteArrayOutputStream;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
void <init>(sun.security.ssl.CipherSuite);
descriptor: (Lsun/security/ssl/CipherSuite;)V
flags: (0x0000)
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 1
getfield sun.security.ssl.CipherSuite.hashAlg:Lsun/security/ssl/CipherSuite$HashAlg;
getfield sun.security.ssl.CipherSuite$HashAlg.name:Ljava/lang/String;
invokestatic sun.security.ssl.JsseJce.getMessageDigest:(Ljava/lang/String;)Ljava/security/MessageDigest;
2: astore 2
start local 2 3: aload 2
instanceof java.lang.Cloneable
ifeq 7
4: aload 0
new sun.security.ssl.HandshakeHash$CloneableHash
dup
aload 2
invokespecial sun.security.ssl.HandshakeHash$CloneableHash.<init>:(Ljava/security/MessageDigest;)V
putfield sun.security.ssl.HandshakeHash$T12HandshakeHash.transcriptHash:Lsun/security/ssl/HandshakeHash$TranscriptHash;
5: aload 0
new java.io.ByteArrayOutputStream
dup
invokespecial java.io.ByteArrayOutputStream.<init>:()V
putfield sun.security.ssl.HandshakeHash$T12HandshakeHash.baos:Ljava/io/ByteArrayOutputStream;
6: goto 9
7: StackMap locals: sun.security.ssl.HandshakeHash$T12HandshakeHash sun.security.ssl.CipherSuite java.security.MessageDigest
StackMap stack:
aload 0
new sun.security.ssl.HandshakeHash$NonCloneableHash
dup
aload 2
invokespecial sun.security.ssl.HandshakeHash$NonCloneableHash.<init>:(Ljava/security/MessageDigest;)V
putfield sun.security.ssl.HandshakeHash$T12HandshakeHash.transcriptHash:Lsun/security/ssl/HandshakeHash$TranscriptHash;
8: aload 0
aconst_null
putfield sun.security.ssl.HandshakeHash$T12HandshakeHash.baos:Ljava/io/ByteArrayOutputStream;
9: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lsun/security/ssl/HandshakeHash$T12HandshakeHash;
0 10 1 cipherSuite Lsun/security/ssl/CipherSuite;
3 10 2 md Ljava/security/MessageDigest;
MethodParameters:
Name Flags
cipherSuite
public void update(byte[], int, int);
descriptor: ([BII)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield sun.security.ssl.HandshakeHash$T12HandshakeHash.transcriptHash:Lsun/security/ssl/HandshakeHash$TranscriptHash;
aload 1
iload 2
iload 3
invokeinterface sun.security.ssl.HandshakeHash$TranscriptHash.update:([BII)V
1: aload 0
getfield sun.security.ssl.HandshakeHash$T12HandshakeHash.baos:Ljava/io/ByteArrayOutputStream;
ifnull 3
2: aload 0
getfield sun.security.ssl.HandshakeHash$T12HandshakeHash.baos:Ljava/io/ByteArrayOutputStream;
aload 1
iload 2
iload 3
invokevirtual java.io.ByteArrayOutputStream.write:([BII)V
3: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/HandshakeHash$T12HandshakeHash;
0 4 1 input [B
0 4 2 offset I
0 4 3 length I
MethodParameters:
Name Flags
input
offset
length
public byte[] digest();
descriptor: ()[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.HandshakeHash$T12HandshakeHash.transcriptHash:Lsun/security/ssl/HandshakeHash$TranscriptHash;
invokeinterface sun.security.ssl.HandshakeHash$TranscriptHash.digest:()[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/HandshakeHash$T12HandshakeHash;
public byte[] archived();
descriptor: ()[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.HandshakeHash$T12HandshakeHash.baos:Ljava/io/ByteArrayOutputStream;
ifnull 2
1: aload 0
getfield sun.security.ssl.HandshakeHash$T12HandshakeHash.baos:Ljava/io/ByteArrayOutputStream;
invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
areturn
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeHash$T12HandshakeHash.transcriptHash:Lsun/security/ssl/HandshakeHash$TranscriptHash;
invokeinterface sun.security.ssl.HandshakeHash$TranscriptHash.archived:()[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/HandshakeHash$T12HandshakeHash;
}
SourceFile: "HandshakeHash.java"
NestHost: sun.security.ssl.HandshakeHash
InnerClasses:
final HashAlg = sun.security.ssl.CipherSuite$HashAlg of sun.security.ssl.CipherSuite
final CloneableHash = sun.security.ssl.HandshakeHash$CloneableHash of sun.security.ssl.HandshakeHash
final NonCloneableHash = sun.security.ssl.HandshakeHash$NonCloneableHash of sun.security.ssl.HandshakeHash
final T12HandshakeHash = sun.security.ssl.HandshakeHash$T12HandshakeHash of sun.security.ssl.HandshakeHash
abstract TranscriptHash = sun.security.ssl.HandshakeHash$TranscriptHash of sun.security.ssl.HandshakeHash