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

  public byte[] produce(sun.security.ssl.ConnectionContext);
    descriptor: (Lsun/security/ssl/ConnectionContext;)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=16, args_size=2
        start local 0 // sun.security.ssl.ClientHello$ClientHelloKickstartProducer this
        start local 1 // sun.security.ssl.ConnectionContext context
         0: .line 401
            aload 1 /* context */
            checkcast sun.security.ssl.ClientHandshakeContext
            astore 2 /* chc */
        start local 2 // sun.security.ssl.ClientHandshakeContext chc
         1: .line 404
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeProducers:Ljava/util/HashMap;
            getstatic sun.security.ssl.SSLHandshake.CLIENT_HELLO:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
            invokevirtual java.util.HashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 407
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.maximumActiveProtocol:Lsun/security/ssl/ProtocolVersion;
            astore 3 /* maxProtocolVersion */
        start local 3 // sun.security.ssl.ProtocolVersion maxProtocolVersion
         3: .line 410
            getstatic sun.security.ssl.SSLSessionImpl.nullSession:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getSessionId:()Lsun/security/ssl/SessionId;
            astore 4 /* sessionId */
        start local 4 // sun.security.ssl.SessionId sessionId
         4: .line 413
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.activeCipherSuites:Ljava/util/List;
            astore 5 /* cipherSuites */
        start local 5 // java.util.List cipherSuites
         5: .line 419
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.engineGetClientSessionContext:()Ljavax/net/ssl/SSLSessionContext;
         6: .line 418
            checkcast sun.security.ssl.SSLSessionContextImpl
            astore 6 /* ssci */
        start local 6 // sun.security.ssl.SSLSessionContextImpl ssci
         7: .line 420
            aload 6 /* ssci */
         8: .line 421
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            invokeinterface sun.security.ssl.SSLTransport.getPeerHost:()Ljava/lang/String;
         9: .line 422
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            invokeinterface sun.security.ssl.SSLTransport.getPeerPort:()I
        10: .line 420
            invokevirtual sun.security.ssl.SSLSessionContextImpl.get:(Ljava/lang/String;I)Lsun/security/ssl/SSLSessionImpl;
            astore 7 /* session */
        start local 7 // sun.security.ssl.SSLSessionImpl session
        11: .line 423
            aload 7 /* session */
            ifnull 25
        12: .line 427
            getstatic sun.security.ssl.ClientHandshakeContext.allowUnsafeServerCertChange:Z
            ifne 19
        13: .line 428
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.isSessionResumption:()Z
            ifeq 19
        14: .line 431
            aload 2 /* chc */
        15: .line 432
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getPeerCertificates:()[Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate[]
        16: .line 431
            putfield sun.security.ssl.ClientHandshakeContext.reservedServerCerts:[Ljava/security/cert/X509Certificate;
        17: .line 433
            goto 19
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloKickstartProducer sun.security.ssl.ConnectionContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId java.util.List sun.security.ssl.SSLSessionContextImpl sun.security.ssl.SSLSessionImpl
      StackMap stack: javax.net.ssl.SSLPeerUnverifiedException
        18: pop
        19: .line 438
      StackMap locals:
      StackMap stack:
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.isRejoinable:()Z
            ifne 25
        20: .line 439
            aconst_null
            astore 7 /* session */
        21: .line 440
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 25
        22: .line 441
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 25
        23: .line 443
            ldc "Can't resume, the session is not rejoinable"
            iconst_0
            anewarray java.lang.Object
        24: .line 442
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        25: .line 448
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* sessionSuite */
        start local 8 // sun.security.ssl.CipherSuite sessionSuite
        26: .line 449
            aload 7 /* session */
            ifnull 34
        27: .line 450
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getSuite:()Lsun/security/ssl/CipherSuite;
            astore 8 /* sessionSuite */
        28: .line 451
            aload 2 /* chc */
            aload 8 /* sessionSuite */
            invokevirtual sun.security.ssl.ClientHandshakeContext.isNegotiable:(Lsun/security/ssl/CipherSuite;)Z
            ifne 34
        29: .line 452
            aconst_null
            astore 7 /* session */
        30: .line 453
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 34
        31: .line 454
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 34
        32: .line 456
            ldc "Can't resume, unavailable session cipher suite"
            iconst_0
            anewarray java.lang.Object
        33: .line 455
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        34: .line 461
      StackMap locals: sun.security.ssl.CipherSuite
      StackMap stack:
            aconst_null
            astore 9 /* sessionVersion */
        start local 9 // sun.security.ssl.ProtocolVersion sessionVersion
        35: .line 462
            aload 7 /* session */
            ifnull 43
        36: .line 463
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getProtocolVersion:()Lsun/security/ssl/ProtocolVersion;
            astore 9 /* sessionVersion */
        37: .line 464
            aload 2 /* chc */
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ClientHandshakeContext.isNegotiable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifne 43
        38: .line 465
            aconst_null
            astore 7 /* session */
        39: .line 466
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 43
        40: .line 467
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 43
        41: .line 469
            ldc "Can't resume, unavailable protocol version"
            iconst_0
            anewarray java.lang.Object
        42: .line 468
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        43: .line 474
      StackMap locals: sun.security.ssl.ProtocolVersion
      StackMap stack:
            aload 7 /* session */
            ifnull 61
        44: .line 475
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 61
        45: .line 476
            getstatic sun.security.ssl.SSLConfiguration.useExtendedMasterSecret:Z
            ifeq 61
        46: .line 478
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        47: .line 479
            getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
            aload 9 /* sessionVersion */
        48: .line 478
            invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;Lsun/security/ssl/ProtocolVersion;)Z
            istore 10 /* isEmsAvailable */
        start local 10 // boolean isEmsAvailable
        49: .line 480
            iload 10 /* isEmsAvailable */
            ifeq 52
            aload 7 /* session */
            getfield sun.security.ssl.SSLSessionImpl.useExtendedMasterSecret:Z
            ifne 52
        50: .line 481
            getstatic sun.security.ssl.SSLConfiguration.allowLegacyResumption:Z
            ifne 52
        51: .line 488
            aconst_null
            astore 7 /* session */
        52: .line 491
      StackMap locals: int
      StackMap stack:
            aload 7 /* session */
            ifnull 61
        53: .line 492
            getstatic sun.security.ssl.ClientHandshakeContext.allowUnsafeServerCertChange:Z
            ifne 61
        54: .line 495
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
            astore 11 /* identityAlg */
        start local 11 // java.lang.String identityAlg
        55: .line 496
            aload 11 /* identityAlg */
            ifnull 56
            aload 11 /* identityAlg */
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 61
        56: .line 497
      StackMap locals: java.lang.String
      StackMap stack:
            iload 10 /* isEmsAvailable */
            ifeq 60
        57: .line 498
            aload 7 /* session */
            getfield sun.security.ssl.SSLSessionImpl.useExtendedMasterSecret:Z
            ifne 61
        58: .line 500
            aconst_null
            astore 7 /* session */
        59: .line 502
            goto 61
        60: .line 510
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 7 /* session */
        end local 11 // java.lang.String identityAlg
        end local 10 // boolean isEmsAvailable
        61: .line 518
      StackMap locals:
      StackMap stack:
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
            astore 10 /* identityAlg */
        start local 10 // java.lang.String identityAlg
        62: .line 519
            aload 7 /* session */
            ifnull 72
            aload 10 /* identityAlg */
            ifnull 72
        63: .line 521
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getIdentificationProtocol:()Ljava/lang/String;
        64: .line 520
            astore 11 /* sessionIdentityAlg */
        start local 11 // java.lang.String sessionIdentityAlg
        65: .line 522
            aload 10 /* identityAlg */
            aload 11 /* sessionIdentityAlg */
            invokestatic java.util.Objects.equals:(Ljava/lang/Object;Ljava/lang/Object;)Z
            ifne 72
        66: .line 523
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 71
        67: .line 524
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 71
        68: .line 525
            new java.lang.StringBuilder
            dup
            ldc "Can't resume, endpoint id algorithm does not match, requested: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        69: .line 527
            aload 10 /* identityAlg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ", cached: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 11 /* sessionIdentityAlg */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        70: .line 525
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        71: .line 529
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
            aconst_null
            astore 7 /* session */
        end local 11 // java.lang.String sessionIdentityAlg
        72: .line 533
      StackMap locals:
      StackMap stack:
            aload 7 /* session */
            ifnull 99
        73: .line 534
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 75
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 75
        74: .line 535
            ldc "Try resuming session"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 7 /* session */
            aastore
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        75: .line 539
      StackMap locals:
      StackMap stack:
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getProtocolVersion:()Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 77
        76: .line 540
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getSessionId:()Lsun/security/ssl/SessionId;
            astore 4 /* sessionId */
        77: .line 542
      StackMap locals:
      StackMap stack:
            aload 3 /* maxProtocolVersion */
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.equals:(Ljava/lang/Object;)Z
            ifne 80
        78: .line 543
            aload 9 /* sessionVersion */
            astore 3 /* maxProtocolVersion */
        79: .line 548
            aload 2 /* chc */
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ClientHandshakeContext.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
        80: .line 554
      StackMap locals:
      StackMap stack:
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.enableSessionCreation:Z
            ifne 97
        81: .line 555
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.isNegotiated:Z
            ifne 91
        82: .line 556
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 91
        83: .line 557
            aload 5 /* cipherSuites */
        84: .line 558
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
        85: .line 557
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
        86: .line 558
            ifeq 91
        87: .line 559
            iconst_2
            anewarray sun.security.ssl.CipherSuite
            dup
            iconst_0
            aload 8 /* sessionSuite */
            aastore
            dup
            iconst_1
        88: .line 560
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
            aastore
        89: .line 559
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            astore 5 /* cipherSuites */
        90: .line 561
            goto 92
        91: .line 562
      StackMap locals:
      StackMap stack:
            iconst_1
            anewarray sun.security.ssl.CipherSuite
            dup
            iconst_0
            aload 8 /* sessionSuite */
            aastore
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            astore 5 /* cipherSuites */
        92: .line 565
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 97
        93: .line 566
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 97
        94: .line 568
            ldc "No new session is allowed, so try to resume the session cipher suite only"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
        95: .line 569
            aload 8 /* sessionSuite */
            aastore
        96: .line 567
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        97: .line 573
      StackMap locals:
      StackMap stack:
            aload 2 /* chc */
            iconst_1
            putfield sun.security.ssl.ClientHandshakeContext.isResumption:Z
        98: .line 574
            aload 2 /* chc */
            aload 7 /* session */
            putfield sun.security.ssl.ClientHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
        99: .line 577
      StackMap locals:
      StackMap stack:
            aload 7 /* session */
            ifnonnull 108
       100: .line 578
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.enableSessionCreation:Z
            ifne 104
       101: .line 579
            new javax.net.ssl.SSLHandshakeException
            dup
       102: .line 580
            ldc "No new session is allowed and no existing session can be resumed"
       103: .line 579
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            athrow
       104: .line 584
      StackMap locals:
      StackMap stack:
            aload 3 /* maxProtocolVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifeq 108
       105: .line 585
            getstatic sun.security.ssl.SSLConfiguration.useCompatibilityMode:Z
            ifeq 108
       106: .line 590
            new sun.security.ssl.SessionId
            dup
            iconst_1
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
            invokespecial sun.security.ssl.SessionId.<init>:(ZLjava/security/SecureRandom;)V
       107: .line 589
            astore 4 /* sessionId */
       108: .line 594
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            astore 11 /* minimumVersion */
        start local 11 // sun.security.ssl.ProtocolVersion minimumVersion
       109: .line 595
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.activeProtocols:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 13
            goto 114
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloKickstartProducer sun.security.ssl.ConnectionContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId java.util.List sun.security.ssl.SSLSessionContextImpl sun.security.ssl.SSLSessionImpl sun.security.ssl.CipherSuite sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.ProtocolVersion top java.util.Iterator
      StackMap stack:
       110: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 12 /* pv */
        start local 12 // sun.security.ssl.ProtocolVersion pv
       111: .line 596
            aload 11 /* minimumVersion */
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            if_acmpeq 113
       112: .line 597
            aload 12 /* pv */
            aload 11 /* minimumVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.compare:(Lsun/security/ssl/ProtocolVersion;)I
            ifge 114
       113: .line 598
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloKickstartProducer sun.security.ssl.ConnectionContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId java.util.List sun.security.ssl.SSLSessionContextImpl sun.security.ssl.SSLSessionImpl sun.security.ssl.CipherSuite sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.util.Iterator
      StackMap stack:
            aload 12 /* pv */
            astore 11 /* minimumVersion */
        end local 12 // sun.security.ssl.ProtocolVersion pv
       114: .line 595
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloKickstartProducer sun.security.ssl.ConnectionContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId java.util.List sun.security.ssl.SSLSessionContextImpl sun.security.ssl.SSLSessionImpl sun.security.ssl.CipherSuite sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.ProtocolVersion top java.util.Iterator
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 110
       115: .line 603
            aload 11 /* minimumVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 125
       116: .line 604
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.secureRenegotiation:Z
            ifeq 125
       117: .line 605
            aload 5 /* cipherSuites */
       118: .line 606
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
       119: .line 605
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
       120: .line 606
            ifeq 125
       121: .line 608
            new java.util.LinkedList
            dup
            aload 5 /* cipherSuites */
            invokespecial java.util.LinkedList.<init>:(Ljava/util/Collection;)V
            astore 5 /* cipherSuites */
       122: .line 609
            aload 5 /* cipherSuites */
       123: .line 610
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
       124: .line 609
            invokeinterface java.util.List.remove:(Ljava/lang/Object;)Z
            pop
       125: .line 615
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloKickstartProducer sun.security.ssl.ConnectionContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId java.util.List sun.security.ssl.SSLSessionContextImpl sun.security.ssl.SSLSessionImpl sun.security.ssl.CipherSuite sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.ProtocolVersion
      StackMap stack:
            iconst_0
            istore 12 /* negotiable */
        start local 12 // boolean negotiable
       126: .line 616
            aload 5 /* cipherSuites */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 14
            goto 131
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloKickstartProducer sun.security.ssl.ConnectionContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId java.util.List sun.security.ssl.SSLSessionContextImpl sun.security.ssl.SSLSessionImpl sun.security.ssl.CipherSuite sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.ProtocolVersion int top java.util.Iterator
      StackMap stack:
       127: aload 14
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.CipherSuite
            astore 13 /* suite */
        start local 13 // sun.security.ssl.CipherSuite suite
       128: .line 617
            aload 2 /* chc */
            aload 13 /* suite */
            invokevirtual sun.security.ssl.ClientHandshakeContext.isNegotiable:(Lsun/security/ssl/CipherSuite;)Z
            ifeq 131
       129: .line 618
            iconst_1
            istore 12 /* negotiable */
       130: .line 619
            goto 132
        end local 13 // sun.security.ssl.CipherSuite suite
       131: .line 616
      StackMap locals:
      StackMap stack:
            aload 14
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 127
       132: .line 622
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloKickstartProducer sun.security.ssl.ConnectionContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId java.util.List sun.security.ssl.SSLSessionContextImpl sun.security.ssl.SSLSessionImpl sun.security.ssl.CipherSuite sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.ProtocolVersion int
      StackMap stack:
            iload 12 /* negotiable */
            ifne 134
       133: .line 623
            new javax.net.ssl.SSLHandshakeException
            dup
            ldc "No negotiable cipher suite"
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            athrow
       134: .line 627
      StackMap locals:
      StackMap stack:
            aload 3 /* maxProtocolVersion */
            astore 13 /* clientHelloVersion */
        start local 13 // sun.security.ssl.ProtocolVersion clientHelloVersion
       135: .line 628
            aload 13 /* clientHelloVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifeq 140
       136: .line 632
            aload 13 /* clientHelloVersion */
            getfield sun.security.ssl.ProtocolVersion.isDTLS:Z
            ifeq 139
       137: .line 633
            getstatic sun.security.ssl.ProtocolVersion.DTLS12:Lsun/security/ssl/ProtocolVersion;
            astore 13 /* clientHelloVersion */
       138: .line 634
            goto 140
       139: .line 635
      StackMap locals: sun.security.ssl.ProtocolVersion
      StackMap stack:
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            astore 13 /* clientHelloVersion */
       140: .line 639
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.ClientHello$ClientHelloMessage
            dup
            aload 2 /* chc */
       141: .line 640
            aload 13 /* clientHelloVersion */
            getfield sun.security.ssl.ProtocolVersion.id:I
            aload 4 /* sessionId */
            aload 5 /* cipherSuites */
       142: .line 641
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
       143: .line 639
            invokespecial sun.security.ssl.ClientHello$ClientHelloMessage.<init>:(Lsun/security/ssl/HandshakeContext;ILsun/security/ssl/SessionId;Ljava/util/List;Ljava/security/SecureRandom;)V
            astore 14 /* chm */
        start local 14 // sun.security.ssl.ClientHello$ClientHelloMessage chm
       144: .line 644
            aload 2 /* chc */
            aload 14 /* chm */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.clientRandom:Lsun/security/ssl/RandomCookie;
            putfield sun.security.ssl.ClientHandshakeContext.clientHelloRandom:Lsun/security/ssl/RandomCookie;
       145: .line 645
            aload 2 /* chc */
            aload 13 /* clientHelloVersion */
            getfield sun.security.ssl.ProtocolVersion.id:I
            putfield sun.security.ssl.ClientHandshakeContext.clientHelloVersion:I
       146: .line 648
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
       147: .line 649
            getstatic sun.security.ssl.SSLHandshake.CLIENT_HELLO:Lsun/security/ssl/SSLHandshake;
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.activeProtocols:Ljava/util/List;
       148: .line 648
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Ljava/util/List;)[Lsun/security/ssl/SSLExtension;
            astore 15 /* extTypes */
        start local 15 // sun.security.ssl.SSLExtension[] extTypes
       149: .line 650
            aload 14 /* chm */
            getfield sun.security.ssl.ClientHello$ClientHelloMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 2 /* chc */
            aload 15 /* extTypes */
            invokevirtual sun.security.ssl.SSLExtensions.produce:(Lsun/security/ssl/HandshakeContext;[Lsun/security/ssl/SSLExtension;)V
       150: .line 652
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 152
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 152
       151: .line 653
            ldc "Produced ClientHello handshake message"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 14 /* chm */
            aastore
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
       152: .line 657
      StackMap locals: sun.security.ssl.ClientHello$ClientHelloMessage sun.security.ssl.SSLExtension[]
      StackMap stack:
            aload 14 /* chm */
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.ClientHello$ClientHelloMessage.write:(Lsun/security/ssl/HandshakeOutStream;)V
       153: .line 658
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
       154: .line 662
            aload 2 /* chc */
            aload 14 /* chm */
            putfield sun.security.ssl.ClientHandshakeContext.initialClientHelloMsg:Lsun/security/ssl/ClientHello$ClientHelloMessage;
       155: .line 665
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
       156: .line 666
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
            getstatic sun.security.ssl.SSLHandshake.SERVER_HELLO:Lsun/security/ssl/SSLHandshake;
       157: .line 665
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
       158: .line 667
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.isDTLS:()Z
            ifeq 164
       159: .line 668
            aload 11 /* minimumVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 164
       160: .line 669
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
       161: .line 670
            getstatic sun.security.ssl.SSLHandshake.HELLO_VERIFY_REQUEST:Lsun/security/ssl/SSLHandshake;
            getfield sun.security.ssl.SSLHandshake.id:B
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
       162: .line 671
            getstatic sun.security.ssl.SSLHandshake.HELLO_VERIFY_REQUEST:Lsun/security/ssl/SSLHandshake;
       163: .line 669
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
       164: .line 675
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 15 // sun.security.ssl.SSLExtension[] extTypes
        end local 14 // sun.security.ssl.ClientHello$ClientHelloMessage chm
        end local 13 // sun.security.ssl.ProtocolVersion clientHelloVersion
        end local 12 // boolean negotiable
        end local 11 // sun.security.ssl.ProtocolVersion minimumVersion
        end local 10 // java.lang.String identityAlg
        end local 9 // sun.security.ssl.ProtocolVersion sessionVersion
        end local 8 // sun.security.ssl.CipherSuite sessionSuite
        end local 7 // sun.security.ssl.SSLSessionImpl session
        end local 6 // sun.security.ssl.SSLSessionContextImpl ssci
        end local 5 // java.util.List cipherSuites
        end local 4 // sun.security.ssl.SessionId sessionId
        end local 3 // sun.security.ssl.ProtocolVersion maxProtocolVersion
        end local 2 // sun.security.ssl.ClientHandshakeContext chc
        end local 1 // sun.security.ssl.ConnectionContext context
        end local 0 // sun.security.ssl.ClientHello$ClientHelloKickstartProducer this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0  165     0                this  Lsun/security/ssl/ClientHello$ClientHelloKickstartProducer;
            0  165     1             context  Lsun/security/ssl/ConnectionContext;
            1  165     2                 chc  Lsun/security/ssl/ClientHandshakeContext;
            3  165     3  maxProtocolVersion  Lsun/security/ssl/ProtocolVersion;
            4  165     4           sessionId  Lsun/security/ssl/SessionId;
            5  165     5        cipherSuites  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
            7  165     6                ssci  Lsun/security/ssl/SSLSessionContextImpl;
           11  165     7             session  Lsun/security/ssl/SSLSessionImpl;
           26  165     8        sessionSuite  Lsun/security/ssl/CipherSuite;
           35  165     9      sessionVersion  Lsun/security/ssl/ProtocolVersion;
           49   61    10      isEmsAvailable  Z
           55   61    11         identityAlg  Ljava/lang/String;
           62  165    10         identityAlg  Ljava/lang/String;
           65   72    11  sessionIdentityAlg  Ljava/lang/String;
          109  165    11      minimumVersion  Lsun/security/ssl/ProtocolVersion;
          111  114    12                  pv  Lsun/security/ssl/ProtocolVersion;
          126  165    12          negotiable  Z
          128  131    13               suite  Lsun/security/ssl/CipherSuite;
          135  165    13  clientHelloVersion  Lsun/security/ssl/ProtocolVersion;
          144  165    14                 chm  Lsun/security/ssl/ClientHello$ClientHelloMessage;
          149  165    15            extTypes  [Lsun/security/ssl/SSLExtension;
      Exception table:
        from    to  target  type
          14    17      18  Class javax.net.ssl.SSLPeerUnverifiedException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      context  
}
SourceFile: "ClientHello.java"
NestHost: sun.security.ssl.ClientHello
InnerClasses:
  private final ClientHelloKickstartProducer = sun.security.ssl.ClientHello$ClientHelloKickstartProducer of sun.security.ssl.ClientHello
  final ClientHelloMessage = sun.security.ssl.ClientHello$ClientHelloMessage of sun.security.ssl.ClientHello