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

  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=9, locals=13, args_size=3
        start local 0 // sun.security.ssl.ServerHello$T12ServerHelloProducer this
        start local 1 // sun.security.ssl.ConnectionContext context
        start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
         0: .line 265
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            astore 3 /* shc */
        start local 3 // sun.security.ssl.ServerHandshakeContext shc
         1: .line 266
            aload 2 /* message */
            checkcast sun.security.ssl.ClientHello$ClientHelloMessage
            astore 4 /* clientHello */
        start local 4 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
         2: .line 271
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.isResumption:Z
            ifeq 3
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            ifnonnull 69
         3: .line 272
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.enableSessionCreation:Z
            ifne 7
         4: .line 273
            new javax.net.ssl.SSLException
            dup
         5: .line 274
            ldc "Not resumption, and no new session is allowed"
         6: .line 273
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 277
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.localSupportedSignAlgs:Ljava/util/List;
            ifnonnull 13
         8: .line 278
            aload 3 /* shc */
         9: .line 280
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        10: .line 281
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.algorithmConstraints:Ljava/security/AlgorithmConstraints;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.activeProtocols:Ljava/util/List;
        11: .line 279
            invokestatic sun.security.ssl.SignatureScheme.getSupportedAlgorithms:(Lsun/security/ssl/SSLConfiguration;Ljava/security/AlgorithmConstraints;Ljava/util/List;)Ljava/util/List;
        12: .line 278
            putfield sun.security.ssl.ServerHandshakeContext.localSupportedSignAlgs:Ljava/util/List;
        13: .line 285
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLSessionImpl
            dup
            aload 3 /* shc */
            getstatic sun.security.ssl.CipherSuite.C_NULL:Lsun/security/ssl/CipherSuite;
            invokespecial sun.security.ssl.SSLSessionImpl.<init>:(Lsun/security/ssl/HandshakeContext;Lsun/security/ssl/CipherSuite;)V
        14: .line 284
            astore 5 /* session */
        start local 5 // sun.security.ssl.SSLSessionImpl session
        15: .line 286
            aload 5 /* session */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.maximumPacketSize:I
            invokevirtual sun.security.ssl.SSLSessionImpl.setMaximumPacketSize:(I)V
        16: .line 287
            aload 3 /* shc */
            aload 5 /* session */
            putfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
        17: .line 291
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        18: .line 292
            getstatic sun.security.ssl.SSLHandshake.CLIENT_HELLO:Lsun/security/ssl/SSLHandshake;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        19: .line 291
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
        20: .line 290
            astore 6 /* enabledExtensions */
        start local 6 // sun.security.ssl.SSLExtension[] enabledExtensions
        21: .line 293
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 3 /* shc */
            aload 6 /* enabledExtensions */
            invokevirtual sun.security.ssl.SSLExtensions.consumeOnTrade:(Lsun/security/ssl/HandshakeContext;[Lsun/security/ssl/SSLExtension;)V
        22: .line 297
            aload 3 /* shc */
            aload 4 /* clientHello */
            invokestatic sun.security.ssl.ServerHello$T12ServerHelloProducer.chooseCipherSuite:(Lsun/security/ssl/ServerHandshakeContext;Lsun/security/ssl/ClientHello$ClientHelloMessage;)Lsun/security/ssl/ServerHello$T12ServerHelloProducer$KeyExchangeProperties;
        23: .line 296
            astore 7 /* credentials */
        start local 7 // sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties credentials
        24: .line 298
            aload 7 /* credentials */
            ifnonnull 28
        25: .line 299
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        26: .line 300
            ldc "no cipher suites in common"
        27: .line 299
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        28: .line 302
      StackMap locals: sun.security.ssl.SSLSessionImpl sun.security.ssl.SSLExtension[] sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties
      StackMap stack:
            aload 3 /* shc */
            aload 7 /* credentials */
            getfield sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties.cipherSuite:Lsun/security/ssl/CipherSuite;
            putfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
        29: .line 303
            aload 3 /* shc */
            aload 7 /* credentials */
            getfield sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties.keyExchange:Lsun/security/ssl/SSLKeyExchange;
            putfield sun.security.ssl.ServerHandshakeContext.handshakeKeyExchange:Lsun/security/ssl/SSLKeyExchange;
        30: .line 304
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
            aload 7 /* credentials */
            getfield sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties.cipherSuite:Lsun/security/ssl/CipherSuite;
            invokevirtual sun.security.ssl.SSLSessionImpl.setSuite:(Lsun/security/ssl/CipherSuite;)V
        31: .line 305
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakePossessions:Ljava/util/List;
        32: .line 306
            aload 7 /* credentials */
            getfield sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties.possessions:[Lsun/security/ssl/SSLPossession;
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
        33: .line 305
            invokeinterface java.util.List.addAll:(Ljava/util/Collection;)Z
            pop
        34: .line 307
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
        35: .line 308
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
        36: .line 307
            invokevirtual sun.security.ssl.HandshakeHash.determine:(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)V
        37: .line 313
            aload 3 /* shc */
            aload 3 /* shc */
            invokestatic sun.security.ssl.StatusResponseManager.processStapling:(Lsun/security/ssl/ServerHandshakeContext;)Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            putfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
        38: .line 314
            aload 3 /* shc */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            ifnull 39
            iconst_1
            goto 40
      StackMap locals:
      StackMap stack: sun.security.ssl.ServerHandshakeContext
        39: iconst_0
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLSessionImpl sun.security.ssl.SSLExtension[] sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties
      StackMap stack: sun.security.ssl.ServerHandshakeContext int
        40: putfield sun.security.ssl.ServerHandshakeContext.staplingActive:Z
        41: .line 317
            aload 7 /* credentials */
            getfield sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties.keyExchange:Lsun/security/ssl/SSLKeyExchange;
            astore 8 /* ke */
        start local 8 // sun.security.ssl.SSLKeyExchange ke
        42: .line 318
            aload 8 /* ke */
            ifnull 50
        43: .line 320
            aload 8 /* ke */
            aload 3 /* shc */
            invokevirtual sun.security.ssl.SSLKeyExchange.getHandshakeProducers:(Lsun/security/ssl/HandshakeContext;)[Ljava/util/Map$Entry;
            dup
            astore 12
            arraylength
            istore 11
            iconst_0
            istore 10
            goto 49
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLSessionImpl sun.security.ssl.SSLExtension[] sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties sun.security.ssl.SSLKeyExchange top int int java.util.Map$Entry[]
      StackMap stack:
        44: aload 12
            iload 10
            aaload
            astore 9 /* me */
        start local 9 // java.util.Map$Entry me
        45: .line 321
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
        46: .line 322
            aload 9 /* me */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.Byte
            aload 9 /* me */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast sun.security.ssl.HandshakeProducer
        47: .line 321
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 9 // java.util.Map$Entry me
        48: .line 319
            iinc 10 1
      StackMap locals:
      StackMap stack:
        49: iload 10
            iload 11
            if_icmplt 44
        50: .line 326
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLSessionImpl sun.security.ssl.SSLExtension[] sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties sun.security.ssl.SSLKeyExchange
      StackMap stack:
            aload 8 /* ke */
            ifnull 65
        51: .line 327
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        52: .line 328
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
        53: .line 327
            if_acmpeq 65
        54: .line 329
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
            invokevirtual sun.security.ssl.CipherSuite.isAnonymous:()Z
            ifne 65
        55: .line 331
            aload 8 /* ke */
            aload 3 /* shc */
            invokevirtual sun.security.ssl.SSLKeyExchange.getRelatedHandshakers:(Lsun/security/ssl/HandshakeContext;)[Lsun/security/ssl/SSLHandshake;
            dup
            astore 12
            arraylength
            istore 11
            iconst_0
            istore 10
            goto 64
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLSessionImpl sun.security.ssl.SSLExtension[] sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties sun.security.ssl.SSLKeyExchange top int int sun.security.ssl.SSLHandshake[]
      StackMap stack:
        56: aload 12
            iload 10
            aaload
            astore 9 /* hs */
        start local 9 // sun.security.ssl.SSLHandshake hs
        57: .line 332
            aload 9 /* hs */
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE:Lsun/security/ssl/SSLHandshake;
            if_acmpne 63
        58: .line 333
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
        59: .line 334
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_REQUEST:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
        60: .line 335
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_REQUEST:Lsun/security/ssl/SSLHandshake;
        61: .line 333
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        62: .line 336
            goto 65
        end local 9 // sun.security.ssl.SSLHandshake hs
        63: .line 330
      StackMap locals:
      StackMap stack:
            iinc 10 1
      StackMap locals:
      StackMap stack:
        64: iload 10
            iload 11
            if_icmplt 56
        65: .line 340
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLSessionImpl sun.security.ssl.SSLExtension[] sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties sun.security.ssl.SSLKeyExchange
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO_DONE:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
        66: .line 341
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO_DONE:Lsun/security/ssl/SSLHandshake;
        67: .line 340
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 8 // sun.security.ssl.SSLKeyExchange ke
        end local 7 // sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties credentials
        end local 6 // sun.security.ssl.SSLExtension[] enabledExtensions
        end local 5 // sun.security.ssl.SSLSessionImpl session
        68: .line 342
            goto 88
        69: .line 344
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.statelessResumption:Z
            ifeq 80
        70: .line 345
            aload 3 /* shc */
        71: new sun.security.ssl.SSLSessionImpl
            dup
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
        72: .line 346
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.sessionId:Lsun/security/ssl/SessionId;
            invokevirtual sun.security.ssl.SessionId.length:()I
            ifne 77
        73: .line 347
            new sun.security.ssl.SessionId
            dup
            iconst_1
        74: .line 348
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
        75: .line 347
            invokespecial sun.security.ssl.SessionId.<init>:(ZLjava/security/SecureRandom;)V
        76: .line 348
            goto 78
        77: .line 349
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage
      StackMap stack: sun.security.ssl.ServerHandshakeContext new 71 new 71 sun.security.ssl.SSLSessionImpl
            new sun.security.ssl.SessionId
            dup
            aload 4 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.sessionId:Lsun/security/ssl/SessionId;
            invokevirtual sun.security.ssl.SessionId.getId:()[B
            invokespecial sun.security.ssl.SessionId.<init>:([B)V
      StackMap locals: sun.security.ssl.ServerHello$T12ServerHelloProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage
      StackMap stack: sun.security.ssl.ServerHandshakeContext new 71 new 71 sun.security.ssl.SSLSessionImpl sun.security.ssl.SessionId
        78: invokespecial sun.security.ssl.SSLSessionImpl.<init>:(Lsun/security/ssl/SSLSessionImpl;Lsun/security/ssl/SessionId;)V
        79: .line 345
            putfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
        80: .line 352
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            putfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
        81: .line 353
            aload 3 /* shc */
        82: .line 354
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getProtocolVersion:()Lsun/security/ssl/ProtocolVersion;
        83: .line 353
            putfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        84: .line 355
            aload 3 /* shc */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getSuite:()Lsun/security/ssl/CipherSuite;
            putfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
        85: .line 356
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
        86: .line 357
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
        87: .line 356
            invokevirtual sun.security.ssl.HandshakeHash.determine:(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)V
        88: .line 361
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.ServerHello$ServerHelloMessage
            dup
            aload 3 /* shc */
        89: .line 362
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        90: .line 363
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getSessionId:()Lsun/security/ssl/SessionId;
        91: .line 364
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
        92: .line 365
            new sun.security.ssl.RandomCookie
            dup
            aload 3 /* shc */
            invokespecial sun.security.ssl.RandomCookie.<init>:(Lsun/security/ssl/HandshakeContext;)V
        93: .line 366
            aload 4 /* clientHello */
        94: .line 361
            invokespecial sun.security.ssl.ServerHello$ServerHelloMessage.<init>:(Lsun/security/ssl/HandshakeContext;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/SessionId;Lsun/security/ssl/CipherSuite;Lsun/security/ssl/RandomCookie;Lsun/security/ssl/ClientHello$ClientHelloMessage;)V
            astore 5 /* shm */
        start local 5 // sun.security.ssl.ServerHello$ServerHelloMessage shm
        95: .line 367
            aload 3 /* shc */
            aload 5 /* shm */
            getfield sun.security.ssl.ServerHello$ServerHelloMessage.serverRandom:Lsun/security/ssl/RandomCookie;
            putfield sun.security.ssl.ServerHandshakeContext.serverHelloRandom:Lsun/security/ssl/RandomCookie;
        96: .line 371
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        97: .line 372
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO:Lsun/security/ssl/SSLHandshake;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        98: .line 371
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
        99: .line 370
            astore 6 /* serverHelloExtensions */
        start local 6 // sun.security.ssl.SSLExtension[] serverHelloExtensions
       100: .line 373
            aload 5 /* shm */
            getfield sun.security.ssl.ServerHello$ServerHelloMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 3 /* shc */
            aload 6 /* serverHelloExtensions */
            invokevirtual sun.security.ssl.SSLExtensions.produce:(Lsun/security/ssl/HandshakeContext;[Lsun/security/ssl/SSLExtension;)V
       101: .line 374
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 103
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 103
       102: .line 375
            ldc "Produced ServerHello handshake message"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 5 /* shm */
            aastore
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
       103: .line 379
      StackMap locals: sun.security.ssl.ServerHello$ServerHelloMessage sun.security.ssl.SSLExtension[]
      StackMap stack:
            aload 5 /* shm */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.ServerHello$ServerHelloMessage.write:(Lsun/security/ssl/HandshakeOutStream;)V
       104: .line 380
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
       105: .line 382
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.isResumption:Z
            ifeq 120
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            ifnull 120
       106: .line 384
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            invokestatic sun.security.ssl.SSLTrafficKeyDerivation.valueOf:(Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/SSLTrafficKeyDerivation;
       107: .line 383
            astore 7 /* kdg */
        start local 7 // sun.security.ssl.SSLTrafficKeyDerivation kdg
       108: .line 385
            aload 7 /* kdg */
            ifnonnull 114
       109: .line 387
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.INTERNAL_ERROR:Lsun/security/ssl/Alert;
       110: .line 388
            new java.lang.StringBuilder
            dup
            ldc "Not supported key derivation: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
       111: .line 389
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
       112: .line 388
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       113: .line 387
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
       114: .line 391
      StackMap locals: sun.security.ssl.SSLTrafficKeyDerivation
      StackMap stack:
            aload 3 /* shc */
            aload 7 /* kdg */
       115: .line 392
            aload 3 /* shc */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getMasterSecret:()Ljavax/crypto/SecretKey;
       116: .line 391
            invokevirtual sun.security.ssl.SSLTrafficKeyDerivation.createKeyDerivation:(Lsun/security/ssl/HandshakeContext;Ljavax/crypto/SecretKey;)Lsun/security/ssl/SSLKeyDerivation;
            putfield sun.security.ssl.ServerHandshakeContext.handshakeKeyDerivation:Lsun/security/ssl/SSLKeyDerivation;
       117: .line 396
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
            getstatic sun.security.ssl.SSLHandshake.FINISHED:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
       118: .line 397
            getstatic sun.security.ssl.SSLHandshake.FINISHED:Lsun/security/ssl/SSLHandshake;
       119: .line 396
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // sun.security.ssl.SSLTrafficKeyDerivation kdg
       120: .line 401
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 6 // sun.security.ssl.SSLExtension[] serverHelloExtensions
        end local 5 // sun.security.ssl.ServerHello$ServerHelloMessage shm
        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.ServerHello$T12ServerHelloProducer this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0  121     0                   this  Lsun/security/ssl/ServerHello$T12ServerHelloProducer;
            0  121     1                context  Lsun/security/ssl/ConnectionContext;
            0  121     2                message  Lsun/security/ssl/SSLHandshake$HandshakeMessage;
            1  121     3                    shc  Lsun/security/ssl/ServerHandshakeContext;
            2  121     4            clientHello  Lsun/security/ssl/ClientHello$ClientHelloMessage;
           15   68     5                session  Lsun/security/ssl/SSLSessionImpl;
           21   68     6      enabledExtensions  [Lsun/security/ssl/SSLExtension;
           24   68     7            credentials  Lsun/security/ssl/ServerHello$T12ServerHelloProducer$KeyExchangeProperties;
           42   68     8                     ke  Lsun/security/ssl/SSLKeyExchange;
           45   48     9                     me  Ljava/util/Map$Entry<Ljava/lang/Byte;Lsun/security/ssl/HandshakeProducer;>;
           57   63     9                     hs  Lsun/security/ssl/SSLHandshake;
           95  121     5                    shm  Lsun/security/ssl/ServerHello$ServerHelloMessage;
          100  121     6  serverHelloExtensions  [Lsun/security/ssl/SSLExtension;
          108  120     7                    kdg  Lsun/security/ssl/SSLTrafficKeyDerivation;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
      message  

  private static sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties chooseCipherSuite(sun.security.ssl.ServerHandshakeContext, sun.security.ssl.ClientHello$ClientHelloMessage);
    descriptor: (Lsun/security/ssl/ServerHandshakeContext;Lsun/security/ssl/ClientHello$ClientHelloMessage;)Lsun/security/ssl/ServerHello$T12ServerHelloProducer$KeyExchangeProperties;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=9, args_size=2
        start local 0 // sun.security.ssl.ServerHandshakeContext shc
        start local 1 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
         0: .line 409
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
            ifeq 4
         1: .line 410
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.activeCipherSuites:Ljava/util/List;
            astore 2 /* preferred */
        start local 2 // java.util.List preferred
         2: .line 411
            aload 1 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.cipherSuites:Ljava/util/List;
            astore 3 /* proposed */
        start local 3 // java.util.List proposed
         3: .line 412
            goto 6
        end local 3 // java.util.List proposed
        end local 2 // java.util.List preferred
         4: .line 413
      StackMap locals:
      StackMap stack:
            aload 1 /* clientHello */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.cipherSuites:Ljava/util/List;
            astore 2 /* preferred */
        start local 2 // java.util.List preferred
         5: .line 414
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.activeCipherSuites:Ljava/util/List;
            astore 3 /* proposed */
        start local 3 // java.util.List proposed
         6: .line 417
      StackMap locals: java.util.List java.util.List
      StackMap stack:
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 4 /* legacySuites */
        start local 4 // java.util.List legacySuites
         7: .line 418
            aload 2 /* preferred */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 35
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage java.util.List java.util.List java.util.List top java.util.Iterator
      StackMap stack:
         8: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.CipherSuite
            astore 5 /* cs */
        start local 5 // sun.security.ssl.CipherSuite cs
         9: .line 420
            aload 3 /* proposed */
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            aload 5 /* cs */
        10: .line 419
            invokestatic sun.security.ssl.HandshakeContext.isNegotiable:(Ljava/util/List;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)Z
        11: .line 420
            ifne 13
        12: .line 421
            goto 35
        13: .line 424
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage java.util.List java.util.List java.util.List sun.security.ssl.CipherSuite java.util.Iterator
      StackMap stack:
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        14: .line 425
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUIRED:Lsun/security/ssl/ClientAuthType;
        15: .line 424
            if_acmpne 19
        16: .line 426
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
            getstatic sun.security.ssl.CipherSuite$KeyExchange.K_DH_ANON:Lsun/security/ssl/CipherSuite$KeyExchange;
            if_acmpeq 35
        17: .line 427
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
            getstatic sun.security.ssl.CipherSuite$KeyExchange.K_ECDH_ANON:Lsun/security/ssl/CipherSuite$KeyExchange;
            if_acmpne 19
        18: .line 428
            goto 35
        19: .line 433
      StackMap locals:
      StackMap stack:
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        20: .line 432
            invokestatic sun.security.ssl.SSLKeyExchange.valueOf:(Lsun/security/ssl/CipherSuite$KeyExchange;Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/SSLKeyExchange;
            astore 7 /* ke */
        start local 7 // sun.security.ssl.SSLKeyExchange ke
        21: .line 434
            aload 7 /* ke */
            ifnonnull 23
        22: .line 435
            goto 35
        23: .line 437
      StackMap locals: sun.security.ssl.SSLKeyExchange
      StackMap stack:
            getstatic sun.security.ssl.ServerHandshakeContext.legacyAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
        24: .line 438
            aconst_null
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
            aconst_null
        25: .line 437
            invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
        26: .line 438
            ifne 29
        27: .line 439
            aload 4 /* legacySuites */
            aload 5 /* cs */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        28: .line 440
            goto 35
        29: .line 443
      StackMap locals:
      StackMap stack:
            aload 7 /* ke */
            aload 0 /* shc */
            invokevirtual sun.security.ssl.SSLKeyExchange.createPossessions:(Lsun/security/ssl/HandshakeContext;)[Lsun/security/ssl/SSLPossession;
            astore 8 /* hcds */
        start local 8 // sun.security.ssl.SSLPossession[] hcds
        30: .line 444
            aload 8 /* hcds */
            ifnull 35
            aload 8 /* hcds */
            arraylength
            ifne 32
        31: .line 445
            goto 35
        32: .line 449
      StackMap locals: sun.security.ssl.SSLPossession[]
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 34
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 34
        33: .line 450
            new java.lang.StringBuilder
            dup
            ldc "use cipher suite "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        34: .line 453
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties
            dup
            aload 5 /* cs */
            aload 7 /* ke */
            aload 8 /* hcds */
            invokespecial sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties.<init>:(Lsun/security/ssl/CipherSuite;Lsun/security/ssl/SSLKeyExchange;[Lsun/security/ssl/SSLPossession;)V
            areturn
        end local 8 // sun.security.ssl.SSLPossession[] hcds
        end local 7 // sun.security.ssl.SSLKeyExchange ke
        end local 5 // sun.security.ssl.CipherSuite cs
        35: .line 418
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage java.util.List java.util.List java.util.List top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        36: .line 456
            aload 4 /* legacySuites */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 47
      StackMap locals:
      StackMap stack:
        37: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.CipherSuite
            astore 5 /* cs */
        start local 5 // sun.security.ssl.CipherSuite cs
        38: .line 458
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        39: .line 457
            invokestatic sun.security.ssl.SSLKeyExchange.valueOf:(Lsun/security/ssl/CipherSuite$KeyExchange;Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/SSLKeyExchange;
            astore 7 /* ke */
        start local 7 // sun.security.ssl.SSLKeyExchange ke
        40: .line 459
            aload 7 /* ke */
            ifnull 47
        41: .line 460
            aload 7 /* ke */
            aload 0 /* shc */
            invokevirtual sun.security.ssl.SSLKeyExchange.createPossessions:(Lsun/security/ssl/HandshakeContext;)[Lsun/security/ssl/SSLPossession;
            astore 8 /* hcds */
        start local 8 // sun.security.ssl.SSLPossession[] hcds
        42: .line 461
            aload 8 /* hcds */
            ifnull 47
            aload 8 /* hcds */
            arraylength
            ifeq 47
        43: .line 462
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 46
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 46
        44: .line 464
            new java.lang.StringBuilder
            dup
            ldc "use legacy cipher suite "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        45: .line 463
            invokestatic sun.security.ssl.SSLLogger.warning:(Ljava/lang/String;[Ljava/lang/Object;)V
        46: .line 466
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage java.util.List java.util.List java.util.List sun.security.ssl.CipherSuite java.util.Iterator sun.security.ssl.SSLKeyExchange sun.security.ssl.SSLPossession[]
      StackMap stack:
            new sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties
            dup
            aload 5 /* cs */
            aload 7 /* ke */
            aload 8 /* hcds */
            invokespecial sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties.<init>:(Lsun/security/ssl/CipherSuite;Lsun/security/ssl/SSLKeyExchange;[Lsun/security/ssl/SSLPossession;)V
            areturn
        end local 8 // sun.security.ssl.SSLPossession[] hcds
        end local 7 // sun.security.ssl.SSLKeyExchange ke
        end local 5 // sun.security.ssl.CipherSuite cs
        47: .line 456
      StackMap locals: sun.security.ssl.ServerHandshakeContext sun.security.ssl.ClientHello$ClientHelloMessage java.util.List java.util.List java.util.List top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 37
        48: .line 471
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        49: .line 472
            ldc "no cipher suites in common"
        50: .line 471
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        end local 4 // java.util.List legacySuites
        end local 3 // java.util.List proposed
        end local 2 // java.util.List preferred
        end local 1 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
        end local 0 // sun.security.ssl.ServerHandshakeContext shc
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   51     0           shc  Lsun/security/ssl/ServerHandshakeContext;
            0   51     1   clientHello  Lsun/security/ssl/ClientHello$ClientHelloMessage;
            2    4     2     preferred  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
            5   51     2     preferred  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
            3    4     3      proposed  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
            6   51     3      proposed  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
            7   51     4  legacySuites  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
            9   35     5            cs  Lsun/security/ssl/CipherSuite;
           21   35     7            ke  Lsun/security/ssl/SSLKeyExchange;
           30   35     8          hcds  [Lsun/security/ssl/SSLPossession;
           38   47     5            cs  Lsun/security/ssl/CipherSuite;
           40   47     7            ke  Lsun/security/ssl/SSLKeyExchange;
           42   47     8          hcds  [Lsun/security/ssl/SSLPossession;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      shc          
      clientHello  
}
SourceFile: "ServerHello.java"
NestHost: sun.security.ssl.ServerHello
InnerClasses:
  public abstract Entry = java.util.Map$Entry of java.util.Map
  final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
  final ClientHelloMessage = sun.security.ssl.ClientHello$ClientHelloMessage of sun.security.ssl.ClientHello
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake
  final ServerHelloMessage = sun.security.ssl.ServerHello$ServerHelloMessage of sun.security.ssl.ServerHello
  private final T12ServerHelloProducer = sun.security.ssl.ServerHello$T12ServerHelloProducer of sun.security.ssl.ServerHello
  private final KeyExchangeProperties = sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties of sun.security.ssl.ServerHello$T12ServerHelloProducer
  final StaplingParameters = sun.security.ssl.StatusResponseManager$StaplingParameters of sun.security.ssl.StatusResponseManager