final class sun.security.ssl.CertificateRequest$T13CertificateRequestProducer implements sun.security.ssl.HandshakeProducer
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.CertificateRequest$T13CertificateRequestProducer
  super_class: java.lang.Object
{
  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestProducer this
         0: .line 865
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 867
            return
        end local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestProducer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/CertificateRequest$T13CertificateRequestProducer;

  public byte[] produce(sun.security.ssl.ConnectionContext, sun.security.ssl.SSLHandshake$HandshakeMessage);
    descriptor: (Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=3
        start local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestProducer this
        start local 1 // sun.security.ssl.ConnectionContext context
        start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
         0: .line 873
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            astore 3 /* shc */
        start local 3 // sun.security.ssl.ServerHandshakeContext shc
         1: .line 876
            new sun.security.ssl.CertificateRequest$T13CertificateRequestMessage
            dup
            aload 3 /* shc */
            invokespecial sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         2: .line 875
            astore 4 /* crm */
        start local 4 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage crm
         3: .line 878
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
         4: .line 879
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_REQUEST:Lsun/security/ssl/SSLHandshake;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
         5: .line 878
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
            astore 5 /* extTypes */
        start local 5 // sun.security.ssl.SSLExtension[] extTypes
         6: .line 880
            aload 4 /* crm */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 3 /* shc */
            aload 5 /* extTypes */
            invokevirtual sun.security.ssl.SSLExtensions.produce:(Lsun/security/ssl/HandshakeContext;[Lsun/security/ssl/SSLExtension;)V
         7: .line 881
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 9
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 9
         8: .line 882
            ldc "Produced CertificateRequest message"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 4 /* crm */
            aastore
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
         9: .line 886
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.CertificateRequest$T13CertificateRequestMessage sun.security.ssl.SSLExtension[]
      StackMap stack:
            aload 4 /* crm */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.write:(Lsun/security/ssl/HandshakeOutStream;)V
        10: .line 887
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
        11: .line 892
            aload 3 /* shc */
            aload 4 /* crm */
            getfield sun.security.ssl.CertificateRequest$T13CertificateRequestMessage.requestContext:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield sun.security.ssl.ServerHandshakeContext.certRequestContext:[B
        12: .line 893
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
        13: .line 894
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE:Lsun/security/ssl/SSLHandshake;
        14: .line 893
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        15: .line 895
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_VERIFY:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
        16: .line 896
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_VERIFY:Lsun/security/ssl/SSLHandshake;
        17: .line 895
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        18: .line 899
            aconst_null
            areturn
        end local 5 // sun.security.ssl.SSLExtension[] extTypes
        end local 4 // sun.security.ssl.CertificateRequest$T13CertificateRequestMessage crm
        end local 3 // sun.security.ssl.ServerHandshakeContext shc
        end local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
        end local 1 // sun.security.ssl.ConnectionContext context
        end local 0 // sun.security.ssl.CertificateRequest$T13CertificateRequestProducer this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   19     0      this  Lsun/security/ssl/CertificateRequest$T13CertificateRequestProducer;
            0   19     1   context  Lsun/security/ssl/ConnectionContext;
            0   19     2   message  Lsun/security/ssl/SSLHandshake$HandshakeMessage;
            1   19     3       shc  Lsun/security/ssl/ServerHandshakeContext;
            3   19     4       crm  Lsun/security/ssl/CertificateRequest$T13CertificateRequestMessage;
            6   19     5  extTypes  [Lsun/security/ssl/SSLExtension;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
      message  
}
SourceFile: "CertificateRequest.java"
NestHost: sun.security.ssl.CertificateRequest
InnerClasses:
  final T13CertificateRequestMessage = sun.security.ssl.CertificateRequest$T13CertificateRequestMessage of sun.security.ssl.CertificateRequest
  private final T13CertificateRequestProducer = sun.security.ssl.CertificateRequest$T13CertificateRequestProducer of sun.security.ssl.CertificateRequest
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake