final class sun.security.ssl.CertificateRequest$T10CertificateRequestProducer implements sun.security.ssl.HandshakeProducer
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.CertificateRequest$T10CertificateRequestProducer
  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$T10CertificateRequestProducer this
         0: .line 276
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 278
            return
        end local 0 // sun.security.ssl.CertificateRequest$T10CertificateRequestProducer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestProducer;

  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$T10CertificateRequestProducer this
        start local 1 // sun.security.ssl.ConnectionContext context
        start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
         0: .line 284
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            astore 3 /* shc */
        start local 3 // sun.security.ssl.ServerHandshakeContext shc
         1: .line 287
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getX509TrustManager:()Ljavax/net/ssl/X509TrustManager;
            invokeinterface javax.net.ssl.X509TrustManager.getAcceptedIssuers:()[Ljava/security/cert/X509Certificate;
         2: .line 286
            astore 4 /* caCerts */
        start local 4 // java.security.cert.X509Certificate[] caCerts
         3: .line 288
            new sun.security.ssl.CertificateRequest$T10CertificateRequestMessage
            dup
         4: .line 289
            aload 3 /* shc */
            aload 4 /* caCerts */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
         5: .line 288
            invokespecial sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.<init>:(Lsun/security/ssl/HandshakeContext;[Ljava/security/cert/X509Certificate;Lsun/security/ssl/CipherSuite$KeyExchange;)V
            astore 5 /* crm */
        start local 5 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage crm
         6: .line 290
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 9
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 9
         7: .line 292
            ldc "Produced CertificateRequest handshake message"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 5 /* crm */
            aastore
         8: .line 291
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
         9: .line 296
      StackMap locals: sun.security.ssl.ServerHandshakeContext java.security.cert.X509Certificate[] sun.security.ssl.CertificateRequest$T10CertificateRequestMessage
      StackMap stack:
            aload 5 /* crm */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.CertificateRequest$T10CertificateRequestMessage.write:(Lsun/security/ssl/HandshakeOutStream;)V
        10: .line 297
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
        11: .line 302
            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;
        12: .line 303
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE:Lsun/security/ssl/SSLHandshake;
        13: .line 302
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        14: .line 304
            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;
        15: .line 305
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_VERIFY:Lsun/security/ssl/SSLHandshake;
        16: .line 304
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        17: .line 308
            aconst_null
            areturn
        end local 5 // sun.security.ssl.CertificateRequest$T10CertificateRequestMessage crm
        end local 4 // java.security.cert.X509Certificate[] caCerts
        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$T10CertificateRequestProducer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   18     0     this  Lsun/security/ssl/CertificateRequest$T10CertificateRequestProducer;
            0   18     1  context  Lsun/security/ssl/ConnectionContext;
            0   18     2  message  Lsun/security/ssl/SSLHandshake$HandshakeMessage;
            1   18     3      shc  Lsun/security/ssl/ServerHandshakeContext;
            3   18     4  caCerts  [Ljava/security/cert/X509Certificate;
            6   18     5      crm  Lsun/security/ssl/CertificateRequest$T10CertificateRequestMessage;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
      message  
}
SourceFile: "CertificateRequest.java"
NestHost: sun.security.ssl.CertificateRequest
InnerClasses:
  final T10CertificateRequestMessage = sun.security.ssl.CertificateRequest$T10CertificateRequestMessage of sun.security.ssl.CertificateRequest
  private final T10CertificateRequestProducer = sun.security.ssl.CertificateRequest$T10CertificateRequestProducer of sun.security.ssl.CertificateRequest
  final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake