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 319
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 321
            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 327
            aload 1 /* context */
            checkcast sun.security.ssl.ClientHandshakeContext
            astore 2 /* chc */
        start local 2 // sun.security.ssl.ClientHandshakeContext chc
         1: .line 330
            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 333
            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 336
            new sun.security.ssl.SessionId
            dup
            iconst_0
            newarray 8
            invokespecial sun.security.ssl.SessionId.<init>:([B)V
            astore 4 /* sessionId */
        start local 4 // sun.security.ssl.SessionId sessionId
         4: .line 339
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.activeCipherSuites:Ljava/util/List;
            astore 5 /* cipherSuites */
        start local 5 // java.util.List cipherSuites
         5: .line 345
            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 344
            checkcast sun.security.ssl.SSLSessionContextImpl
            astore 6 /* ssci */
        start local 6 // sun.security.ssl.SSLSessionContextImpl ssci
         7: .line 346
            aload 6 /* ssci */
         8: .line 347
            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 348
            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 346
            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 349
            aload 7 /* session */
            ifnull 25
        12: .line 353
            getstatic sun.security.ssl.ClientHandshakeContext.allowUnsafeServerCertChange:Z
            ifne 19
        13: .line 354
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.isSessionResumption:()Z
            ifeq 19
        14: .line 357
            aload 2 /* chc */
        15: .line 358
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getPeerCertificates:()[Ljava/security/cert/Certificate;
            checkcast java.security.cert.X509Certificate[]
        16: .line 357
            putfield sun.security.ssl.ClientHandshakeContext.reservedServerCerts:[Ljava/security/cert/X509Certificate;
        17: .line 359
            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 364
      StackMap locals:
      StackMap stack:
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.isRejoinable:()Z
            ifne 25
        20: .line 365
            aconst_null
            astore 7 /* session */
        21: .line 366
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 25
        22: .line 367
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 25
        23: .line 369
            ldc "Can't resume, the session is not rejoinable"
            iconst_0
            anewarray java.lang.Object
        24: .line 368
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        25: .line 374
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 8 /* sessionSuite */
        start local 8 // sun.security.ssl.CipherSuite sessionSuite
        26: .line 375
            aload 7 /* session */
            ifnull 34
        27: .line 376
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getSuite:()Lsun/security/ssl/CipherSuite;
            astore 8 /* sessionSuite */
        28: .line 377
            aload 2 /* chc */
            aload 8 /* sessionSuite */
            invokevirtual sun.security.ssl.ClientHandshakeContext.isNegotiable:(Lsun/security/ssl/CipherSuite;)Z
            ifne 34
        29: .line 378
            aconst_null
            astore 7 /* session */
        30: .line 379
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 34
        31: .line 380
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 34
        32: .line 382
            ldc "Can't resume, unavailable session cipher suite"
            iconst_0
            anewarray java.lang.Object
        33: .line 381
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        34: .line 387
      StackMap locals: sun.security.ssl.CipherSuite
      StackMap stack:
            aconst_null
            astore 9 /* sessionVersion */
        start local 9 // sun.security.ssl.ProtocolVersion sessionVersion
        35: .line 388
            aload 7 /* session */
            ifnull 43
        36: .line 389
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getProtocolVersion:()Lsun/security/ssl/ProtocolVersion;
            astore 9 /* sessionVersion */
        37: .line 390
            aload 2 /* chc */
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ClientHandshakeContext.isNegotiable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifne 43
        38: .line 391
            aconst_null
            astore 7 /* session */
        39: .line 392
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 43
        40: .line 393
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 43
        41: .line 395
            ldc "Can't resume, unavailable protocol version"
            iconst_0
            anewarray java.lang.Object
        42: .line 394
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        43: .line 400
      StackMap locals: sun.security.ssl.ProtocolVersion
      StackMap stack:
            aload 7 /* session */
            ifnull 61
        44: .line 401
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 61
        45: .line 402
            getstatic sun.security.ssl.SSLConfiguration.useExtendedMasterSecret:Z
            ifeq 61
        46: .line 404
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
        47: .line 405
            getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
            aload 9 /* sessionVersion */
        48: .line 404
            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 406
            iload 10 /* isEmsAvailable */
            ifeq 52
            aload 7 /* session */
            getfield sun.security.ssl.SSLSessionImpl.useExtendedMasterSecret:Z
            ifne 52
        50: .line 407
            getstatic sun.security.ssl.SSLConfiguration.allowLegacyResumption:Z
            ifne 52
        51: .line 414
            aconst_null
            astore 7 /* session */
        52: .line 417
      StackMap locals: int
      StackMap stack:
            aload 7 /* session */
            ifnull 61
        53: .line 418
            getstatic sun.security.ssl.ClientHandshakeContext.allowUnsafeServerCertChange:Z
            ifne 61
        54: .line 421
            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 422
            aload 11 /* identityAlg */
            ifnull 56
            aload 11 /* identityAlg */
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 61
        56: .line 423
      StackMap locals: java.lang.String
      StackMap stack:
            iload 10 /* isEmsAvailable */
            ifeq 60
        57: .line 424
            aload 7 /* session */
            getfield sun.security.ssl.SSLSessionImpl.useExtendedMasterSecret:Z
            ifne 61
        58: .line 426
            aconst_null
            astore 7 /* session */
        59: .line 428
            goto 61
        60: .line 436
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 7 /* session */
        end local 11 // java.lang.String identityAlg
        end local 10 // boolean isEmsAvailable
        61: .line 444
      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 445
            aload 7 /* session */
            ifnull 72
            aload 10 /* identityAlg */
            ifnull 72
        63: .line 447
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getIdentificationProtocol:()Ljava/lang/String;
        64: .line 446
            astore 11 /* sessionIdentityAlg */
        start local 11 // java.lang.String sessionIdentityAlg
        65: .line 448
            aload 10 /* identityAlg */
            aload 11 /* sessionIdentityAlg */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 72
        66: .line 449
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 71
        67: .line 450
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 71
        68: .line 451
            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 453
            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 451
            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 455
      StackMap locals: java.lang.String java.lang.String
      StackMap stack:
            aconst_null
            astore 7 /* session */
        end local 11 // java.lang.String sessionIdentityAlg
        72: .line 459
      StackMap locals:
      StackMap stack:
            aload 7 /* session */
            ifnull 99
        73: .line 460
            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 461
            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 465
      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 466
            aload 7 /* session */
            invokevirtual sun.security.ssl.SSLSessionImpl.getSessionId:()Lsun/security/ssl/SessionId;
            astore 4 /* sessionId */
        77: .line 468
      StackMap locals:
      StackMap stack:
            aload 3 /* maxProtocolVersion */
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.equals:(Ljava/lang/Object;)Z
            ifne 80
        78: .line 469
            aload 9 /* sessionVersion */
            astore 3 /* maxProtocolVersion */
        79: .line 474
            aload 2 /* chc */
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ClientHandshakeContext.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
        80: .line 480
      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 481
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.isNegotiated:Z
            ifne 91
        82: .line 482
            aload 9 /* sessionVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 91
        83: .line 483
            aload 5 /* cipherSuites */
        84: .line 484
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
        85: .line 483
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
        86: .line 484
            ifeq 91
        87: .line 485
            iconst_2
            anewarray sun.security.ssl.CipherSuite
            dup
            iconst_0
            aload 8 /* sessionSuite */
            aastore
            dup
            iconst_1
        88: .line 486
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
            aastore
        89: .line 485
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            astore 5 /* cipherSuites */
        90: .line 487
            goto 92
        91: .line 488
      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 491
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 97
        93: .line 492
            ldc "ssl,handshake,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 97
        94: .line 494
            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 495
            aload 8 /* sessionSuite */
            aastore
        96: .line 493
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        97: .line 499
      StackMap locals:
      StackMap stack:
            aload 2 /* chc */
            iconst_1
            putfield sun.security.ssl.ClientHandshakeContext.isResumption:Z
        98: .line 500
            aload 2 /* chc */
            aload 7 /* session */
            putfield sun.security.ssl.ClientHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
        99: .line 503
      StackMap locals:
      StackMap stack:
            aload 7 /* session */
            ifnonnull 108
       100: .line 504
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.enableSessionCreation:Z
            ifne 104
       101: .line 505
            new javax.net.ssl.SSLHandshakeException
            dup
       102: .line 506
            ldc "No new session is allowed and no existing session can be resumed"
       103: .line 505
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            athrow
       104: .line 510
      StackMap locals:
      StackMap stack:
            aload 3 /* maxProtocolVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifeq 108
       105: .line 511
            getstatic sun.security.ssl.SSLConfiguration.useCompatibilityMode:Z
            ifeq 108
       106: .line 516
            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 515
            astore 4 /* sessionId */
       108: .line 520
      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 521
            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 522
            aload 11 /* minimumVersion */
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            if_acmpeq 113
       112: .line 523
            aload 12 /* pv */
            aload 11 /* minimumVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.compare:(Lsun/security/ssl/ProtocolVersion;)I
            ifge 114
       113: .line 524
      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 521
      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 529
            aload 11 /* minimumVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 125
       116: .line 530
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.secureRenegotiation:Z
            ifeq 125
       117: .line 531
            aload 5 /* cipherSuites */
       118: .line 532
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
       119: .line 531
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
       120: .line 532
            ifeq 125
       121: .line 534
            new java.util.LinkedList
            dup
            aload 5 /* cipherSuites */
            invokespecial java.util.LinkedList.<init>:(Ljava/util/Collection;)V
            astore 5 /* cipherSuites */
       122: .line 535
            aload 5 /* cipherSuites */
       123: .line 536
            getstatic sun.security.ssl.CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV:Lsun/security/ssl/CipherSuite;
       124: .line 535
            invokeinterface java.util.List.remove:(Ljava/lang/Object;)Z
            pop
       125: .line 541
      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 542
            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 543
            aload 2 /* chc */
            aload 13 /* suite */
            invokevirtual sun.security.ssl.ClientHandshakeContext.isNegotiable:(Lsun/security/ssl/CipherSuite;)Z
            ifeq 131
       129: .line 544
            iconst_1
            istore 12 /* negotiable */
       130: .line 545
            goto 132
        end local 13 // sun.security.ssl.CipherSuite suite
       131: .line 542
      StackMap locals:
      StackMap stack:
            aload 14
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 127
       132: .line 548
      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 549
            new javax.net.ssl.SSLHandshakeException
            dup
            ldc "No negotiable cipher suite"
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            athrow
       134: .line 553
      StackMap locals:
      StackMap stack:
            aload 3 /* maxProtocolVersion */
            astore 13 /* clientHelloVersion */
        start local 13 // sun.security.ssl.ProtocolVersion clientHelloVersion
       135: .line 554
            aload 13 /* clientHelloVersion */
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifeq 137
       136: .line 558
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            astore 13 /* clientHelloVersion */
       137: .line 561
      StackMap locals: sun.security.ssl.ProtocolVersion
      StackMap stack:
            new sun.security.ssl.ClientHello$ClientHelloMessage
            dup
            aload 2 /* chc */
       138: .line 562
            aload 13 /* clientHelloVersion */
            getfield sun.security.ssl.ProtocolVersion.id:I
            aload 4 /* sessionId */
            aload 5 /* cipherSuites */
       139: .line 563
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
       140: .line 561
            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
       141: .line 566
            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;
       142: .line 567
            aload 2 /* chc */
            aload 13 /* clientHelloVersion */
            getfield sun.security.ssl.ProtocolVersion.id:I
            putfield sun.security.ssl.ClientHandshakeContext.clientHelloVersion:I
       143: .line 570
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
       144: .line 571
            getstatic sun.security.ssl.SSLHandshake.CLIENT_HELLO:Lsun/security/ssl/SSLHandshake;
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.activeProtocols:Ljava/util/List;
       145: .line 570
            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
       146: .line 572
            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
       147: .line 574
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 149
            ldc "ssl,handshake"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 149
       148: .line 575
            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
       149: .line 579
      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
       150: .line 580
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeOutput:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
       151: .line 584
            aload 2 /* chc */
            aload 14 /* chm */
            putfield sun.security.ssl.ClientHandshakeContext.initialClientHelloMsg:Lsun/security/ssl/ClientHello$ClientHelloMessage;
       152: .line 587
            aload 2 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
       153: .line 588
            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;
       154: .line 587
            invokevirtual java.util.LinkedHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
       155: .line 591
            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  156     0                this  Lsun/security/ssl/ClientHello$ClientHelloKickstartProducer;
            0  156     1             context  Lsun/security/ssl/ConnectionContext;
            1  156     2                 chc  Lsun/security/ssl/ClientHandshakeContext;
            3  156     3  maxProtocolVersion  Lsun/security/ssl/ProtocolVersion;
            4  156     4           sessionId  Lsun/security/ssl/SessionId;
            5  156     5        cipherSuites  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
            7  156     6                ssci  Lsun/security/ssl/SSLSessionContextImpl;
           11  156     7             session  Lsun/security/ssl/SSLSessionImpl;
           26  156     8        sessionSuite  Lsun/security/ssl/CipherSuite;
           35  156     9      sessionVersion  Lsun/security/ssl/ProtocolVersion;
           49   61    10      isEmsAvailable  Z
           55   61    11         identityAlg  Ljava/lang/String;
           62  156    10         identityAlg  Ljava/lang/String;
           65   72    11  sessionIdentityAlg  Ljava/lang/String;
          109  156    11      minimumVersion  Lsun/security/ssl/ProtocolVersion;
          111  114    12                  pv  Lsun/security/ssl/ProtocolVersion;
          126  156    12          negotiable  Z
          128  131    13               suite  Lsun/security/ssl/CipherSuite;
          135  156    13  clientHelloVersion  Lsun/security/ssl/ProtocolVersion;
          141  156    14                 chm  Lsun/security/ssl/ClientHello$ClientHelloMessage;
          146  156    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