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

  public void consume(sun.security.ssl.ConnectionContext, sun.security.ssl.SSLHandshake$HandshakeMessage);
    descriptor: (Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=12, args_size=3
        start local 0 // sun.security.ssl.ClientHello$T12ClientHelloConsumer this
        start local 1 // sun.security.ssl.ConnectionContext context
        start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
         0: .line 939
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            astore 3 /* shc */
        start local 3 // sun.security.ssl.ServerHandshakeContext shc
         1: .line 940
            aload 2 /* message */
            checkcast sun.security.ssl.ClientHello$ClientHelloMessage
            astore 4 /* clientHello */
        start local 4 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
         2: .line 958
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.isNegotiated:Z
            ifeq 13
         3: .line 959
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.secureRenegotiation:Z
            ifne 8
         4: .line 960
            getstatic sun.security.ssl.HandshakeContext.allowUnsafeRenegotiation:Z
            ifne 8
         5: .line 961
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
         6: .line 962
            ldc "Unsafe renegotiation is not allowed"
         7: .line 961
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
         8: .line 965
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage
      StackMap stack:
            getstatic sun.security.ssl.ServerHandshakeContext.rejectClientInitiatedRenego:Z
            ifeq 13
         9: .line 966
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.kickstartMessageDelivered:Z
            ifne 13
        10: .line 967
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        11: .line 968
            ldc "Client initiated renegotiation is not allowed"
        12: .line 967
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        13: .line 973
      StackMap locals:
      StackMap stack:
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.sessionId:Lsun/security/ssl/SessionId;
            invokevirtual sun.security.ssl.SessionId.length:()I
            ifeq 71
        14: .line 974
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
        15: .line 975
            invokevirtual sun.security.ssl.SSLContextImpl.engineGetServerSessionContext:()Ljavax/net/ssl/SSLSessionContext;
        16: .line 974
            checkcast sun.security.ssl.SSLSessionContextImpl
        17: .line 976
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.sessionId:Lsun/security/ssl/SessionId;
            invokevirtual sun.security.ssl.SessionId.getId:()[B
            invokevirtual sun.security.ssl.SSLSessionContextImpl.get:([B)Lsun/security/ssl/SSLSessionImpl;
        18: .line 974
            astore 5 /* previous */
        start local 5 // sun.security.ssl.SSLSessionImpl previous
        19: .line 979
            aload 5 /* previous */
            ifnull 21
            aload 5 /* previous */
            invokevirtual sun.security.ssl.SSLSessionImpl.isRejoinable:()Z
            ifeq 21
        20: .line 978
            iconst_1
            goto 22
      StackMap locals: sun.security.ssl.SSLSessionImpl
      StackMap stack:
        21: iconst_0
      StackMap locals:
      StackMap stack: int
        22: istore 6 /* resumingSession */
        start local 6 // boolean resumingSession
        23: .line 980
            iload 6 /* resumingSession */
            ifne 28
        24: .line 981
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 28
        25: .line 982
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 28
        26: .line 984
            ldc "Can't resume, the existing session is not rejoinable"
            iconst_0
            anewarray java.lang.Object
        27: .line 983
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        28: .line 989
      StackMap locals: int
      StackMap stack:
            iload 6 /* resumingSession */
            ifeq 37
        29: .line 991
            aload 5 /* previous */
            invokevirtual sun.security.ssl.SSLSessionImpl.getProtocolVersion:()Lsun/security/ssl/ProtocolVersion;
        30: .line 990
            astore 7 /* sessionProtocol */
        start local 7 // sun.security.ssl.ProtocolVersion sessionProtocol
        31: .line 992
            aload 7 /* sessionProtocol */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            if_acmpeq 37
        32: .line 993
            iconst_0
            istore 6 /* resumingSession */
        33: .line 994
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 37
        34: .line 995
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 37
        35: .line 997
            ldc "Can't resume, not the same protocol version"
            iconst_0
            anewarray java.lang.Object
        36: .line 996
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        end local 7 // sun.security.ssl.ProtocolVersion sessionProtocol
        37: .line 1003
      StackMap locals:
      StackMap stack:
            iload 6 /* resumingSession */
            ifeq 47
        38: .line 1004
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUIRED:Lsun/security/ssl/ClientAuthType;
            if_acmpne 47
        39: .line 1006
            aload 5 /* previous */
            invokevirtual sun.security.ssl.SSLSessionImpl.getPeerPrincipal:()Ljava/security/Principal;
            pop
        40: .line 1007
            goto 47
      StackMap locals:
      StackMap stack: javax.net.ssl.SSLPeerUnverifiedException
        41: pop
        42: .line 1008
            iconst_0
            istore 6 /* resumingSession */
        43: .line 1009
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 47
        44: .line 1010
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 47
        45: .line 1012
            ldc "Can't resume, client authentication is required"
            iconst_0
            anewarray java.lang.Object
        46: .line 1011
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        47: .line 1019
      StackMap locals:
      StackMap stack:
            iload 6 /* resumingSession */
            ifeq 56
        48: .line 1020
            aload 5 /* previous */
            invokevirtual sun.security.ssl.SSLSessionImpl.getSuite:()Lsun/security/ssl/CipherSuite;
            astore 7 /* suite */
        start local 7 // sun.security.ssl.CipherSuite suite
        49: .line 1021
            aload 3 /* shc */
            aload 7 /* suite */
            invokevirtual sun.security.ssl.ServerHandshakeContext.isNegotiable:(Lsun/security/ssl/CipherSuite;)Z
            ifeq 51
        50: .line 1022
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.cipherSuites:Ljava/util/List;
            aload 7 /* suite */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifne 56
        51: .line 1023
      StackMap locals: sun.security.ssl.CipherSuite
      StackMap stack:
            iconst_0
            istore 6 /* resumingSession */
        52: .line 1024
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 56
        53: .line 1025
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 56
        54: .line 1027
            ldc "Can't resume, the session cipher suite is absent"
            iconst_0
            anewarray java.lang.Object
        55: .line 1026
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        end local 7 // sun.security.ssl.CipherSuite suite
        56: .line 1035
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
            astore 7 /* identityAlg */
        start local 7 // java.lang.String identityAlg
        57: .line 1036
            iload 6 /* resumingSession */
            ifeq 67
            aload 7 /* identityAlg */
            ifnull 67
        58: .line 1038
            aload 5 /* previous */
            invokevirtual sun.security.ssl.SSLSessionImpl.getIdentificationProtocol:()Ljava/lang/String;
        59: .line 1037
            astore 8 /* sessionIdentityAlg */
        start local 8 // java.lang.String sessionIdentityAlg
        60: .line 1039
            aload 7 /* identityAlg */
            aload 8 /* sessionIdentityAlg */
            invokestatic java.util.Objects.equals:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ifne 67
        61: .line 1040
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 66
        62: .line 1041
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 66
        63: .line 1042
            new java.lang.StringBuilder
            dup
            ldc "Can't resume, endpoint id algorithm does not match, requested: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        64: .line 1044
            aload 7 /* identityAlg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ", cached: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 8 /* sessionIdentityAlg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        65: .line 1042
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        66: .line 1046
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
            iconst_0
            istore 6 /* resumingSession */
        end local 8 // java.lang.String sessionIdentityAlg
        67: .line 1052
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            iload 6 /* resumingSession */
            putfield sun.security.ssl.ServerHandshakeContext.isResumption:Z
        68: .line 1053
            aload 3 /* shc */
            iload 6 /* resumingSession */
            ifeq 69
            aload 5 /* previous */
            goto 70
      StackMap locals:
      StackMap stack: sun.security.ssl.ServerHandshakeContext
        69: aconst_null
      StackMap locals: sun.security.ssl.ClientHello$T12ClientHelloConsumer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLSessionImpl int java.lang.String
      StackMap stack: sun.security.ssl.ServerHandshakeContext sun.security.ssl.SSLSessionImpl
        70: putfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
        end local 7 // java.lang.String identityAlg
        end local 6 // boolean resumingSession
        end local 5 // sun.security.ssl.SSLSessionImpl previous
        71: .line 1057
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.clientRandom:Lsun/security/ssl/RandomCookie;
            putfield sun.security.ssl.ServerHandshakeContext.clientHelloRandom:Lsun/security/ssl/RandomCookie;
        72: .line 1060
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        73: .line 1061
            getstatic sun.security.ssl.SSLHandshake.CLIENT_HELLO:Lsun/security/ssl/SSLHandshake;
        74: .line 1060
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;)[Lsun/security/ssl/SSLExtension;
            astore 5 /* extTypes */
        start local 5 // sun.security.ssl.SSLExtension[] extTypes
        75: .line 1062
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 3 /* shc */
            aload 5 /* extTypes */
            invokevirtual sun.security.ssl.SSLExtensions.consumeOnLoad:(Lsun/security/ssl/HandshakeContext;[Lsun/security/ssl/SSLExtension;)V
        76: .line 1067
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.isNegotiated:Z
            ifne 79
        77: .line 1068
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            putfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
        78: .line 1069
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.outputRecord:Lsun/security/ssl/OutputRecord;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.OutputRecord.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
        79: .line 1078
      StackMap locals: sun.security.ssl.SSLExtension[]
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
        80: .line 1079
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO:Lsun/security/ssl/SSLHandshake;
        81: .line 1078
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        82: .line 1084
            bipush 7
            anewarray sun.security.ssl.SSLHandshake
            dup
            iconst_0
        83: .line 1085
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO:Lsun/security/ssl/SSLHandshake;
            aastore
            dup
            iconst_1
        84: .line 1088
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE:Lsun/security/ssl/SSLHandshake;
            aastore
            dup
            iconst_2
        85: .line 1089
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_STATUS:Lsun/security/ssl/SSLHandshake;
            aastore
            dup
            iconst_3
        86: .line 1090
            getstatic sun.security.ssl.SSLHandshake.SERVER_KEY_EXCHANGE:Lsun/security/ssl/SSLHandshake;
            aastore
            dup
            iconst_4
        87: .line 1091
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_REQUEST:Lsun/security/ssl/SSLHandshake;
            aastore
            dup
            iconst_5
        88: .line 1092
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO_DONE:Lsun/security/ssl/SSLHandshake;
            aastore
            dup
            bipush 6
        89: .line 1095
            getstatic sun.security.ssl.SSLHandshake.FINISHED:Lsun/security/ssl/SSLHandshake;
            aastore
        90: .line 1084
            astore 6 /* probableHandshakeMessages */
        start local 6 // sun.security.ssl.SSLHandshake[] probableHandshakeMessages
        91: .line 1098
            aload 6 /* probableHandshakeMessages */
            dup
            astore 10
            arraylength
            istore 9
            iconst_0
            istore 8
            goto 98
      StackMap locals: sun.security.ssl.ClientHello$T12ClientHelloConsumer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLExtension[] sun.security.ssl.SSLHandshake[] top int int sun.security.ssl.SSLHandshake[]
      StackMap stack:
        92: aload 10
            iload 8
            aaload
            astore 7 /* hs */
        start local 7 // sun.security.ssl.SSLHandshake hs
        93: .line 1100
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
            aload 7 /* hs */
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
            invokevirtual java.util.HashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast sun.security.ssl.HandshakeProducer
        94: .line 1099
            astore 11 /* handshakeProducer */
        start local 11 // sun.security.ssl.HandshakeProducer handshakeProducer
        95: .line 1101
            aload 11 /* handshakeProducer */
            ifnull 97
        96: .line 1102
            aload 11 /* handshakeProducer */
            aload 1 /* context */
            aload 4 /* clientHello */
            invokeinterface sun.security.ssl.HandshakeProducer.produce:(Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;)[B
            pop
        end local 11 // sun.security.ssl.HandshakeProducer handshakeProducer
        end local 7 // sun.security.ssl.SSLHandshake hs
        97: .line 1098
      StackMap locals:
      StackMap stack:
            iinc 8 1
      StackMap locals:
      StackMap stack:
        98: iload 8
            iload 9
            if_icmplt 92
        99: .line 1105
            return
        end local 6 // sun.security.ssl.SSLHandshake[] probableHandshakeMessages
        end local 5 // sun.security.ssl.SSLExtension[] extTypes
        end local 4 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
        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.ClientHello$T12ClientHelloConsumer this
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            0  100     0                       this  Lsun/security/ssl/ClientHello$T12ClientHelloConsumer;
            0  100     1                    context  Lsun/security/ssl/ConnectionContext;
            0  100     2                    message  Lsun/security/ssl/SSLHandshake$HandshakeMessage;
            1  100     3                        shc  Lsun/security/ssl/ServerHandshakeContext;
            2  100     4                clientHello  Lsun/security/ssl/ClientHello$ClientHelloMessage;
           19   71     5                   previous  Lsun/security/ssl/SSLSessionImpl;
           23   71     6            resumingSession  Z
           31   37     7            sessionProtocol  Lsun/security/ssl/ProtocolVersion;
           49   56     7                      suite  Lsun/security/ssl/CipherSuite;
           57   71     7                identityAlg  Ljava/lang/String;
           60   67     8         sessionIdentityAlg  Ljava/lang/String;
           75  100     5                   extTypes  [Lsun/security/ssl/SSLExtension;
           91  100     6  probableHandshakeMessages  [Lsun/security/ssl/SSLHandshake;
           93   97     7                         hs  Lsun/security/ssl/SSLHandshake;
           95   97    11          handshakeProducer  Lsun/security/ssl/HandshakeProducer;
      Exception table:
        from    to  target  type
          39    40      41  Class javax.net.ssl.SSLPeerUnverifiedException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
      message  
}
SourceFile: "ClientHello.java"
NestHost: sun.security.ssl.ClientHello
InnerClasses:
  final ClientHelloMessage = sun.security.ssl.ClientHello$ClientHelloMessage of sun.security.ssl.ClientHello
  private final T12ClientHelloConsumer = sun.security.ssl.ClientHello$T12ClientHelloConsumer of sun.security.ssl.ClientHello
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake