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 256
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 258
            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 264
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            astore 3 /* shc */
        start local 3 // sun.security.ssl.ServerHandshakeContext shc
         1: .line 265
            aload 2 /* message */
            checkcast sun.security.ssl.ClientHello$ClientHelloMessage
            astore 4 /* clientHello */
        start local 4 // sun.security.ssl.ClientHello$ClientHelloMessage clientHello
         2: .line 270
            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 68
         3: .line 271
      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 272
            new javax.net.ssl.SSLException
            dup
         5: .line 273
            ldc "Not resumption, and no new session is allowed"
         6: .line 272
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 276
      StackMap locals:
      StackMap stack:
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.localSupportedSignAlgs:Ljava/util/List;
            ifnonnull 12
         8: .line 277
            aload 3 /* shc */
         9: .line 279
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.algorithmConstraints:Ljava/security/AlgorithmConstraints;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.activeProtocols:Ljava/util/List;
        10: .line 278
            invokestatic sun.security.ssl.SignatureScheme.getSupportedAlgorithms:(Ljava/security/AlgorithmConstraints;Ljava/util/List;)Ljava/util/List;
        11: .line 277
            putfield sun.security.ssl.ServerHandshakeContext.localSupportedSignAlgs:Ljava/util/List;
        12: .line 283
      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
        13: .line 282
            astore 5 /* session */
        start local 5 // sun.security.ssl.SSLSessionImpl session
        14: .line 284
            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
        15: .line 285
            aload 3 /* shc */
            aload 5 /* session */
            putfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
        16: .line 289
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        17: .line 290
            getstatic sun.security.ssl.SSLHandshake.CLIENT_HELLO:Lsun/security/ssl/SSLHandshake;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        18: .line 289
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
        19: .line 288
            astore 6 /* enabledExtensions */
        start local 6 // sun.security.ssl.SSLExtension[] enabledExtensions
        20: .line 291
            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
        21: .line 295
            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;
        22: .line 294
            astore 7 /* credentials */
        start local 7 // sun.security.ssl.ServerHello$T12ServerHelloProducer$KeyExchangeProperties credentials
        23: .line 296
            aload 7 /* credentials */
            ifnonnull 27
        24: .line 297
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
        25: .line 298
            ldc "no cipher suites in common"
        26: .line 297
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
        27: .line 300
      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;
        28: .line 301
            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;
        29: .line 302
            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
        30: .line 303
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakePossessions:Ljava/util/List;
        31: .line 304
            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;
        32: .line 303
            invokeinterface java.util.List.addAll:(Ljava/util/Collection;)Z
            pop
        33: .line 305
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
        34: .line 306
            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;
        35: .line 305
            invokevirtual sun.security.ssl.HandshakeHash.determine:(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)V
        36: .line 311
            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;
        37: .line 312
            aload 3 /* shc */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.stapleParams:Lsun/security/ssl/StatusResponseManager$StaplingParameters;
            ifnull 38
            iconst_1
            goto 39
      StackMap locals:
      StackMap stack: sun.security.ssl.ServerHandshakeContext
        38: 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
        39: putfield sun.security.ssl.ServerHandshakeContext.staplingActive:Z
        40: .line 315
            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
        41: .line 316
            aload 8 /* ke */
            ifnull 49
        42: .line 318
            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 48
      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:
        43: aload 12
            iload 10
            aaload
            astore 9 /* me */
        start local 9 // java.util.Map$Entry me
        44: .line 319
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
        45: .line 320
            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
        46: .line 319
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 9 // java.util.Map$Entry me
        47: .line 317
            iinc 10 1
      StackMap locals:
      StackMap stack:
        48: iload 10
            iload 11
            if_icmplt 43
        49: .line 324
      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 64
        50: .line 325
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        51: .line 326
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
        52: .line 325
            if_acmpeq 64
        53: .line 327
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
            invokevirtual sun.security.ssl.CipherSuite.isAnonymous:()Z
            ifne 64
        54: .line 329
            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 63
      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:
        55: aload 12
            iload 10
            aaload
            astore 9 /* hs */
        start local 9 // sun.security.ssl.SSLHandshake hs
        56: .line 330
            aload 9 /* hs */
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE:Lsun/security/ssl/SSLHandshake;
            if_acmpne 62
        57: .line 331
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeProducers:Ljava/util/HashMap;
        58: .line 332
            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;
        59: .line 333
            getstatic sun.security.ssl.SSLHandshake.CERTIFICATE_REQUEST:Lsun/security/ssl/SSLHandshake;
        60: .line 331
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        61: .line 334
            goto 64
        end local 9 // sun.security.ssl.SSLHandshake hs
        62: .line 328
      StackMap locals:
      StackMap stack:
            iinc 10 1
      StackMap locals:
      StackMap stack:
        63: iload 10
            iload 11
            if_icmplt 55
        64: .line 338
      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;
        65: .line 339
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO_DONE:Lsun/security/ssl/SSLHandshake;
        66: .line 338
            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
        67: .line 340
            goto 76
        68: .line 341
      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 */
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            putfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
        69: .line 342
            aload 3 /* shc */
        70: .line 343
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getProtocolVersion:()Lsun/security/ssl/ProtocolVersion;
        71: .line 342
            putfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        72: .line 344
            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;
        73: .line 345
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeHash:Lsun/security/ssl/HandshakeHash;
        74: .line 346
            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;
        75: .line 345
            invokevirtual sun.security.ssl.HandshakeHash.determine:(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)V
        76: .line 350
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.ServerHello$ServerHelloMessage
            dup
            aload 3 /* shc */
        77: .line 351
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        78: .line 352
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getSessionId:()Lsun/security/ssl/SessionId;
        79: .line 353
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
        80: .line 354
            new sun.security.ssl.RandomCookie
            dup
            aload 3 /* shc */
            invokespecial sun.security.ssl.RandomCookie.<init>:(Lsun/security/ssl/HandshakeContext;)V
        81: .line 355
            aload 4 /* clientHello */
        82: .line 350
            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
        83: .line 356
            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;
        84: .line 360
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        85: .line 361
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO:Lsun/security/ssl/SSLHandshake;
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
        86: .line 360
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
        87: .line 359
            astore 6 /* serverHelloExtensions */
        start local 6 // sun.security.ssl.SSLExtension[] serverHelloExtensions
        88: .line 362
            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
        89: .line 363
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 91
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 91
        90: .line 364
            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
        91: .line 368
      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
        92: .line 369
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
        93: .line 371
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.isResumption:Z
            ifeq 108
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
            ifnull 108
        94: .line 373
            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;
        95: .line 372
            astore 7 /* kdg */
        start local 7 // sun.security.ssl.SSLTrafficKeyDerivation kdg
        96: .line 374
            aload 7 /* kdg */
            ifnonnull 102
        97: .line 376
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.INTERNAL_ERROR:Lsun/security/ssl/Alert;
        98: .line 377
            new java.lang.StringBuilder
            dup
            ldc "Not supported key derivation: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        99: .line 378
            aload 3 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
       100: .line 377
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
       101: .line 376
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
       102: .line 380
      StackMap locals: sun.security.ssl.SSLTrafficKeyDerivation
      StackMap stack:
            aload 3 /* shc */
            aload 7 /* kdg */
       103: .line 381
            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;
       104: .line 380
            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;
       105: .line 385
            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;
       106: .line 386
            getstatic sun.security.ssl.SSLHandshake.FINISHED:Lsun/security/ssl/SSLHandshake;
       107: .line 385
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 7 // sun.security.ssl.SSLTrafficKeyDerivation kdg
       108: .line 390
      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  109     0                   this  Lsun/security/ssl/ServerHello$T12ServerHelloProducer;
            0  109     1                context  Lsun/security/ssl/ConnectionContext;
            0  109     2                message  Lsun/security/ssl/SSLHandshake$HandshakeMessage;
            1  109     3                    shc  Lsun/security/ssl/ServerHandshakeContext;
            2  109     4            clientHello  Lsun/security/ssl/ClientHello$ClientHelloMessage;
           14   67     5                session  Lsun/security/ssl/SSLSessionImpl;
           20   67     6      enabledExtensions  [Lsun/security/ssl/SSLExtension;
           23   67     7            credentials  Lsun/security/ssl/ServerHello$T12ServerHelloProducer$KeyExchangeProperties;
           41   67     8                     ke  Lsun/security/ssl/SSLKeyExchange;
           44   47     9                     me  Ljava/util/Map$Entry<Ljava/lang/Byte;Lsun/security/ssl/HandshakeProducer;>;
           56   62     9                     hs  Lsun/security/ssl/SSLHandshake;
           83  109     5                    shm  Lsun/security/ssl/ServerHello$ServerHelloMessage;
           88  109     6  serverHelloExtensions  [Lsun/security/ssl/SSLExtension;
           96  108     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 398
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
            ifeq 4
         1: .line 399
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.activeCipherSuites:Ljava/util/List;
            astore 2 /* preferred */
        start local 2 // java.util.List preferred
         2: .line 400
            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 401
            goto 6
        end local 3 // java.util.List proposed
        end local 2 // java.util.List preferred
         4: .line 402
      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 403
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.activeCipherSuites:Ljava/util/List;
            astore 3 /* proposed */
        start local 3 // java.util.List proposed
         6: .line 406
      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 407
            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 409
            aload 3 /* proposed */
            aload 0 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            aload 5 /* cs */
        10: .line 408
            invokestatic sun.security.ssl.HandshakeContext.isNegotiable:(Ljava/util/List;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;)Z
        11: .line 409
            ifne 13
        12: .line 410
            goto 35
        13: .line 413
      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 414
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUIRED:Lsun/security/ssl/ClientAuthType;
        15: .line 413
            if_acmpne 19
        16: .line 415
            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 416
            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 417
            goto 35
        19: .line 422
      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 421
            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 423
            aload 7 /* ke */
            ifnonnull 23
        22: .line 424
            goto 35
        23: .line 426
      StackMap locals: sun.security.ssl.SSLKeyExchange
      StackMap stack:
            getstatic sun.security.ssl.ServerHandshakeContext.legacyAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
        24: .line 427
            aconst_null
            aload 5 /* cs */
            getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
            aconst_null
        25: .line 426
            invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
        26: .line 427
            ifne 29
        27: .line 428
            aload 4 /* legacySuites */
            aload 5 /* cs */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        28: .line 429
            goto 35
        29: .line 432
      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 433
            aload 8 /* hcds */
            ifnull 35
            aload 8 /* hcds */
            arraylength
            ifne 32
        31: .line 434
            goto 35
        32: .line 438
      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 439
            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 442
      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 407
      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 445
            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 447
            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 446
            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 448
            aload 7 /* ke */
            ifnull 47
        41: .line 449
            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 450
            aload 8 /* hcds */
            ifnull 47
            aload 8 /* hcds */
            arraylength
            ifeq 47
        43: .line 451
            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 453
            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 452
            invokestatic sun.security.ssl.SSLLogger.warning:(Ljava/lang/String;[Ljava/lang/Object;)V
        46: .line 455
      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 445
      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 460
            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 461
            ldc "no cipher suites in common"
        50: .line 460
            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