abstract class sun.security.ssl.Handshaker
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: sun.security.ssl.Handshaker
  super_class: java.lang.Object
{
  sun.security.ssl.ProtocolVersion protocolVersion;
    descriptor: Lsun/security/ssl/ProtocolVersion;
    flags: (0x0000) 

  sun.security.ssl.ProtocolVersion activeProtocolVersion;
    descriptor: Lsun/security/ssl/ProtocolVersion;
    flags: (0x0000) 

  boolean secureRenegotiation;
    descriptor: Z
    flags: (0x0000) 

  byte[] clientVerifyData;
    descriptor: [B
    flags: (0x0000) 

  byte[] serverVerifyData;
    descriptor: [B
    flags: (0x0000) 

  boolean isInitialHandshake;
    descriptor: Z
    flags: (0x0000) 

  private sun.security.ssl.ProtocolList enabledProtocols;
    descriptor: Lsun/security/ssl/ProtocolList;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.ssl.CipherSuiteList enabledCipherSuites;
    descriptor: Lsun/security/ssl/CipherSuiteList;
    flags: (0x0002) ACC_PRIVATE

  java.lang.String identificationProtocol;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.security.AlgorithmConstraints algorithmConstraints;
    descriptor: Ljava/security/AlgorithmConstraints;
    flags: (0x0000) 

  private java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> localSupportedSignAlgs;
    descriptor: Ljava/util/Collection;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;

  java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> peerSupportedSignAlgs;
    descriptor: Ljava/util/Collection;
    flags: (0x0000) 
    Signature: Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;

  private sun.security.ssl.ProtocolList activeProtocols;
    descriptor: Lsun/security/ssl/ProtocolList;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.ssl.CipherSuiteList activeCipherSuites;
    descriptor: Lsun/security/ssl/CipherSuiteList;
    flags: (0x0002) ACC_PRIVATE

  java.util.List<javax.net.ssl.SNIServerName> serverNames;
    descriptor: Ljava/util/List;
    flags: (0x0000) 
    Signature: Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;

  java.util.Collection<javax.net.ssl.SNIMatcher> sniMatchers;
    descriptor: Ljava/util/Collection;
    flags: (0x0000) 
    Signature: Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;

  java.lang.String[] localApl;
    descriptor: [Ljava/lang/String;
    flags: (0x0000) 

  java.lang.String applicationProtocol;
    descriptor: Ljava/lang/String;
    flags: (0x0000) 

  java.util.function.BiFunction<javax.net.ssl.SSLEngine, java.util.List<java.lang.String>, java.lang.String> appProtocolSelectorSSLEngine;
    descriptor: Ljava/util/function/BiFunction;
    flags: (0x0000) 
    Signature: Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLEngine;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;

  java.util.function.BiFunction<javax.net.ssl.SSLSocket, java.util.List<java.lang.String>, java.lang.String> appProtocolSelectorSSLSocket;
    descriptor: Ljava/util/function/BiFunction;
    flags: (0x0000) 
    Signature: Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLSocket;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;

  int maximumPacketSize;
    descriptor: I
    flags: (0x0000) 

  private boolean isClient;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private boolean needCertVerify;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  sun.security.ssl.SSLSocketImpl conn;
    descriptor: Lsun/security/ssl/SSLSocketImpl;
    flags: (0x0000) 

  sun.security.ssl.SSLEngineImpl engine;
    descriptor: Lsun/security/ssl/SSLEngineImpl;
    flags: (0x0000) 

  sun.security.ssl.HandshakeHash handshakeHash;
    descriptor: Lsun/security/ssl/HandshakeHash;
    flags: (0x0000) 

  sun.security.ssl.HandshakeInStream input;
    descriptor: Lsun/security/ssl/HandshakeInStream;
    flags: (0x0000) 

  sun.security.ssl.HandshakeOutStream output;
    descriptor: Lsun/security/ssl/HandshakeOutStream;
    flags: (0x0000) 

  sun.security.ssl.SSLContextImpl sslContext;
    descriptor: Lsun/security/ssl/SSLContextImpl;
    flags: (0x0000) 

  sun.security.ssl.RandomCookie clnt_random;
    descriptor: Lsun/security/ssl/RandomCookie;
    flags: (0x0000) 

  sun.security.ssl.RandomCookie svr_random;
    descriptor: Lsun/security/ssl/RandomCookie;
    flags: (0x0000) 

  sun.security.ssl.SSLSessionImpl session;
    descriptor: Lsun/security/ssl/SSLSessionImpl;
    flags: (0x0000) 

  sun.security.ssl.HandshakeStateManager handshakeState;
    descriptor: Lsun/security/ssl/HandshakeStateManager;
    flags: (0x0000) 

  boolean clientHelloDelivered;
    descriptor: Z
    flags: (0x0000) 

  boolean serverHelloRequested;
    descriptor: Z
    flags: (0x0000) 

  boolean handshakeActivated;
    descriptor: Z
    flags: (0x0000) 

  boolean handshakeFinished;
    descriptor: Z
    flags: (0x0000) 

  sun.security.ssl.CipherSuite cipherSuite;
    descriptor: Lsun/security/ssl/CipherSuite;
    flags: (0x0000) 

  sun.security.ssl.CipherSuite$KeyExchange keyExchange;
    descriptor: Lsun/security/ssl/CipherSuite$KeyExchange;
    flags: (0x0000) 

  boolean resumingSession;
    descriptor: Z
    flags: (0x0000) 

  boolean enableNewSession;
    descriptor: Z
    flags: (0x0000) 

  boolean preferLocalCipherSuites;
    descriptor: Z
    flags: (0x0000) 

  private javax.crypto.SecretKey clntWriteKey;
    descriptor: Ljavax/crypto/SecretKey;
    flags: (0x0002) ACC_PRIVATE

  private javax.crypto.SecretKey svrWriteKey;
    descriptor: Ljavax/crypto/SecretKey;
    flags: (0x0002) ACC_PRIVATE

  private javax.crypto.spec.IvParameterSpec clntWriteIV;
    descriptor: Ljavax/crypto/spec/IvParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  private javax.crypto.spec.IvParameterSpec svrWriteIV;
    descriptor: Ljavax/crypto/spec/IvParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  private javax.crypto.SecretKey clntMacSecret;
    descriptor: Ljavax/crypto/SecretKey;
    flags: (0x0002) ACC_PRIVATE

  private javax.crypto.SecretKey svrMacSecret;
    descriptor: Ljavax/crypto/SecretKey;
    flags: (0x0002) ACC_PRIVATE

  private volatile boolean taskDelegated;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile sun.security.ssl.Handshaker$DelegatedTask<?> delegatedTask;
    descriptor: Lsun/security/ssl/Handshaker$DelegatedTask;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
    Signature: Lsun/security/ssl/Handshaker$DelegatedTask<*>;

  private volatile java.lang.Exception thrown;
    descriptor: Ljava/lang/Exception;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private java.lang.Object thrownLock;
    descriptor: Ljava/lang/Object;
    flags: (0x0002) ACC_PRIVATE

  static final sun.security.ssl.Debug debug;
    descriptor: Lsun/security/ssl/Debug;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean allowUnsafeRenegotiation;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean allowLegacyHelloMessages;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean rejectClientInitiatedRenego;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean useExtendedMasterSecret;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean allowLegacyResumption;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final boolean allowLegacyMasterSecret;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  boolean requestedToUseEMS;
    descriptor: Z
    flags: (0x0000) 

  boolean invalidated;
    descriptor: Z
    flags: (0x0000) 

  final boolean isDTLS;
    descriptor: Z
    flags: (0x0010) ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 195
            ldc "ssl"
            invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
            putstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
         1: .line 199
            ldc "sun.security.ssl.allowUnsafeRenegotiation"
            iconst_0
         2: .line 198
            invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
            putstatic sun.security.ssl.Handshaker.allowUnsafeRenegotiation:Z
         3: .line 210
            ldc "sun.security.ssl.allowLegacyHelloMessages"
            iconst_1
         4: .line 209
            invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
            putstatic sun.security.ssl.Handshaker.allowLegacyHelloMessages:Z
         5: .line 220
            ldc "jdk.tls.rejectClientInitiatedRenegotiation"
            iconst_0
         6: .line 219
            invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
         7: .line 218
            putstatic sun.security.ssl.Handshaker.rejectClientInitiatedRenego:Z
         8: .line 227
            ldc "jdk.tls.allowLegacyResumption"
            iconst_1
            invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
         9: .line 226
            putstatic sun.security.ssl.Handshaker.allowLegacyResumption:Z
        10: .line 231
            ldc "jdk.tls.allowLegacyMasterSecret"
            iconst_1
            invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
        11: .line 230
            putstatic sun.security.ssl.Handshaker.allowLegacyMasterSecret:Z
        12: .line 246
            iconst_1
            istore 0 /* supportExtendedMasterSecret */
        start local 0 // boolean supportExtendedMasterSecret
        13: .line 249
            ldc "SunTlsExtendedMasterSecret"
            invokestatic sun.security.ssl.JsseJce.getKeyGenerator:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            pop
        14: .line 250
            goto 17
      StackMap locals: int
      StackMap stack: java.security.NoSuchAlgorithmException
        15: pop
        16: .line 251
            iconst_0
            istore 0 /* supportExtendedMasterSecret */
        17: .line 254
      StackMap locals:
      StackMap stack:
            iload 0 /* supportExtendedMasterSecret */
            ifeq 21
        18: .line 256
            ldc "jdk.tls.useExtendedMasterSecret"
            iconst_1
        19: .line 255
            invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
            putstatic sun.security.ssl.Handshaker.useExtendedMasterSecret:Z
        20: .line 257
            goto 22
        21: .line 258
      StackMap locals:
      StackMap stack:
            iconst_0
            putstatic sun.security.ssl.Handshaker.useExtendedMasterSecret:Z
        end local 0 // boolean supportExtendedMasterSecret
        22: .line 260
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot                         Name  Signature
           13   22     0  supportExtendedMasterSecret  Z
      Exception table:
        from    to  target  type
          13    14      15  Class java.security.NoSuchAlgorithmException

  void <init>(sun.security.ssl.SSLSocketImpl, sun.security.ssl.SSLContextImpl, sun.security.ssl.ProtocolList, boolean, boolean, sun.security.ssl.ProtocolVersion, boolean, boolean, byte[], byte[]);
    descriptor: (Lsun/security/ssl/SSLSocketImpl;Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
    flags: (0x0000) 
    Code:
      stack=10, locals=11, args_size=11
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.SSLSocketImpl c
        start local 2 // sun.security.ssl.SSLContextImpl context
        start local 3 // sun.security.ssl.ProtocolList enabledProtocols
        start local 4 // boolean needCertVerify
        start local 5 // boolean isClient
        start local 6 // sun.security.ssl.ProtocolVersion activeProtocolVersion
        start local 7 // boolean isInitialHandshake
        start local 8 // boolean secureRenegotiation
        start local 9 // byte[] clientVerifyData
        start local 10 // byte[] serverVerifyData
         0: .line 262
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 86
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
         2: .line 112
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.Handshaker.serverNames:Ljava/util/List;
         3: .line 113
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.Handshaker.sniMatchers:Ljava/util/Collection;
         4: .line 116
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.localApl:[Ljava/lang/String;
         5: .line 119
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.applicationProtocol:Ljava/lang/String;
         6: .line 123
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLEngine:Ljava/util/function/BiFunction;
         7: .line 127
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLSocket:Ljava/util/function/BiFunction;
         8: .line 130
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.maximumPacketSize:I
         9: .line 135
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
        10: .line 136
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
        11: .line 169
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.preferLocalCipherSuites:Z
        12: .line 186
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.taskDelegated:Z
        13: .line 187
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
        14: .line 188
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
        15: .line 192
            aload 0 /* this */
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putfield sun.security.ssl.Handshaker.thrownLock:Ljava/lang/Object;
        16: .line 234
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.requestedToUseEMS:Z
        17: .line 267
            aload 0 /* this */
            aload 1 /* c */
            putfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
        18: .line 268
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.isDTLS:Z
        19: .line 269
            aload 0 /* this */
            aload 2 /* context */
            aload 3 /* enabledProtocols */
            iload 4 /* needCertVerify */
            iload 5 /* isClient */
        20: .line 270
            aload 6 /* activeProtocolVersion */
            iload 7 /* isInitialHandshake */
            iload 8 /* secureRenegotiation */
        21: .line 271
            aload 9 /* clientVerifyData */
            aload 10 /* serverVerifyData */
        22: .line 269
            invokevirtual sun.security.ssl.Handshaker.init:(Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
        23: .line 272
            return
        end local 10 // byte[] serverVerifyData
        end local 9 // byte[] clientVerifyData
        end local 8 // boolean secureRenegotiation
        end local 7 // boolean isInitialHandshake
        end local 6 // sun.security.ssl.ProtocolVersion activeProtocolVersion
        end local 5 // boolean isClient
        end local 4 // boolean needCertVerify
        end local 3 // sun.security.ssl.ProtocolList enabledProtocols
        end local 2 // sun.security.ssl.SSLContextImpl context
        end local 1 // sun.security.ssl.SSLSocketImpl c
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   24     0                   this  Lsun/security/ssl/Handshaker;
            0   24     1                      c  Lsun/security/ssl/SSLSocketImpl;
            0   24     2                context  Lsun/security/ssl/SSLContextImpl;
            0   24     3       enabledProtocols  Lsun/security/ssl/ProtocolList;
            0   24     4         needCertVerify  Z
            0   24     5               isClient  Z
            0   24     6  activeProtocolVersion  Lsun/security/ssl/ProtocolVersion;
            0   24     7     isInitialHandshake  Z
            0   24     8    secureRenegotiation  Z
            0   24     9       clientVerifyData  [B
            0   24    10       serverVerifyData  [B
    MethodParameters:
                       Name  Flags
      c                      
      context                
      enabledProtocols       
      needCertVerify         
      isClient               
      activeProtocolVersion  
      isInitialHandshake     
      secureRenegotiation    
      clientVerifyData       
      serverVerifyData       

  void <init>(sun.security.ssl.SSLEngineImpl, sun.security.ssl.SSLContextImpl, sun.security.ssl.ProtocolList, boolean, boolean, sun.security.ssl.ProtocolVersion, boolean, boolean, byte[], byte[], boolean);
    descriptor: (Lsun/security/ssl/SSLEngineImpl;Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[BZ)V
    flags: (0x0000) 
    Code:
      stack=10, locals=12, args_size=12
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.SSLEngineImpl engine
        start local 2 // sun.security.ssl.SSLContextImpl context
        start local 3 // sun.security.ssl.ProtocolList enabledProtocols
        start local 4 // boolean needCertVerify
        start local 5 // boolean isClient
        start local 6 // sun.security.ssl.ProtocolVersion activeProtocolVersion
        start local 7 // boolean isInitialHandshake
        start local 8 // boolean secureRenegotiation
        start local 9 // byte[] clientVerifyData
        start local 10 // byte[] serverVerifyData
        start local 11 // boolean isDTLS
         0: .line 274
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 86
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
         2: .line 112
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.Handshaker.serverNames:Ljava/util/List;
         3: .line 113
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.Handshaker.sniMatchers:Ljava/util/Collection;
         4: .line 116
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.localApl:[Ljava/lang/String;
         5: .line 119
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.applicationProtocol:Ljava/lang/String;
         6: .line 123
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLEngine:Ljava/util/function/BiFunction;
         7: .line 127
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLSocket:Ljava/util/function/BiFunction;
         8: .line 130
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.maximumPacketSize:I
         9: .line 135
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
        10: .line 136
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
        11: .line 169
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.preferLocalCipherSuites:Z
        12: .line 186
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.taskDelegated:Z
        13: .line 187
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
        14: .line 188
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
        15: .line 192
            aload 0 /* this */
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putfield sun.security.ssl.Handshaker.thrownLock:Ljava/lang/Object;
        16: .line 234
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.requestedToUseEMS:Z
        17: .line 280
            aload 0 /* this */
            aload 1 /* engine */
            putfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
        18: .line 281
            aload 0 /* this */
            iload 11 /* isDTLS */
            putfield sun.security.ssl.Handshaker.isDTLS:Z
        19: .line 282
            aload 0 /* this */
            aload 2 /* context */
            aload 3 /* enabledProtocols */
            iload 4 /* needCertVerify */
            iload 5 /* isClient */
        20: .line 283
            aload 6 /* activeProtocolVersion */
            iload 7 /* isInitialHandshake */
            iload 8 /* secureRenegotiation */
        21: .line 284
            aload 9 /* clientVerifyData */
            aload 10 /* serverVerifyData */
        22: .line 282
            invokevirtual sun.security.ssl.Handshaker.init:(Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
        23: .line 285
            return
        end local 11 // boolean isDTLS
        end local 10 // byte[] serverVerifyData
        end local 9 // byte[] clientVerifyData
        end local 8 // boolean secureRenegotiation
        end local 7 // boolean isInitialHandshake
        end local 6 // sun.security.ssl.ProtocolVersion activeProtocolVersion
        end local 5 // boolean isClient
        end local 4 // boolean needCertVerify
        end local 3 // sun.security.ssl.ProtocolList enabledProtocols
        end local 2 // sun.security.ssl.SSLContextImpl context
        end local 1 // sun.security.ssl.SSLEngineImpl engine
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   24     0                   this  Lsun/security/ssl/Handshaker;
            0   24     1                 engine  Lsun/security/ssl/SSLEngineImpl;
            0   24     2                context  Lsun/security/ssl/SSLContextImpl;
            0   24     3       enabledProtocols  Lsun/security/ssl/ProtocolList;
            0   24     4         needCertVerify  Z
            0   24     5               isClient  Z
            0   24     6  activeProtocolVersion  Lsun/security/ssl/ProtocolVersion;
            0   24     7     isInitialHandshake  Z
            0   24     8    secureRenegotiation  Z
            0   24     9       clientVerifyData  [B
            0   24    10       serverVerifyData  [B
            0   24    11                 isDTLS  Z
    MethodParameters:
                       Name  Flags
      engine                 
      context                
      enabledProtocols       
      needCertVerify         
      isClient               
      activeProtocolVersion  
      isInitialHandshake     
      secureRenegotiation    
      clientVerifyData       
      serverVerifyData       
      isDTLS                 

  private void init(sun.security.ssl.SSLContextImpl, sun.security.ssl.ProtocolList, boolean, boolean, sun.security.ssl.ProtocolVersion, boolean, boolean, byte[], byte[]);
    descriptor: (Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=10, args_size=10
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.SSLContextImpl context
        start local 2 // sun.security.ssl.ProtocolList enabledProtocols
        start local 3 // boolean needCertVerify
        start local 4 // boolean isClient
        start local 5 // sun.security.ssl.ProtocolVersion activeProtocolVersion
        start local 6 // boolean isInitialHandshake
        start local 7 // boolean secureRenegotiation
        start local 8 // byte[] clientVerifyData
        start local 9 // byte[] serverVerifyData
         0: .line 293
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 8
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 8
         1: .line 294
            getstatic java.lang.System.out:Ljava/io/PrintStream;
         2: .line 295
            new java.lang.StringBuilder
            dup
            ldc "Allow unsafe renegotiation: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            getstatic sun.security.ssl.Handshaker.allowUnsafeRenegotiation:Z
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
         3: .line 296
            ldc "\nAllow legacy hello messages: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic sun.security.ssl.Handshaker.allowLegacyHelloMessages:Z
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
         4: .line 297
            ldc "\nIs initial handshake: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 6 /* isInitialHandshake */
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
         5: .line 298
            ldc "\nIs secure renegotiation: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 7 /* secureRenegotiation */
            invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
         6: .line 295
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         7: .line 294
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 301
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* context */
            putfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
         9: .line 302
            aload 0 /* this */
            iload 4 /* isClient */
            putfield sun.security.ssl.Handshaker.isClient:Z
        10: .line 303
            aload 0 /* this */
            iload 3 /* needCertVerify */
            putfield sun.security.ssl.Handshaker.needCertVerify:Z
        11: .line 304
            aload 0 /* this */
            aload 5 /* activeProtocolVersion */
            putfield sun.security.ssl.Handshaker.activeProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        12: .line 305
            aload 0 /* this */
            iload 6 /* isInitialHandshake */
            putfield sun.security.ssl.Handshaker.isInitialHandshake:Z
        13: .line 306
            aload 0 /* this */
            iload 7 /* secureRenegotiation */
            putfield sun.security.ssl.Handshaker.secureRenegotiation:Z
        14: .line 307
            aload 0 /* this */
            aload 8 /* clientVerifyData */
            putfield sun.security.ssl.Handshaker.clientVerifyData:[B
        15: .line 308
            aload 0 /* this */
            aload 9 /* serverVerifyData */
            putfield sun.security.ssl.Handshaker.serverVerifyData:[B
        16: .line 309
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.enableNewSession:Z
        17: .line 310
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.invalidated:Z
        18: .line 311
            aload 0 /* this */
            new sun.security.ssl.HandshakeStateManager
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isDTLS:Z
            invokespecial sun.security.ssl.HandshakeStateManager.<init>:(Z)V
            putfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
        19: .line 312
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
        20: .line 313
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.serverHelloRequested:Z
        21: .line 314
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.handshakeActivated:Z
        22: .line 315
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.handshakeFinished:Z
        23: .line 317
            aload 0 /* this */
            getstatic sun.security.ssl.CipherSuite.C_NULL:Lsun/security/ssl/CipherSuite;
            invokevirtual sun.security.ssl.Handshaker.setCipherSuite:(Lsun/security/ssl/CipherSuite;)V
        24: .line 318
            aload 0 /* this */
            aload 2 /* enabledProtocols */
            invokevirtual sun.security.ssl.Handshaker.setEnabledProtocols:(Lsun/security/ssl/ProtocolList;)V
        25: .line 320
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 28
        26: .line 321
            aload 0 /* this */
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            iconst_1
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;Z)V
            putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
        27: .line 322
            goto 29
        28: .line 323
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            iconst_1
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;Z)V
            putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
        29: .line 325
      StackMap locals:
      StackMap stack:
            return
        end local 9 // byte[] serverVerifyData
        end local 8 // byte[] clientVerifyData
        end local 7 // boolean secureRenegotiation
        end local 6 // boolean isInitialHandshake
        end local 5 // sun.security.ssl.ProtocolVersion activeProtocolVersion
        end local 4 // boolean isClient
        end local 3 // boolean needCertVerify
        end local 2 // sun.security.ssl.ProtocolList enabledProtocols
        end local 1 // sun.security.ssl.SSLContextImpl context
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   30     0                   this  Lsun/security/ssl/Handshaker;
            0   30     1                context  Lsun/security/ssl/SSLContextImpl;
            0   30     2       enabledProtocols  Lsun/security/ssl/ProtocolList;
            0   30     3         needCertVerify  Z
            0   30     4               isClient  Z
            0   30     5  activeProtocolVersion  Lsun/security/ssl/ProtocolVersion;
            0   30     6     isInitialHandshake  Z
            0   30     7    secureRenegotiation  Z
            0   30     8       clientVerifyData  [B
            0   30     9       serverVerifyData  [B
    MethodParameters:
                       Name  Flags
      context                
      enabledProtocols       
      needCertVerify         
      isClient               
      activeProtocolVersion  
      isInitialHandshake     
      secureRenegotiation    
      clientVerifyData       
      serverVerifyData       

  void fatalSE(byte, java.lang.String);
    descriptor: (BLjava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // byte b
        start local 2 // java.lang.String diagnostic
         0: .line 335
            aload 0 /* this */
            iload 1 /* b */
            aload 2 /* diagnostic */
            aconst_null
            invokevirtual sun.security.ssl.Handshaker.fatalSE:(BLjava/lang/String;Ljava/lang/Throwable;)V
         1: .line 336
            return
        end local 2 // java.lang.String diagnostic
        end local 1 // byte b
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lsun/security/ssl/Handshaker;
            0    2     1           b  B
            0    2     2  diagnostic  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
            Name  Flags
      b           
      diagnostic  

  void fatalSE(byte, java.lang.Throwable);
    descriptor: (BLjava/lang/Throwable;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // byte b
        start local 2 // java.lang.Throwable cause
         0: .line 339
            aload 0 /* this */
            iload 1 /* b */
            aconst_null
            aload 2 /* cause */
            invokevirtual sun.security.ssl.Handshaker.fatalSE:(BLjava/lang/String;Ljava/lang/Throwable;)V
         1: .line 340
            return
        end local 2 // java.lang.Throwable cause
        end local 1 // byte b
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lsun/security/ssl/Handshaker;
            0    2     1      b  B
            0    2     2  cause  Ljava/lang/Throwable;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
       Name  Flags
      b      
      cause  

  void fatalSE(byte, java.lang.String, java.lang.Throwable);
    descriptor: (BLjava/lang/String;Ljava/lang/Throwable;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // byte b
        start local 2 // java.lang.String diagnostic
        start local 3 // java.lang.Throwable cause
         0: .line 344
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 3
         1: .line 345
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            iload 1 /* b */
            aload 2 /* diagnostic */
            aload 3 /* cause */
            invokevirtual sun.security.ssl.SSLSocketImpl.fatal:(BLjava/lang/String;Ljava/lang/Throwable;)V
         2: .line 346
            goto 4
         3: .line 347
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            iload 1 /* b */
            aload 2 /* diagnostic */
            aload 3 /* cause */
            invokevirtual sun.security.ssl.SSLEngineImpl.fatal:(BLjava/lang/String;Ljava/lang/Throwable;)V
         4: .line 349
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.Throwable cause
        end local 2 // java.lang.String diagnostic
        end local 1 // byte b
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Lsun/security/ssl/Handshaker;
            0    5     1           b  B
            0    5     2  diagnostic  Ljava/lang/String;
            0    5     3       cause  Ljava/lang/Throwable;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
            Name  Flags
      b           
      diagnostic  
      cause       

  void warningSE(byte);
    descriptor: (B)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // byte b
         0: .line 352
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 3
         1: .line 353
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            iload 1 /* b */
            invokevirtual sun.security.ssl.SSLSocketImpl.warning:(B)V
         2: .line 354
            goto 4
         3: .line 355
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            iload 1 /* b */
            invokevirtual sun.security.ssl.SSLEngineImpl.warning:(B)V
         4: .line 357
      StackMap locals:
      StackMap stack:
            return
        end local 1 // byte b
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/ssl/Handshaker;
            0    5     1     b  B
    MethodParameters:
      Name  Flags
      b     

  java.lang.String getHostSE();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 361
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 2
         1: .line 362
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.getHost:()Ljava/lang/String;
            areturn
         2: .line 364
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            invokevirtual sun.security.ssl.SSLEngineImpl.getPeerHost:()Ljava/lang/String;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/Handshaker;

  java.lang.String getHostAddressSE();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 370
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 2
         1: .line 371
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.getInetAddress:()Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            areturn
         2: .line 378
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            invokevirtual sun.security.ssl.SSLEngineImpl.getPeerHost:()Ljava/lang/String;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/Handshaker;

  int getPortSE();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 383
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 2
         1: .line 384
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.getPort:()I
            ireturn
         2: .line 386
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            invokevirtual sun.security.ssl.SSLEngineImpl.getPeerPort:()I
            ireturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/Handshaker;

  int getLocalPortSE();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 391
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 2
         1: .line 392
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.getLocalPort:()I
            ireturn
         2: .line 394
      StackMap locals:
      StackMap stack:
            iconst_m1
            ireturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/Handshaker;

  java.security.AccessControlContext getAccSE();
    descriptor: ()Ljava/security/AccessControlContext;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 399
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 2
         1: .line 400
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.getAcc:()Ljava/security/AccessControlContext;
            areturn
         2: .line 402
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            invokevirtual sun.security.ssl.SSLEngineImpl.getAcc:()Ljava/security/AccessControlContext;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/Handshaker;

  java.lang.String getEndpointIdentificationAlgorithmSE();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 408
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 3
         1: .line 409
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
            astore 1 /* paras */
        start local 1 // javax.net.ssl.SSLParameters paras
         2: .line 410
            goto 4
        end local 1 // javax.net.ssl.SSLParameters paras
         3: .line 411
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            invokevirtual sun.security.ssl.SSLEngineImpl.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
            astore 1 /* paras */
        start local 1 // javax.net.ssl.SSLParameters paras
         4: .line 414
      StackMap locals: javax.net.ssl.SSLParameters
      StackMap stack:
            aload 1 /* paras */
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
            areturn
        end local 1 // javax.net.ssl.SSLParameters paras
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lsun/security/ssl/Handshaker;
            2    3     1  paras  Ljavax/net/ssl/SSLParameters;
            4    5     1  paras  Ljavax/net/ssl/SSLParameters;

  private void setVersionSE(sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/ProtocolVersion;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 418
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 3
         1: .line 419
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            aload 1 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLSocketImpl.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
         2: .line 420
            goto 4
         3: .line 421
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            aload 1 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLEngineImpl.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
         4: .line 423
      StackMap locals:
      StackMap stack:
            return
        end local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lsun/security/ssl/Handshaker;
            0    5     1  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      protocolVersion  

  void setVersion(sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/ProtocolVersion;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 431
            aload 0 /* this */
            aload 1 /* protocolVersion */
            putfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
         1: .line 432
            aload 0 /* this */
            aload 1 /* protocolVersion */
            invokevirtual sun.security.ssl.Handshaker.setVersionSE:(Lsun/security/ssl/ProtocolVersion;)V
         2: .line 433
            return
        end local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lsun/security/ssl/Handshaker;
            0    3     1  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      protocolVersion  

  void setEnabledProtocols(sun.security.ssl.ProtocolList);
    descriptor: (Lsun/security/ssl/ProtocolList;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.ProtocolList enabledProtocols
         0: .line 441
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
         1: .line 442
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
         2: .line 444
            aload 0 /* this */
            aload 1 /* enabledProtocols */
            putfield sun.security.ssl.Handshaker.enabledProtocols:Lsun/security/ssl/ProtocolList;
         3: .line 445
            return
        end local 1 // sun.security.ssl.ProtocolList enabledProtocols
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    4     0              this  Lsun/security/ssl/Handshaker;
            0    4     1  enabledProtocols  Lsun/security/ssl/ProtocolList;
    MethodParameters:
                  Name  Flags
      enabledProtocols  

  void setEnabledCipherSuites(sun.security.ssl.CipherSuiteList);
    descriptor: (Lsun/security/ssl/CipherSuiteList;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.CipherSuiteList enabledCipherSuites
         0: .line 453
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
         1: .line 454
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
         2: .line 455
            aload 0 /* this */
            aload 1 /* enabledCipherSuites */
            putfield sun.security.ssl.Handshaker.enabledCipherSuites:Lsun/security/ssl/CipherSuiteList;
         3: .line 456
            return
        end local 1 // sun.security.ssl.CipherSuiteList enabledCipherSuites
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    4     0                 this  Lsun/security/ssl/Handshaker;
            0    4     1  enabledCipherSuites  Lsun/security/ssl/CipherSuiteList;
    MethodParameters:
                     Name  Flags
      enabledCipherSuites  

  void setAlgorithmConstraints(java.security.AlgorithmConstraints);
    descriptor: (Ljava/security/AlgorithmConstraints;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.security.AlgorithmConstraints algorithmConstraints
         0: .line 464
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
         1: .line 465
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
         2: .line 467
            aload 0 /* this */
         3: .line 468
            new sun.security.ssl.SSLAlgorithmConstraints
            dup
            aload 1 /* algorithmConstraints */
            invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljava/security/AlgorithmConstraints;)V
         4: .line 467
            putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
         5: .line 469
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
         6: .line 470
            return
        end local 1 // java.security.AlgorithmConstraints algorithmConstraints
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0    7     0                  this  Lsun/security/ssl/Handshaker;
            0    7     1  algorithmConstraints  Ljava/security/AlgorithmConstraints;
    MethodParameters:
                      Name  Flags
      algorithmConstraints  

  java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> getLocalSupportedSignAlgs();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 473
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
            ifnonnull 5
         1: .line 474
            aload 0 /* this */
         2: .line 476
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
         3: .line 475
            invokestatic sun.security.ssl.SignatureAndHashAlgorithm.getSupportedAlgorithms:(Ljava/security/AlgorithmConstraints;)Ljava/util/Collection;
         4: .line 474
            putfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
         5: .line 479
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lsun/security/ssl/Handshaker;
    Signature: ()Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;

  void setPeerSupportedSignAlgs(java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.util.Collection algorithms
         0: .line 484
            aload 0 /* this */
         1: .line 485
            new java.util.ArrayList
            dup
            aload 1 /* algorithms */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
         2: .line 484
            putfield sun.security.ssl.Handshaker.peerSupportedSignAlgs:Ljava/util/Collection;
         3: .line 486
            return
        end local 1 // java.util.Collection algorithms
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lsun/security/ssl/Handshaker;
            0    4     1  algorithms  Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;
    Signature: (Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;)V
    MethodParameters:
            Name  Flags
      algorithms  

  java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> getPeerSupportedSignAlgs();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 489
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.peerSupportedSignAlgs:Ljava/util/Collection;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/Handshaker;
    Signature: ()Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;

  void setIdentificationProtocol(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.lang.String protocol
         0: .line 499
            aload 0 /* this */
            aload 1 /* protocol */
            putfield sun.security.ssl.Handshaker.identificationProtocol:Ljava/lang/String;
         1: .line 500
            return
        end local 1 // java.lang.String protocol
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/Handshaker;
            0    2     1  protocol  Ljava/lang/String;
    MethodParameters:
          Name  Flags
      protocol  

  void setSNIServerNames(java.util.List<javax.net.ssl.SNIServerName>);
    descriptor: (Ljava/util/List;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.util.List serverNames
         0: .line 507
            aload 0 /* this */
            aload 1 /* serverNames */
            putfield sun.security.ssl.Handshaker.serverNames:Ljava/util/List;
         1: .line 508
            return
        end local 1 // java.util.List serverNames
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lsun/security/ssl/Handshaker;
            0    2     1  serverNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
    Signature: (Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;)V
    MethodParameters:
             Name  Flags
      serverNames  

  void setSNIMatchers(java.util.Collection<javax.net.ssl.SNIMatcher>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.util.Collection sniMatchers
         0: .line 515
            aload 0 /* this */
            aload 1 /* sniMatchers */
            putfield sun.security.ssl.Handshaker.sniMatchers:Ljava/util/Collection;
         1: .line 516
            return
        end local 1 // java.util.Collection sniMatchers
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lsun/security/ssl/Handshaker;
            0    2     1  sniMatchers  Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;
    Signature: (Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;)V
    MethodParameters:
             Name  Flags
      sniMatchers  

  void setMaximumPacketSize(int);
    descriptor: (I)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // int maximumPacketSize
         0: .line 522
            aload 0 /* this */
            iload 1 /* maximumPacketSize */
            putfield sun.security.ssl.Handshaker.maximumPacketSize:I
         1: .line 523
            return
        end local 1 // int maximumPacketSize
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    2     0               this  Lsun/security/ssl/Handshaker;
            0    2     1  maximumPacketSize  I
    MethodParameters:
                   Name  Flags
      maximumPacketSize  

  void setApplicationProtocols(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.lang.String[] apl
         0: .line 529
            aload 0 /* this */
            aload 1 /* apl */
            putfield sun.security.ssl.Handshaker.localApl:[Ljava/lang/String;
         1: .line 530
            return
        end local 1 // java.lang.String[] apl
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/Handshaker;
            0    2     1   apl  [Ljava/lang/String;
    MethodParameters:
      Name  Flags
      apl   

  java.lang.String getHandshakeApplicationProtocol();
    descriptor: ()Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 536
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.applicationProtocol:Ljava/lang/String;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/Handshaker;

  void setApplicationProtocolSelectorSSLEngine(java.util.function.BiFunction<javax.net.ssl.SSLEngine, java.util.List<java.lang.String>, java.lang.String>);
    descriptor: (Ljava/util/function/BiFunction;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.util.function.BiFunction selector
         0: .line 544
            aload 0 /* this */
            aload 1 /* selector */
            putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLEngine:Ljava/util/function/BiFunction;
         1: .line 545
            return
        end local 1 // java.util.function.BiFunction selector
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/Handshaker;
            0    2     1  selector  Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLEngine;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;
    Signature: (Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLEngine;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;)V
    MethodParameters:
          Name  Flags
      selector  

  void setApplicationProtocolSelectorSSLSocket(java.util.function.BiFunction<javax.net.ssl.SSLSocket, java.util.List<java.lang.String>, java.lang.String>);
    descriptor: (Ljava/util/function/BiFunction;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.util.function.BiFunction selector
         0: .line 552
            aload 0 /* this */
            aload 1 /* selector */
            putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLSocket:Ljava/util/function/BiFunction;
         1: .line 553
            return
        end local 1 // java.util.function.BiFunction selector
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lsun/security/ssl/Handshaker;
            0    2     1  selector  Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLSocket;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;
    Signature: (Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLSocket;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;)V
    MethodParameters:
          Name  Flags
      selector  

  void setUseCipherSuitesOrder(boolean);
    descriptor: (Z)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // boolean on
         0: .line 559
            aload 0 /* this */
            iload 1 /* on */
            putfield sun.security.ssl.Handshaker.preferLocalCipherSuites:Z
         1: .line 560
            return
        end local 1 // boolean on
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/Handshaker;
            0    2     1    on  Z
    MethodParameters:
      Name  Flags
      on    

  void activate(sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/ProtocolVersion;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.ProtocolVersion helloVersion
         0: .line 567
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            ifnonnull 2
         1: .line 568
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
         2: .line 571
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            invokevirtual sun.security.ssl.ProtocolList.collection:()Ljava/util/Collection;
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 4
         3: .line 572
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            getfield sun.security.ssl.ProtocolList.max:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmpne 7
         4: .line 573
      StackMap locals:
      StackMap stack:
            new javax.net.ssl.SSLHandshakeException
            dup
         5: .line 574
            ldc "No appropriate protocol (protocol is disabled or cipher suites are inappropriate)"
         6: .line 573
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 578
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
            ifnonnull 9
         8: .line 579
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.getActiveCipherSuites:()Lsun/security/ssl/CipherSuiteList;
            putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
         9: .line 582
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
            invokevirtual sun.security.ssl.CipherSuiteList.collection:()Ljava/util/Collection;
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 11
        10: .line 583
            new javax.net.ssl.SSLHandshakeException
            dup
            ldc "No appropriate cipher suite"
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 589
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isInitialHandshake:Z
            ifne 14
        12: .line 590
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocolVersion:Lsun/security/ssl/ProtocolVersion;
            putfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
        13: .line 591
            goto 15
        14: .line 592
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            getfield sun.security.ssl.ProtocolList.max:Lsun/security/ssl/ProtocolVersion;
            putfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
        15: .line 595
      StackMap locals:
      StackMap stack:
            aload 1 /* helloVersion */
            ifnull 16
            aload 1 /* helloVersion */
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmpne 17
        16: .line 596
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            getfield sun.security.ssl.ProtocolList.helloVersion:Lsun/security/ssl/ProtocolVersion;
            astore 1 /* helloVersion */
        17: .line 602
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new sun.security.ssl.HandshakeHash
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.needCertVerify:Z
            invokespecial sun.security.ssl.HandshakeHash.<init>:(Z)V
            putfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
        18: .line 605
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 27
        19: .line 606
            aload 0 /* this */
            new sun.security.ssl.HandshakeInStream
            dup
            invokespecial sun.security.ssl.HandshakeInStream.<init>:()V
            putfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
        20: .line 607
            aload 0 /* this */
            new sun.security.ssl.HandshakeOutStream
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
            putfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
        21: .line 609
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.inputRecord:Lsun/security/ssl/InputRecord;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.InputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
        22: .line 610
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.inputRecord:Lsun/security/ssl/InputRecord;
            aload 1 /* helloVersion */
            invokevirtual sun.security.ssl.InputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
        23: .line 612
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.OutputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
        24: .line 613
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            aload 1 /* helloVersion */
            invokevirtual sun.security.ssl.OutputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
        25: .line 614
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.OutputRecord.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
        26: .line 615
            goto 35
      StackMap locals:
      StackMap stack:
        27: aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            ifnull 35
        28: .line 616
            aload 0 /* this */
            new sun.security.ssl.HandshakeInStream
            dup
            invokespecial sun.security.ssl.HandshakeInStream.<init>:()V
            putfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
        29: .line 617
            aload 0 /* this */
            new sun.security.ssl.HandshakeOutStream
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
            putfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
        30: .line 619
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            getfield sun.security.ssl.SSLEngineImpl.inputRecord:Lsun/security/ssl/InputRecord;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.InputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
        31: .line 620
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            getfield sun.security.ssl.SSLEngineImpl.inputRecord:Lsun/security/ssl/InputRecord;
            aload 1 /* helloVersion */
            invokevirtual sun.security.ssl.InputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
        32: .line 622
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.OutputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
        33: .line 623
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            aload 1 /* helloVersion */
            invokevirtual sun.security.ssl.OutputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
        34: .line 624
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.OutputRecord.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
        35: .line 627
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.handshakeActivated:Z
        36: .line 628
            return
        end local 1 // sun.security.ssl.ProtocolVersion helloVersion
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   37     0          this  Lsun/security/ssl/Handshaker;
            0   37     1  helloVersion  Lsun/security/ssl/ProtocolVersion;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
              Name  Flags
      helloVersion  

  void setCipherSuite(sun.security.ssl.CipherSuite);
    descriptor: (Lsun/security/ssl/CipherSuite;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.CipherSuite s
         0: .line 636
            aload 0 /* this */
            aload 1 /* s */
            putfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
         1: .line 637
            aload 0 /* this */
            aload 1 /* s */
            getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
            putfield sun.security.ssl.Handshaker.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
         2: .line 638
            return
        end local 1 // sun.security.ssl.CipherSuite s
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/Handshaker;
            0    3     1     s  Lsun/security/ssl/CipherSuite;
    MethodParameters:
      Name  Flags
      s     

  boolean isNegotiable(sun.security.ssl.CipherSuite);
    descriptor: (Lsun/security/ssl/CipherSuite;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.CipherSuite s
         0: .line 647
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
            ifnonnull 2
         1: .line 648
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.getActiveCipherSuites:()Lsun/security/ssl/CipherSuiteList;
            putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
         2: .line 651
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
            aload 1 /* s */
            invokestatic sun.security.ssl.Handshaker.isNegotiable:(Lsun/security/ssl/CipherSuiteList;Lsun/security/ssl/CipherSuite;)Z
            ireturn
        end local 1 // sun.security.ssl.CipherSuite s
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/Handshaker;
            0    3     1     s  Lsun/security/ssl/CipherSuite;
    MethodParameters:
      Name  Flags
      s     

  static final boolean isNegotiable(sun.security.ssl.CipherSuiteList, sun.security.ssl.CipherSuite);
    descriptor: (Lsun/security/ssl/CipherSuiteList;Lsun/security/ssl/CipherSuite;)Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.CipherSuiteList proposed
        start local 1 // sun.security.ssl.CipherSuite s
         0: .line 661
            aload 0 /* proposed */
            aload 1 /* s */
            invokevirtual sun.security.ssl.CipherSuiteList.contains:(Lsun/security/ssl/CipherSuite;)Z
            ifeq 1
            aload 1 /* s */
            invokevirtual sun.security.ssl.CipherSuite.isNegotiable:()Z
            ifeq 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // sun.security.ssl.CipherSuite s
        end local 0 // sun.security.ssl.CipherSuiteList proposed
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0  proposed  Lsun/security/ssl/CipherSuiteList;
            0    2     1         s  Lsun/security/ssl/CipherSuite;
    MethodParameters:
          Name  Flags
      proposed  
      s         

  boolean isNegotiable(sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/ProtocolVersion;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 668
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            ifnonnull 2
         1: .line 669
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
         2: .line 672
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            aload 1 /* protocolVersion */
            invokevirtual sun.security.ssl.ProtocolList.contains:(Lsun/security/ssl/ProtocolVersion;)Z
            ireturn
        end local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lsun/security/ssl/Handshaker;
            0    3     1  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      protocolVersion  

  sun.security.ssl.ProtocolVersion selectProtocolVersion(sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/ProtocolVersion;
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 683
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            ifnonnull 2
         1: .line 684
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
         2: .line 687
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            aload 1 /* protocolVersion */
            invokevirtual sun.security.ssl.ProtocolList.selectProtocolVersion:(Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/ProtocolVersion;
            areturn
        end local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lsun/security/ssl/Handshaker;
            0    3     1  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      protocolVersion  

  sun.security.ssl.CipherSuiteList getActiveCipherSuites();
    descriptor: ()Lsun/security/ssl/CipherSuiteList;
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 707
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
            ifnonnull 27
         1: .line 708
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            ifnonnull 3
         2: .line 709
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
         3: .line 712
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* suites */
        start local 1 // java.util.ArrayList suites
         4: .line 713
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            invokevirtual sun.security.ssl.ProtocolList.collection:()Ljava/util/Collection;
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 26
         5: .line 714
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmpeq 26
         6: .line 716
            new java.util.EnumMap
            dup
            ldc Lsun/security/ssl/NamedGroupType;
            invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
         7: .line 715
            astore 2 /* cachedStatus */
        start local 2 // java.util.Map cachedStatus
         8: .line 717
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.enabledCipherSuites:Lsun/security/ssl/CipherSuiteList;
            invokevirtual sun.security.ssl.CipherSuiteList.collection:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 25
      StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList java.util.Map top java.util.Iterator
      StackMap stack:
         9: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.CipherSuite
            astore 3 /* suite */
        start local 3 // sun.security.ssl.CipherSuite suite
        10: .line 718
            aload 3 /* suite */
            invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
            ifeq 16
        11: .line 719
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
            aload 3 /* suite */
            invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
            ifne 16
        12: .line 720
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            getfield sun.security.ssl.ProtocolList.max:Lsun/security/ssl/ProtocolVersion;
            aload 3 /* suite */
            invokevirtual sun.security.ssl.ProtocolVersion.supports:(Lsun/security/ssl/CipherSuite;)Z
            ifeq 16
        13: .line 721
            aload 0 /* this */
            aload 3 /* suite */
            aload 2 /* cachedStatus */
            invokevirtual sun.security.ssl.Handshaker.isActivatable:(Lsun/security/ssl/CipherSuite;Ljava/util/Map;)Z
            ifeq 25
        14: .line 722
            aload 1 /* suites */
            aload 3 /* suite */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        15: .line 724
            goto 25
      StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList java.util.Map sun.security.ssl.CipherSuite java.util.Iterator
      StackMap stack:
        16: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 25
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 25
        17: .line 725
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
            aload 3 /* suite */
            invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
            ifeq 22
        18: .line 726
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        19: .line 727
            new java.lang.StringBuilder
            dup
            ldc "Ignoring obsoleted cipher suite: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* suite */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        20: .line 726
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        21: .line 728
            goto 25
        22: .line 729
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        23: .line 730
            new java.lang.StringBuilder
            dup
            ldc "Ignoring unsupported cipher suite: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* suite */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        24: .line 729
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 3 // sun.security.ssl.CipherSuite suite
        25: .line 717
      StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList java.util.Map top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        end local 2 // java.util.Map cachedStatus
        26: .line 735
      StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList
      StackMap stack:
            aload 0 /* this */
            new sun.security.ssl.CipherSuiteList
            dup
            aload 1 /* suites */
            invokespecial sun.security.ssl.CipherSuiteList.<init>:(Ljava/util/Collection;)V
            putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
        end local 1 // java.util.ArrayList suites
        27: .line 738
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   28     0          this  Lsun/security/ssl/Handshaker;
            4   27     1        suites  Ljava/util/ArrayList<Lsun/security/ssl/CipherSuite;>;
            8   26     2  cachedStatus  Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;
           10   25     3         suite  Lsun/security/ssl/CipherSuite;

  sun.security.ssl.ProtocolList getActiveProtocols();
    descriptor: ()Lsun/security/ssl/ProtocolList;
    flags: (0x0000) 
    Code:
      stack=4, locals=9, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 757
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            ifnonnull 44
         1: .line 758
            iconst_0
            istore 1 /* enabledSSL20Hello */
        start local 1 // boolean enabledSSL20Hello
         2: .line 761
            new java.util.ArrayList
            dup
            iconst_4
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 2 /* protocols */
        start local 2 // java.util.ArrayList protocols
         3: .line 762
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.enabledProtocols:Lsun/security/ssl/ProtocolList;
            invokevirtual sun.security.ssl.ProtocolList.collection:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 40
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList top java.util.Iterator
      StackMap stack:
         4: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 3 /* protocol */
        start local 3 // sun.security.ssl.ProtocolVersion protocol
         5: .line 764
            aload 3 /* protocol */
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmpne 8
         6: .line 765
            iconst_1
            istore 1 /* enabledSSL20Hello */
         7: .line 766
            goto 40
         8: .line 769
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
         9: .line 770
            getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
            invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
        10: .line 771
            aload 3 /* protocol */
            getfield sun.security.ssl.ProtocolVersion.name:Ljava/lang/String;
            aconst_null
        11: .line 769
            invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
        12: .line 771
            ifne 18
        13: .line 772
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 40
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 40
        14: .line 773
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        15: .line 774
            new java.lang.StringBuilder
            dup
            ldc "Ignoring disabled protocol: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* protocol */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        16: .line 773
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        17: .line 777
            goto 40
        18: .line 780
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 5 /* found */
        start local 5 // boolean found
        19: .line 782
            new java.util.EnumMap
            dup
            ldc Lsun/security/ssl/NamedGroupType;
            invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
        20: .line 781
            astore 6 /* cachedStatus */
        start local 6 // java.util.Map cachedStatus
        21: .line 783
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.enabledCipherSuites:Lsun/security/ssl/CipherSuiteList;
            invokevirtual sun.security.ssl.CipherSuiteList.collection:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 8
            goto 35
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map top java.util.Iterator
      StackMap stack:
        22: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.CipherSuite
            astore 7 /* suite */
        start local 7 // sun.security.ssl.CipherSuite suite
        23: .line 784
            aload 7 /* suite */
            invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
            ifeq 29
            aload 3 /* protocol */
            aload 7 /* suite */
            invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
            ifne 29
        24: .line 785
            aload 3 /* protocol */
            aload 7 /* suite */
            invokevirtual sun.security.ssl.ProtocolVersion.supports:(Lsun/security/ssl/CipherSuite;)Z
            ifeq 29
        25: .line 786
            aload 0 /* this */
            aload 7 /* suite */
            aload 6 /* cachedStatus */
            invokevirtual sun.security.ssl.Handshaker.isActivatable:(Lsun/security/ssl/CipherSuite;Ljava/util/Map;)Z
            ifeq 35
        26: .line 787
            aload 2 /* protocols */
            aload 3 /* protocol */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        27: .line 788
            iconst_1
            istore 5 /* found */
        28: .line 789
            goto 36
        29: .line 791
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map sun.security.ssl.CipherSuite java.util.Iterator
      StackMap stack:
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 35
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 35
        30: .line 792
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        31: .line 793
            new java.lang.StringBuilder
            dup
            ldc "Ignoring unsupported cipher suite: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 7 /* suite */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        32: .line 794
            ldc " for "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* protocol */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        33: .line 793
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 792
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 7 // sun.security.ssl.CipherSuite suite
        35: .line 783
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 22
        36: .line 798
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map
      StackMap stack:
            iload 5 /* found */
            ifne 40
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 40
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 40
        37: .line 799
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        38: .line 800
            new java.lang.StringBuilder
            dup
            ldc "No available cipher suite for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* protocol */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        39: .line 799
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 6 // java.util.Map cachedStatus
        end local 5 // boolean found
        end local 3 // sun.security.ssl.ProtocolVersion protocol
        40: .line 762
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        41: .line 804
            aload 2 /* protocols */
            invokevirtual java.util.ArrayList.isEmpty:()Z
            ifne 43
            iload 1 /* enabledSSL20Hello */
            ifeq 43
        42: .line 805
            aload 2 /* protocols */
            getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        43: .line 808
      StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList
      StackMap stack:
            aload 0 /* this */
            new sun.security.ssl.ProtocolList
            dup
            aload 2 /* protocols */
            invokespecial sun.security.ssl.ProtocolList.<init>:(Ljava/util/ArrayList;)V
            putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
        end local 2 // java.util.ArrayList protocols
        end local 1 // boolean enabledSSL20Hello
        44: .line 811
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   45     0               this  Lsun/security/ssl/Handshaker;
            2   44     1  enabledSSL20Hello  Z
            3   44     2          protocols  Ljava/util/ArrayList<Lsun/security/ssl/ProtocolVersion;>;
            5   40     3           protocol  Lsun/security/ssl/ProtocolVersion;
           19   40     5              found  Z
           21   40     6       cachedStatus  Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;
           23   35     7              suite  Lsun/security/ssl/CipherSuite;

  private boolean isActivatable(sun.security.ssl.CipherSuite, java.util.Map<sun.security.ssl.NamedGroupType, java.lang.Boolean>);
    descriptor: (Lsun/security/ssl/CipherSuite;Ljava/util/Map;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.CipherSuite suite
        start local 2 // java.util.Map cachedStatus
         0: .line 817
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
         1: .line 818
            getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
            invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
            aload 1 /* suite */
            getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
            aconst_null
         2: .line 817
            invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
         3: .line 818
            ifeq 22
         4: .line 819
            iconst_1
            istore 3 /* available */
        start local 3 // boolean available
         5: .line 820
            aload 1 /* suite */
            getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
            getfield sun.security.ssl.CipherSuite$KeyExchange.groupType:Lsun/security/ssl/NamedGroupType;
            astore 4 /* groupType */
        start local 4 // sun.security.ssl.NamedGroupType groupType
         6: .line 821
            aload 4 /* groupType */
            getstatic sun.security.ssl.NamedGroupType.NAMED_GROUP_NONE:Lsun/security/ssl/NamedGroupType;
            if_acmpeq 21
         7: .line 822
            aload 2 /* cachedStatus */
            aload 4 /* groupType */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            astore 5 /* checkedStatus */
        start local 5 // java.lang.Boolean checkedStatus
         8: .line 823
            aload 5 /* checkedStatus */
            ifnonnull 15
         9: .line 825
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
            aload 4 /* groupType */
        10: .line 824
            invokestatic sun.security.ssl.SupportedGroupsExtension.isActivatable:(Ljava/security/AlgorithmConstraints;Lsun/security/ssl/NamedGroupType;)Z
            istore 3 /* available */
        11: .line 826
            aload 2 /* cachedStatus */
            aload 4 /* groupType */
            iload 3 /* available */
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        12: .line 828
            iload 3 /* available */
            ifne 16
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 16
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 16
        13: .line 829
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "No activated named group"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        14: .line 831
            goto 16
        15: .line 832
      StackMap locals: int sun.security.ssl.NamedGroupType java.lang.Boolean
      StackMap stack:
            aload 5 /* checkedStatus */
            invokevirtual java.lang.Boolean.booleanValue:()Z
            istore 3 /* available */
        16: .line 835
      StackMap locals:
      StackMap stack:
            iload 3 /* available */
            ifne 20
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 20
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 20
        17: .line 836
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        18: .line 837
            new java.lang.StringBuilder
            dup
            ldc "No active named group, ignore "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* suite */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 836
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        20: .line 840
      StackMap locals:
      StackMap stack:
            iload 3 /* available */
            ireturn
        end local 5 // java.lang.Boolean checkedStatus
        21: .line 842
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 4 // sun.security.ssl.NamedGroupType groupType
        end local 3 // boolean available
        22: .line 844
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 24
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 24
        23: .line 845
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Ignoring disabled cipher suite: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* suite */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        24: .line 848
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
        end local 2 // java.util.Map cachedStatus
        end local 1 // sun.security.ssl.CipherSuite suite
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   25     0           this  Lsun/security/ssl/Handshaker;
            0   25     1          suite  Lsun/security/ssl/CipherSuite;
            0   25     2   cachedStatus  Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;
            5   22     3      available  Z
            6   22     4      groupType  Lsun/security/ssl/NamedGroupType;
            8   21     5  checkedStatus  Ljava/lang/Boolean;
    Signature: (Lsun/security/ssl/CipherSuite;Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;)Z
    MethodParameters:
              Name  Flags
      suite         
      cachedStatus  

  void setEnableSessionCreation(boolean);
    descriptor: (Z)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // boolean newSessions
         0: .line 859
            aload 0 /* this */
            iload 1 /* newSessions */
            putfield sun.security.ssl.Handshaker.enableNewSession:Z
         1: .line 860
            return
        end local 1 // boolean newSessions
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lsun/security/ssl/Handshaker;
            0    2     1  newSessions  Z
    MethodParameters:
             Name  Flags
      newSessions  

  sun.security.ssl.CipherBox newReadCipher();
    descriptor: ()Lsun/security/ssl/CipherBox;
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 866
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
            astore 1 /* cipher */
        start local 1 // sun.security.ssl.CipherSuite$BulkCipher cipher
         1: .line 868
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            ifeq 8
         2: .line 869
            aload 1 /* cipher */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
         3: .line 870
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
            iconst_0
         4: .line 869
            invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
            astore 2 /* box */
        start local 2 // sun.security.ssl.CipherBox box
         5: .line 871
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
         6: .line 872
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
         7: .line 873
            goto 13
        end local 2 // sun.security.ssl.CipherBox box
         8: .line 874
      StackMap locals: sun.security.ssl.CipherSuite$BulkCipher
      StackMap stack:
            aload 1 /* cipher */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
         9: .line 875
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
            iconst_0
        10: .line 874
            invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
            astore 2 /* box */
        start local 2 // sun.security.ssl.CipherBox box
        11: .line 876
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
        12: .line 877
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
        13: .line 879
      StackMap locals: sun.security.ssl.CipherBox
      StackMap stack:
            aload 2 /* box */
            areturn
        end local 2 // sun.security.ssl.CipherBox box
        end local 1 // sun.security.ssl.CipherSuite$BulkCipher cipher
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   14     0    this  Lsun/security/ssl/Handshaker;
            1   14     1  cipher  Lsun/security/ssl/CipherSuite$BulkCipher;
            5    8     2     box  Lsun/security/ssl/CipherBox;
           11   14     2     box  Lsun/security/ssl/CipherBox;
    Exceptions:
      throws java.security.NoSuchAlgorithmException

  sun.security.ssl.CipherBox newWriteCipher();
    descriptor: ()Lsun/security/ssl/CipherBox;
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 886
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
            astore 1 /* cipher */
        start local 1 // sun.security.ssl.CipherSuite$BulkCipher cipher
         1: .line 888
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            ifeq 8
         2: .line 889
            aload 1 /* cipher */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
         3: .line 890
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
            iconst_1
         4: .line 889
            invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
            astore 2 /* box */
        start local 2 // sun.security.ssl.CipherBox box
         5: .line 891
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
         6: .line 892
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
         7: .line 893
            goto 13
        end local 2 // sun.security.ssl.CipherBox box
         8: .line 894
      StackMap locals: sun.security.ssl.CipherSuite$BulkCipher
      StackMap stack:
            aload 1 /* cipher */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
         9: .line 895
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
            iconst_1
        10: .line 894
            invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
            astore 2 /* box */
        start local 2 // sun.security.ssl.CipherBox box
        11: .line 896
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
        12: .line 897
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
        13: .line 899
      StackMap locals: sun.security.ssl.CipherBox
      StackMap stack:
            aload 2 /* box */
            areturn
        end local 2 // sun.security.ssl.CipherBox box
        end local 1 // sun.security.ssl.CipherSuite$BulkCipher cipher
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   14     0    this  Lsun/security/ssl/Handshaker;
            1   14     1  cipher  Lsun/security/ssl/CipherSuite$BulkCipher;
            5    8     2     box  Lsun/security/ssl/CipherBox;
           11   14     2     box  Lsun/security/ssl/CipherBox;
    Exceptions:
      throws java.security.NoSuchAlgorithmException

  sun.security.ssl.Authenticator newReadAuthenticator();
    descriptor: ()Lsun/security/ssl/Authenticator;
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 908
            aconst_null
            astore 1 /* authenticator */
        start local 1 // sun.security.ssl.Authenticator authenticator
         1: .line 909
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
            getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
            getstatic sun.security.ssl.CipherSuite$CipherType.AEAD_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
            if_acmpne 4
         2: .line 910
            new sun.security.ssl.Authenticator
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokespecial sun.security.ssl.Authenticator.<init>:(Lsun/security/ssl/ProtocolVersion;)V
            astore 1 /* authenticator */
         3: .line 911
            goto 11
         4: .line 912
      StackMap locals: sun.security.ssl.Authenticator
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.macAlg:Lsun/security/ssl/CipherSuite$MacAlg;
            astore 2 /* macAlg */
        start local 2 // sun.security.ssl.CipherSuite$MacAlg macAlg
         5: .line 913
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            ifeq 9
         6: .line 914
            aload 2 /* macAlg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
            invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
            astore 1 /* authenticator */
         7: .line 915
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
         8: .line 916
            goto 11
         9: .line 917
      StackMap locals: sun.security.ssl.CipherSuite$MacAlg
      StackMap stack:
            aload 2 /* macAlg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
            invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
            astore 1 /* authenticator */
        10: .line 918
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
        end local 2 // sun.security.ssl.CipherSuite$MacAlg macAlg
        11: .line 922
      StackMap locals:
      StackMap stack:
            aload 1 /* authenticator */
            areturn
        end local 1 // sun.security.ssl.Authenticator authenticator
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Lsun/security/ssl/Handshaker;
            1   12     1  authenticator  Lsun/security/ssl/Authenticator;
            5   11     2         macAlg  Lsun/security/ssl/CipherSuite$MacAlg;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException

  sun.security.ssl.Authenticator newWriteAuthenticator();
    descriptor: ()Lsun/security/ssl/Authenticator;
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 931
            aconst_null
            astore 1 /* authenticator */
        start local 1 // sun.security.ssl.Authenticator authenticator
         1: .line 932
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
            getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
            getstatic sun.security.ssl.CipherSuite$CipherType.AEAD_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
            if_acmpne 4
         2: .line 933
            new sun.security.ssl.Authenticator
            dup
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokespecial sun.security.ssl.Authenticator.<init>:(Lsun/security/ssl/ProtocolVersion;)V
            astore 1 /* authenticator */
         3: .line 934
            goto 11
         4: .line 935
      StackMap locals: sun.security.ssl.Authenticator
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.macAlg:Lsun/security/ssl/CipherSuite$MacAlg;
            astore 2 /* macAlg */
        start local 2 // sun.security.ssl.CipherSuite$MacAlg macAlg
         5: .line 936
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            ifeq 9
         6: .line 937
            aload 2 /* macAlg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
            invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
            astore 1 /* authenticator */
         7: .line 938
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
         8: .line 939
            goto 11
         9: .line 940
      StackMap locals: sun.security.ssl.CipherSuite$MacAlg
      StackMap stack:
            aload 2 /* macAlg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
            invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
            astore 1 /* authenticator */
        10: .line 941
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
        end local 2 // sun.security.ssl.CipherSuite$MacAlg macAlg
        11: .line 945
      StackMap locals:
      StackMap stack:
            aload 1 /* authenticator */
            areturn
        end local 1 // sun.security.ssl.Authenticator authenticator
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Lsun/security/ssl/Handshaker;
            1   12     1  authenticator  Lsun/security/ssl/Authenticator;
            5   11     2         macAlg  Lsun/security/ssl/CipherSuite$MacAlg;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException

  boolean isDone();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 953
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.started:()Z
            ifeq 1
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
            invokevirtual sun.security.ssl.HandshakeStateManager.isEmpty:()Z
            ifeq 1
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeFinished:Z
            ifeq 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/Handshaker;

  sun.security.ssl.SSLSessionImpl getSession();
    descriptor: ()Lsun/security/ssl/SSLSessionImpl;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 963
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.session:Lsun/security/ssl/SSLSessionImpl;
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/Handshaker;

  void setHandshakeSessionSE(sun.security.ssl.SSLSessionImpl);
    descriptor: (Lsun/security/ssl/SSLSessionImpl;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.SSLSessionImpl handshakeSession
         0: .line 970
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 3
         1: .line 971
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            aload 1 /* handshakeSession */
            invokevirtual sun.security.ssl.SSLSocketImpl.setHandshakeSession:(Lsun/security/ssl/SSLSessionImpl;)V
         2: .line 972
            goto 4
         3: .line 973
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            aload 1 /* handshakeSession */
            invokevirtual sun.security.ssl.SSLEngineImpl.setHandshakeSession:(Lsun/security/ssl/SSLSessionImpl;)V
         4: .line 975
      StackMap locals:
      StackMap stack:
            return
        end local 1 // sun.security.ssl.SSLSessionImpl handshakeSession
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    5     0              this  Lsun/security/ssl/Handshaker;
            0    5     1  handshakeSession  Lsun/security/ssl/SSLSessionImpl;
    MethodParameters:
                  Name  Flags
      handshakeSession  

  void expectingFinishFlightSE();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 978
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 3
         1: .line 979
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.expectingFinishFlight:()V
         2: .line 980
            goto 4
         3: .line 981
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            invokevirtual sun.security.ssl.SSLEngineImpl.expectingFinishFlight:()V
         4: .line 983
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/ssl/Handshaker;

  boolean isSecureRenegotiation();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 989
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.secureRenegotiation:Z
            ireturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/Handshaker;

  byte[] getClientVerifyData();
    descriptor: ()[B
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 996
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clientVerifyData:[B
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/Handshaker;

  byte[] getServerVerifyData();
    descriptor: ()[B
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1003
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.serverVerifyData:[B
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/Handshaker;

  void processRecord(java.nio.ByteBuffer, boolean);
    descriptor: (Ljava/nio/ByteBuffer;Z)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.nio.ByteBuffer record
        start local 2 // boolean expectingFinished
         0: .line 1013
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.checkThrown:()V
         1: .line 1019
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
            aload 1 /* record */
            invokevirtual sun.security.ssl.HandshakeInStream.incomingRecord:(Ljava/nio/ByteBuffer;)V
         2: .line 1025
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnonnull 3
            iload 2 /* expectingFinished */
            ifeq 5
         3: .line 1026
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.processLoop:()V
         4: .line 1027
            goto 6
         5: .line 1028
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new sun.security.ssl.Handshaker$1
            dup
            aload 0 /* this */
            invokespecial sun.security.ssl.Handshaker$1.<init>:(Lsun/security/ssl/Handshaker;)V
            invokevirtual sun.security.ssl.Handshaker.delegateTask:(Ljava/security/PrivilegedExceptionAction;)V
         6: .line 1036
      StackMap locals:
      StackMap stack:
            return
        end local 2 // boolean expectingFinished
        end local 1 // java.nio.ByteBuffer record
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    7     0               this  Lsun/security/ssl/Handshaker;
            0    7     1             record  Ljava/nio/ByteBuffer;
            0    7     2  expectingFinished  Z
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                   Name  Flags
      record             
      expectingFinished  

  void processLoop();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1051
            goto 22
         1: .line 1060
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
            iconst_4
            invokevirtual sun.security.ssl.HandshakeInStream.mark:(I)V
         2: .line 1062
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
            invokevirtual sun.security.ssl.HandshakeInStream.getInt8:()I
            i2b
            istore 1 /* messageType */
        start local 1 // byte messageType
         3: .line 1063
            iload 1 /* messageType */
            invokestatic sun.security.ssl.HandshakeMessage.isUnsupported:(B)Z
            ifeq 9
         4: .line 1064
            new javax.net.ssl.SSLProtocolException
            dup
         5: .line 1065
            new java.lang.StringBuilder
            dup
            ldc "Received unsupported or unknown handshake message: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 1066
            iload 1 /* messageType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         7: .line 1065
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 1064
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 1069
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
            invokevirtual sun.security.ssl.HandshakeInStream.getInt24:()I
            istore 2 /* messageLen */
        start local 2 // int messageLen
        10: .line 1071
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
            invokevirtual sun.security.ssl.HandshakeInStream.available:()I
            iload 2 /* messageLen */
            if_icmpge 13
        11: .line 1072
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
            invokevirtual sun.security.ssl.HandshakeInStream.reset:()V
        12: .line 1073
            return
        13: .line 1077
      StackMap locals: int
      StackMap stack:
            iload 1 /* messageType */
            iconst_1
            if_icmpne 16
        14: .line 1078
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
        15: .line 1079
            goto 18
      StackMap locals:
      StackMap stack:
        16: iload 1 /* messageType */
            ifne 18
        17: .line 1080
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.serverHelloRequested:Z
        18: .line 1098
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* messageType */
            iload 2 /* messageLen */
            invokevirtual sun.security.ssl.Handshaker.processMessage:(BI)V
        19: .line 1104
            iload 1 /* messageType */
            bipush 20
            if_icmpeq 21
        20: .line 1105
            iload 1 /* messageType */
            bipush 15
            if_icmpne 22
        21: .line 1107
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.HandshakeHash.reload:()V
        end local 2 // int messageLen
        end local 1 // byte messageType
        22: .line 1051
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
            invokevirtual sun.security.ssl.HandshakeInStream.available:()I
            iconst_4
            if_icmpge 1
        23: .line 1110
            return
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   24     0         this  Lsun/security/ssl/Handshaker;
            3   22     1  messageType  B
           10   22     2   messageLen  I
    Exceptions:
      throws java.io.IOException

  boolean activated();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1119
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeActivated:Z
            ireturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/Handshaker;

  boolean started();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1126
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.serverHelloRequested:Z
            ifne 1
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
            ifne 1
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_1
            ireturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/Handshaker;

  void kickstart();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1135
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            ifeq 1
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
            ifne 2
         1: .line 1136
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            ifne 3
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.serverHelloRequested:Z
            ifeq 3
         2: .line 1137
      StackMap locals:
      StackMap stack:
            return
         3: .line 1140
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.Handshaker.getKickstartMessage:()Lsun/security/ssl/HandshakeMessage;
            astore 1 /* m */
        start local 1 // sun.security.ssl.HandshakeMessage m
         4: .line 1141
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
            aload 1 /* m */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.resumingSession:Z
            invokevirtual sun.security.ssl.HandshakeStateManager.update:(Lsun/security/ssl/HandshakeMessage;Z)V
         5: .line 1143
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 7
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 7
         6: .line 1144
            aload 1 /* m */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual sun.security.ssl.HandshakeMessage.print:(Ljava/io/PrintStream;)V
         7: .line 1146
      StackMap locals: sun.security.ssl.HandshakeMessage
      StackMap stack:
            aload 1 /* m */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeMessage.write:(Lsun/security/ssl/HandshakeOutStream;)V
         8: .line 1147
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
         9: .line 1150
            aload 1 /* m */
            invokevirtual sun.security.ssl.HandshakeMessage.messageType:()I
            istore 2 /* handshakeType */
        start local 2 // int handshakeType
        10: .line 1151
            iload 2 /* handshakeType */
            ifne 13
        11: .line 1152
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.serverHelloRequested:Z
        12: .line 1153
            goto 14
        13: .line 1154
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
        14: .line 1156
      StackMap locals:
      StackMap stack:
            return
        end local 2 // int handshakeType
        end local 1 // sun.security.ssl.HandshakeMessage m
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   15     0           this  Lsun/security/ssl/Handshaker;
            4   15     1              m  Lsun/security/ssl/HandshakeMessage;
           10   15     2  handshakeType  I
    Exceptions:
      throws java.io.IOException

  abstract sun.security.ssl.HandshakeMessage getKickstartMessage();
    descriptor: ()Lsun/security/ssl/HandshakeMessage;
    flags: (0x0400) ACC_ABSTRACT
    Exceptions:
      throws javax.net.ssl.SSLException

  abstract void processMessage(byte, int);
    descriptor: (BI)V
    flags: (0x0400) ACC_ABSTRACT
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      messageType  
      messageLen   

  abstract void handshakeAlert(byte);
    descriptor: (B)V
    flags: (0x0400) ACC_ABSTRACT
    Exceptions:
      throws javax.net.ssl.SSLProtocolException
    MethodParameters:
             Name  Flags
      description  

  void sendChangeCipherSpec(sun.security.ssl.HandshakeMessage$Finished, boolean);
    descriptor: (Lsun/security/ssl/HandshakeMessage$Finished;Z)V
    flags: (0x0000) 
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // sun.security.ssl.HandshakeMessage$Finished mesg
        start local 2 // boolean lastMessage
         0: .line 1185
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
         1: .line 1197
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            ifnull 16
         2: .line 1198
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.writeLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         3: .line 1200
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
            iconst_0
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            invokevirtual sun.security.ssl.HandshakeStateManager.changeCipherSpec:(ZZ)V
         4: .line 1201
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            invokevirtual sun.security.ssl.SSLSocketImpl.changeWriteCiphers:()V
         5: .line 1202
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 7
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 7
         6: .line 1203
            aload 1 /* mesg */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual sun.security.ssl.HandshakeMessage$Finished.print:(Ljava/io/PrintStream;)V
         7: .line 1206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
            aload 1 /* mesg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.resumingSession:Z
            invokevirtual sun.security.ssl.HandshakeStateManager.update:(Lsun/security/ssl/HandshakeMessage;Z)V
         8: .line 1207
            aload 1 /* mesg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeMessage$Finished.write:(Lsun/security/ssl/HandshakeOutStream;)V
         9: .line 1208
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
        10: .line 1209
            goto 14
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: astore 3
        12: .line 1210
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.writeLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        13: .line 1211
            aload 3
            athrow
        14: .line 1210
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
            getfield sun.security.ssl.SSLSocketImpl.writeLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        15: .line 1212
            goto 28
        16: .line 1213
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            getfield sun.security.ssl.SSLEngineImpl.writeLock:Ljava/lang/Object;
            dup
            astore 3
            monitorenter
        17: .line 1214
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
            iconst_0
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            invokevirtual sun.security.ssl.HandshakeStateManager.changeCipherSpec:(ZZ)V
        18: .line 1215
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
            invokevirtual sun.security.ssl.SSLEngineImpl.changeWriteCiphers:()V
        19: .line 1216
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 21
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 21
        20: .line 1217
            aload 1 /* mesg */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual sun.security.ssl.HandshakeMessage$Finished.print:(Ljava/io/PrintStream;)V
        21: .line 1220
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
            aload 1 /* mesg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.resumingSession:Z
            invokevirtual sun.security.ssl.HandshakeStateManager.update:(Lsun/security/ssl/HandshakeMessage;Z)V
        22: .line 1221
            aload 1 /* mesg */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeMessage$Finished.write:(Lsun/security/ssl/HandshakeOutStream;)V
        23: .line 1222
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
            invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
        24: .line 1213
            aload 3
            monitorexit
        25: goto 28
      StackMap locals:
      StackMap stack: java.lang.Throwable
        26: aload 3
            monitorexit
        27: athrow
        28: .line 1226
      StackMap locals:
      StackMap stack:
            iload 2 /* lastMessage */
            ifeq 30
        29: .line 1227
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.handshakeFinished:Z
        30: .line 1229
      StackMap locals:
      StackMap stack:
            return
        end local 2 // boolean lastMessage
        end local 1 // sun.security.ssl.HandshakeMessage$Finished mesg
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   31     0         this  Lsun/security/ssl/Handshaker;
            0   31     1         mesg  Lsun/security/ssl/HandshakeMessage$Finished;
            0   31     2  lastMessage  Z
      Exception table:
        from    to  target  type
           3    11      11  any
          17    25      26  any
          26    27      26  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
             Name  Flags
      mesg         
      lastMessage  

  void receiveChangeCipherSpec();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1232
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
            iconst_1
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.isClient:Z
            invokevirtual sun.security.ssl.HandshakeStateManager.changeCipherSpec:(ZZ)V
         1: .line 1233
            return
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/Handshaker;
    Exceptions:
      throws java.io.IOException

  void calculateKeys(javax.crypto.SecretKey, sun.security.ssl.ProtocolVersion);
    descriptor: (Ljavax/crypto/SecretKey;Lsun/security/ssl/ProtocolVersion;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // javax.crypto.SecretKey preMasterSecret
        start local 2 // sun.security.ssl.ProtocolVersion version
         0: .line 1241
            aload 0 /* this */
            aload 1 /* preMasterSecret */
            aload 2 /* version */
            invokevirtual sun.security.ssl.Handshaker.calculateMasterSecret:(Ljavax/crypto/SecretKey;Lsun/security/ssl/ProtocolVersion;)Ljavax/crypto/SecretKey;
            astore 3 /* master */
        start local 3 // javax.crypto.SecretKey master
         1: .line 1242
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.session:Lsun/security/ssl/SSLSessionImpl;
            aload 3 /* master */
            invokevirtual sun.security.ssl.SSLSessionImpl.setMasterSecret:(Ljavax/crypto/SecretKey;)V
         2: .line 1243
            aload 0 /* this */
            aload 3 /* master */
            invokevirtual sun.security.ssl.Handshaker.calculateConnectionKeys:(Ljavax/crypto/SecretKey;)V
         3: .line 1244
            return
        end local 3 // javax.crypto.SecretKey master
        end local 2 // sun.security.ssl.ProtocolVersion version
        end local 1 // javax.crypto.SecretKey preMasterSecret
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    4     0             this  Lsun/security/ssl/Handshaker;
            0    4     1  preMasterSecret  Ljavax/crypto/SecretKey;
            0    4     2          version  Lsun/security/ssl/ProtocolVersion;
            1    4     3           master  Ljavax/crypto/SecretKey;
    MethodParameters:
                 Name  Flags
      preMasterSecret  
      version          

  private javax.crypto.SecretKey calculateMasterSecret(javax.crypto.SecretKey, sun.security.ssl.ProtocolVersion);
    descriptor: (Ljavax/crypto/SecretKey;Lsun/security/ssl/ProtocolVersion;)Ljavax/crypto/SecretKey;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=10, locals=13, args_size=3
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // javax.crypto.SecretKey preMasterSecret
        start local 2 // sun.security.ssl.ProtocolVersion requestedVersion
         0: .line 1259
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 5
            ldc "keygen"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 5
         1: .line 1260
            new sun.security.util.HexDumpEncoder
            dup
            invokespecial sun.security.util.HexDumpEncoder.<init>:()V
            astore 3 /* dump */
        start local 3 // sun.security.util.HexDumpEncoder dump
         2: .line 1262
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "SESSION KEYGEN:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         3: .line 1264
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "PreMaster Secret:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         4: .line 1265
            aload 3 /* dump */
            aload 1 /* preMasterSecret */
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        end local 3 // sun.security.util.HexDumpEncoder dump
         5: .line 1275
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.major:B
            istore 5 /* majorVersion */
        start local 5 // byte majorVersion
         6: .line 1276
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.minor:B
            istore 6 /* minorVersion */
        start local 6 // byte minorVersion
         7: .line 1277
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.isDTLSProtocol:()Z
            ifeq 19
         8: .line 1279
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.DTLS10:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmpne 14
         9: .line 1280
            getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.major:B
            istore 5 /* majorVersion */
        10: .line 1281
            getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.minor:B
            istore 6 /* minorVersion */
        11: .line 1283
            ldc "SunTlsMasterSecret"
            astore 3 /* masterAlg */
        start local 3 // java.lang.String masterAlg
        12: .line 1284
            getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
            astore 4 /* prf */
        start local 4 // sun.security.ssl.CipherSuite$PRF prf
        13: .line 1285
            goto 25
        end local 4 // sun.security.ssl.CipherSuite$PRF prf
        end local 3 // java.lang.String masterAlg
        14: .line 1286
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion top top int int
      StackMap stack:
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.major:B
            istore 5 /* majorVersion */
        15: .line 1287
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.minor:B
            istore 6 /* minorVersion */
        16: .line 1289
            ldc "SunTls12MasterSecret"
            astore 3 /* masterAlg */
        start local 3 // java.lang.String masterAlg
        17: .line 1290
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
            astore 4 /* prf */
        start local 4 // sun.security.ssl.CipherSuite$PRF prf
        18: .line 1292
            goto 25
        end local 4 // sun.security.ssl.CipherSuite$PRF prf
        end local 3 // java.lang.String masterAlg
        19: .line 1293
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmplt 23
        20: .line 1294
            ldc "SunTls12MasterSecret"
            astore 3 /* masterAlg */
        start local 3 // java.lang.String masterAlg
        21: .line 1295
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
            astore 4 /* prf */
        start local 4 // sun.security.ssl.CipherSuite$PRF prf
        22: .line 1296
            goto 25
        end local 4 // sun.security.ssl.CipherSuite$PRF prf
        end local 3 // java.lang.String masterAlg
        23: .line 1297
      StackMap locals:
      StackMap stack:
            ldc "SunTlsMasterSecret"
            astore 3 /* masterAlg */
        start local 3 // java.lang.String masterAlg
        24: .line 1298
            getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
            astore 4 /* prf */
        start local 4 // sun.security.ssl.CipherSuite$PRF prf
        25: .line 1302
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.CipherSuite$PRF int int
      StackMap stack:
            aload 4 /* prf */
            invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashAlg:()Ljava/lang/String;
            astore 7 /* prfHashAlg */
        start local 7 // java.lang.String prfHashAlg
        26: .line 1303
            aload 4 /* prf */
            invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashLength:()I
            istore 8 /* prfHashLength */
        start local 8 // int prfHashLength
        27: .line 1304
            aload 4 /* prf */
            invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFBlockSize:()I
            istore 9 /* prfBlockSize */
        start local 9 // int prfBlockSize
        28: .line 1307
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.session:Lsun/security/ssl/SSLSessionImpl;
            invokevirtual sun.security.ssl.SSLSessionImpl.getUseExtendedMasterSecret:()Z
            ifeq 47
        29: .line 1309
            ldc "SunTlsExtendedMasterSecret"
            astore 3 /* masterAlg */
        30: .line 1311
            aconst_null
            astore 11 /* sessionHash */
        start local 11 // byte[] sessionHash
        31: .line 1312
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS12PlusSpec:()Z
            ifeq 34
        32: .line 1313
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.HandshakeHash.getFinishedHash:()[B
            astore 11 /* sessionHash */
        33: .line 1314
            goto 40
        34: .line 1316
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int top byte[]
      StackMap stack:
            bipush 36
            newarray 8
            astore 11 /* sessionHash */
        35: .line 1318
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.HandshakeHash.getMD5Clone:()Ljava/security/MessageDigest;
            aload 11 /* sessionHash */
            iconst_0
            bipush 16
            invokevirtual java.security.MessageDigest.digest:([BII)I
            pop
        36: .line 1319
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
            invokevirtual sun.security.ssl.HandshakeHash.getSHAClone:()Ljava/security/MessageDigest;
            aload 11 /* sessionHash */
            bipush 16
            bipush 20
            invokevirtual java.security.MessageDigest.digest:([BII)I
            pop
        37: .line 1320
            goto 40
      StackMap locals:
      StackMap stack: java.security.DigestException
        38: astore 12 /* de */
        start local 12 // java.security.DigestException de
        39: .line 1321
            new java.security.ProviderException
            dup
            aload 12 /* de */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 12 // java.security.DigestException de
        40: .line 1325
      StackMap locals:
      StackMap stack:
            new sun.security.internal.spec.TlsMasterSecretParameterSpec
            dup
        41: .line 1326
            aload 1 /* preMasterSecret */
        42: .line 1327
            iload 5 /* majorVersion */
            sipush 255
            iand
            iload 6 /* minorVersion */
            sipush 255
            iand
        43: .line 1328
            aload 11 /* sessionHash */
        44: .line 1329
            aload 7 /* prfHashAlg */
            iload 8 /* prfHashLength */
            iload 9 /* prfBlockSize */
        45: .line 1325
            invokespecial sun.security.internal.spec.TlsMasterSecretParameterSpec.<init>:(Ljavax/crypto/SecretKey;II[BLjava/lang/String;II)V
            astore 10 /* spec */
        end local 11 // byte[] sessionHash
        start local 10 // sun.security.internal.spec.TlsMasterSecretParameterSpec spec
        46: .line 1330
            goto 53
        end local 10 // sun.security.internal.spec.TlsMasterSecretParameterSpec spec
        47: .line 1331
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int
      StackMap stack:
            new sun.security.internal.spec.TlsMasterSecretParameterSpec
            dup
        48: .line 1332
            aload 1 /* preMasterSecret */
        49: .line 1333
            iload 5 /* majorVersion */
            sipush 255
            iand
            iload 6 /* minorVersion */
            sipush 255
            iand
        50: .line 1334
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clnt_random:Lsun/security/ssl/RandomCookie;
            getfield sun.security.ssl.RandomCookie.random_bytes:[B
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svr_random:Lsun/security/ssl/RandomCookie;
            getfield sun.security.ssl.RandomCookie.random_bytes:[B
        51: .line 1335
            aload 7 /* prfHashAlg */
            iload 8 /* prfHashLength */
            iload 9 /* prfBlockSize */
        52: .line 1331
            invokespecial sun.security.internal.spec.TlsMasterSecretParameterSpec.<init>:(Ljavax/crypto/SecretKey;II[B[BLjava/lang/String;II)V
            astore 10 /* spec */
        start local 10 // sun.security.internal.spec.TlsMasterSecretParameterSpec spec
        53: .line 1339
      StackMap locals: sun.security.internal.spec.TlsMasterSecretParameterSpec
      StackMap stack:
            aload 3 /* masterAlg */
            invokestatic sun.security.ssl.JsseJce.getKeyGenerator:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            astore 11 /* kg */
        start local 11 // javax.crypto.KeyGenerator kg
        54: .line 1340
            aload 11 /* kg */
            aload 10 /* spec */
            invokevirtual javax.crypto.KeyGenerator.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
        55: .line 1341
            aload 11 /* kg */
            invokevirtual javax.crypto.KeyGenerator.generateKey:()Ljavax/crypto/SecretKey;
        56: areturn
        end local 11 // javax.crypto.KeyGenerator kg
        57: .line 1343
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 11 /* iae */
        start local 11 // java.security.GeneralSecurityException iae
        58: .line 1348
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 61
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 61
        59: .line 1349
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "RSA master secret generation error:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        60: .line 1350
            aload 11 /* iae */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.security.GeneralSecurityException.printStackTrace:(Ljava/io/PrintStream;)V
        61: .line 1352
      StackMap locals: java.security.GeneralSecurityException
      StackMap stack:
            new java.security.ProviderException
            dup
            aload 11 /* iae */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 11 // java.security.GeneralSecurityException iae
        end local 10 // sun.security.internal.spec.TlsMasterSecretParameterSpec spec
        end local 9 // int prfBlockSize
        end local 8 // int prfHashLength
        end local 7 // java.lang.String prfHashAlg
        end local 6 // byte minorVersion
        end local 5 // byte majorVersion
        end local 4 // sun.security.ssl.CipherSuite$PRF prf
        end local 3 // java.lang.String masterAlg
        end local 2 // sun.security.ssl.ProtocolVersion requestedVersion
        end local 1 // javax.crypto.SecretKey preMasterSecret
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   62     0              this  Lsun/security/ssl/Handshaker;
            0   62     1   preMasterSecret  Ljavax/crypto/SecretKey;
            0   62     2  requestedVersion  Lsun/security/ssl/ProtocolVersion;
            2    5     3              dump  Lsun/security/util/HexDumpEncoder;
           12   14     3         masterAlg  Ljava/lang/String;
           17   19     3         masterAlg  Ljava/lang/String;
           21   23     3         masterAlg  Ljava/lang/String;
           24   62     3         masterAlg  Ljava/lang/String;
           13   14     4               prf  Lsun/security/ssl/CipherSuite$PRF;
           18   19     4               prf  Lsun/security/ssl/CipherSuite$PRF;
           22   23     4               prf  Lsun/security/ssl/CipherSuite$PRF;
           25   62     4               prf  Lsun/security/ssl/CipherSuite$PRF;
            6   62     5      majorVersion  B
            7   62     6      minorVersion  B
           26   62     7        prfHashAlg  Ljava/lang/String;
           27   62     8     prfHashLength  I
           28   62     9      prfBlockSize  I
           46   47    10              spec  Lsun/security/internal/spec/TlsMasterSecretParameterSpec;
           53   62    10              spec  Lsun/security/internal/spec/TlsMasterSecretParameterSpec;
           31   46    11       sessionHash  [B
           39   40    12                de  Ljava/security/DigestException;
           54   57    11                kg  Ljavax/crypto/KeyGenerator;
           58   62    11               iae  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
          35    37      38  Class java.security.DigestException
          53    56      57  Class java.security.InvalidAlgorithmParameterException
          53    56      57  Class java.security.NoSuchAlgorithmException
    MethodParameters:
                  Name  Flags
      preMasterSecret   
      requestedVersion  

  void calculateConnectionKeys(javax.crypto.SecretKey);
    descriptor: (Ljavax/crypto/SecretKey;)V
    flags: (0x0000) 
    Code:
      stack=15, locals=17, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // javax.crypto.SecretKey masterKey
         0: .line 1376
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.macAlg:Lsun/security/ssl/CipherSuite$MacAlg;
            getfield sun.security.ssl.CipherSuite$MacAlg.size:I
            istore 2 /* hashSize */
        start local 2 // int hashSize
         1: .line 1377
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.exportable:Z
            istore 3 /* is_exportable */
        start local 3 // boolean is_exportable
         2: .line 1378
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
            astore 4 /* cipher */
        start local 4 // sun.security.ssl.CipherSuite$BulkCipher cipher
         3: .line 1379
            iload 3 /* is_exportable */
            ifeq 4
            aload 4 /* cipher */
            getfield sun.security.ssl.CipherSuite$BulkCipher.expandedKeySize:I
            goto 5
      StackMap locals: int int sun.security.ssl.CipherSuite$BulkCipher
      StackMap stack:
         4: iconst_0
      StackMap locals:
      StackMap stack: int
         5: istore 5 /* expandedKeySize */
        start local 5 // int expandedKeySize
         6: .line 1385
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.major:B
            istore 8 /* majorVersion */
        start local 8 // byte majorVersion
         7: .line 1386
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.minor:B
            istore 9 /* minorVersion */
        start local 9 // byte minorVersion
         8: .line 1387
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.isDTLSProtocol:()Z
            ifeq 20
         9: .line 1389
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.DTLS10:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmpne 15
        10: .line 1390
            getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.major:B
            istore 8 /* majorVersion */
        11: .line 1391
            getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.minor:B
            istore 9 /* minorVersion */
        12: .line 1393
            ldc "SunTlsKeyMaterial"
            astore 6 /* keyMaterialAlg */
        start local 6 // java.lang.String keyMaterialAlg
        13: .line 1394
            getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
            astore 7 /* prf */
        start local 7 // sun.security.ssl.CipherSuite$PRF prf
        14: .line 1395
            goto 26
        end local 7 // sun.security.ssl.CipherSuite$PRF prf
        end local 6 // java.lang.String keyMaterialAlg
        15: .line 1396
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int top top int int
      StackMap stack:
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.major:B
            istore 8 /* majorVersion */
        16: .line 1397
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.minor:B
            istore 9 /* minorVersion */
        17: .line 1399
            ldc "SunTls12KeyMaterial"
            astore 6 /* keyMaterialAlg */
        start local 6 // java.lang.String keyMaterialAlg
        18: .line 1400
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
            astore 7 /* prf */
        start local 7 // sun.security.ssl.CipherSuite$PRF prf
        19: .line 1402
            goto 26
        end local 7 // sun.security.ssl.CipherSuite$PRF prf
        end local 6 // java.lang.String keyMaterialAlg
        20: .line 1403
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
            getfield sun.security.ssl.ProtocolVersion.v:I
            if_icmplt 24
        21: .line 1404
            ldc "SunTls12KeyMaterial"
            astore 6 /* keyMaterialAlg */
        start local 6 // java.lang.String keyMaterialAlg
        22: .line 1405
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
            getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
            astore 7 /* prf */
        start local 7 // sun.security.ssl.CipherSuite$PRF prf
        23: .line 1406
            goto 26
        end local 7 // sun.security.ssl.CipherSuite$PRF prf
        end local 6 // java.lang.String keyMaterialAlg
        24: .line 1407
      StackMap locals:
      StackMap stack:
            ldc "SunTlsKeyMaterial"
            astore 6 /* keyMaterialAlg */
        start local 6 // java.lang.String keyMaterialAlg
        25: .line 1408
            getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
            astore 7 /* prf */
        start local 7 // sun.security.ssl.CipherSuite$PRF prf
        26: .line 1412
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int
      StackMap stack:
            aload 7 /* prf */
            invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashAlg:()Ljava/lang/String;
            astore 10 /* prfHashAlg */
        start local 10 // java.lang.String prfHashAlg
        27: .line 1413
            aload 7 /* prf */
            invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashLength:()I
            istore 11 /* prfHashLength */
        start local 11 // int prfHashLength
        28: .line 1414
            aload 7 /* prf */
            invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFBlockSize:()I
            istore 12 /* prfBlockSize */
        start local 12 // int prfBlockSize
        29: .line 1420
            aload 4 /* cipher */
            getfield sun.security.ssl.CipherSuite$BulkCipher.ivSize:I
            istore 13 /* ivSize */
        start local 13 // int ivSize
        30: .line 1421
            aload 4 /* cipher */
            getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
            getstatic sun.security.ssl.CipherSuite$CipherType.AEAD_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
            if_acmpne 33
        31: .line 1422
            aload 4 /* cipher */
            getfield sun.security.ssl.CipherSuite$BulkCipher.fixedIvSize:I
            istore 13 /* ivSize */
        32: .line 1423
            goto 36
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int int
      StackMap stack:
        33: aload 4 /* cipher */
            getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
            getstatic sun.security.ssl.CipherSuite$CipherType.BLOCK_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
            if_acmpne 36
        34: .line 1424
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS11PlusSpec:()Z
            ifeq 36
        35: .line 1425
            iconst_0
            istore 13 /* ivSize */
        36: .line 1428
      StackMap locals:
      StackMap stack:
            new sun.security.internal.spec.TlsKeyMaterialParameterSpec
            dup
        37: .line 1429
            aload 1 /* masterKey */
            iload 8 /* majorVersion */
            sipush 255
            iand
            iload 9 /* minorVersion */
            sipush 255
            iand
        38: .line 1430
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clnt_random:Lsun/security/ssl/RandomCookie;
            getfield sun.security.ssl.RandomCookie.random_bytes:[B
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svr_random:Lsun/security/ssl/RandomCookie;
            getfield sun.security.ssl.RandomCookie.random_bytes:[B
        39: .line 1431
            aload 4 /* cipher */
            getfield sun.security.ssl.CipherSuite$BulkCipher.algorithm:Ljava/lang/String;
            aload 4 /* cipher */
            getfield sun.security.ssl.CipherSuite$BulkCipher.keySize:I
            iload 5 /* expandedKeySize */
        40: .line 1432
            iload 13 /* ivSize */
            iload 2 /* hashSize */
        41: .line 1433
            aload 10 /* prfHashAlg */
            iload 11 /* prfHashLength */
            iload 12 /* prfBlockSize */
        42: .line 1428
            invokespecial sun.security.internal.spec.TlsKeyMaterialParameterSpec.<init>:(Ljavax/crypto/SecretKey;II[B[BLjava/lang/String;IIIILjava/lang/String;II)V
            astore 14 /* spec */
        start local 14 // sun.security.internal.spec.TlsKeyMaterialParameterSpec spec
        43: .line 1436
            aload 6 /* keyMaterialAlg */
            invokestatic sun.security.ssl.JsseJce.getKeyGenerator:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            astore 15 /* kg */
        start local 15 // javax.crypto.KeyGenerator kg
        44: .line 1437
            aload 15 /* kg */
            aload 14 /* spec */
            invokevirtual javax.crypto.KeyGenerator.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
        45: .line 1438
            aload 15 /* kg */
            invokevirtual javax.crypto.KeyGenerator.generateKey:()Ljavax/crypto/SecretKey;
            checkcast sun.security.internal.spec.TlsKeyMaterialSpec
            astore 16 /* keySpec */
        start local 16 // sun.security.internal.spec.TlsKeyMaterialSpec keySpec
        46: .line 1441
            aload 0 /* this */
            aload 16 /* keySpec */
            invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getClientCipherKey:()Ljavax/crypto/SecretKey;
            putfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
        47: .line 1442
            aload 0 /* this */
            aload 16 /* keySpec */
            invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getServerCipherKey:()Ljavax/crypto/SecretKey;
            putfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
        48: .line 1445
            aload 0 /* this */
            aload 16 /* keySpec */
            invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getClientIv:()Ljavax/crypto/spec/IvParameterSpec;
            putfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
        49: .line 1446
            aload 0 /* this */
            aload 16 /* keySpec */
            invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getServerIv:()Ljavax/crypto/spec/IvParameterSpec;
            putfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
        50: .line 1449
            aload 0 /* this */
            aload 16 /* keySpec */
            invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getClientMacKey:()Ljavax/crypto/SecretKey;
            putfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
        51: .line 1450
            aload 0 /* this */
            aload 16 /* keySpec */
            invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getServerMacKey:()Ljavax/crypto/SecretKey;
            putfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
        end local 16 // sun.security.internal.spec.TlsKeyMaterialSpec keySpec
        end local 15 // javax.crypto.KeyGenerator kg
        52: .line 1451
            goto 55
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int int sun.security.internal.spec.TlsKeyMaterialParameterSpec
      StackMap stack: java.security.GeneralSecurityException
        53: astore 15 /* e */
        start local 15 // java.security.GeneralSecurityException e
        54: .line 1452
            new java.security.ProviderException
            dup
            aload 15 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 15 // java.security.GeneralSecurityException e
        55: .line 1458
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
            ifnull 96
            ldc "keygen"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 96
        56: .line 1459
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            dup
            astore 15
            monitorenter
        57: .line 1460
            new sun.security.util.HexDumpEncoder
            dup
            invokespecial sun.security.util.HexDumpEncoder.<init>:()V
            astore 16 /* dump */
        start local 16 // sun.security.util.HexDumpEncoder dump
        58: .line 1462
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "CONNECTION KEYGEN:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        59: .line 1465
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Client Nonce:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        60: .line 1466
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clnt_random:Lsun/security/ssl/RandomCookie;
            getfield sun.security.ssl.RandomCookie.random_bytes:[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        61: .line 1467
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Server Nonce:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        62: .line 1468
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svr_random:Lsun/security/ssl/RandomCookie;
            getfield sun.security.ssl.RandomCookie.random_bytes:[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        63: .line 1469
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Master Secret:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        64: .line 1470
            aload 16 /* dump */
            aload 1 /* masterKey */
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        65: .line 1473
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
            ifnull 71
        66: .line 1474
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Client MAC write Secret:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        67: .line 1475
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        68: .line 1476
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Server MAC write Secret:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        69: .line 1477
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        70: .line 1478
            goto 72
        71: .line 1479
      StackMap locals: java.io.PrintStream sun.security.util.HexDumpEncoder
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "... no MAC keys used for this cipher"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        72: .line 1482
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
            ifnull 78
        73: .line 1483
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Client write key:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        74: .line 1484
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        75: .line 1485
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Server write key:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        76: .line 1486
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        77: .line 1487
            goto 79
        78: .line 1488
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "... no encryption keys used"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        79: .line 1491
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
            ifnull 85
        80: .line 1492
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Client write IV:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        81: .line 1493
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
            invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        82: .line 1494
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Server write IV:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        83: .line 1495
            aload 16 /* dump */
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
            invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
            invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
        84: .line 1496
            goto 91
        85: .line 1497
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS11PlusSpec:()Z
            ifeq 90
        86: .line 1498
            getstatic java.lang.System.out:Ljava/io/PrintStream;
        87: .line 1499
            ldc "... no IV derived for this protocol"
        88: .line 1498
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        89: .line 1500
            goto 91
        90: .line 1501
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "... no IV used for this cipher"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        91: .line 1504
      StackMap locals:
      StackMap stack:
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.io.PrintStream.flush:()V
        end local 16 // sun.security.util.HexDumpEncoder dump
        92: .line 1459
            aload 15
            monitorexit
        93: goto 96
      StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int int sun.security.internal.spec.TlsKeyMaterialParameterSpec java.io.PrintStream
      StackMap stack: java.lang.Throwable
        94: aload 15
            monitorexit
        95: athrow
        96: .line 1507
      StackMap locals:
      StackMap stack:
            return
        end local 14 // sun.security.internal.spec.TlsKeyMaterialParameterSpec spec
        end local 13 // int ivSize
        end local 12 // int prfBlockSize
        end local 11 // int prfHashLength
        end local 10 // java.lang.String prfHashAlg
        end local 9 // byte minorVersion
        end local 8 // byte majorVersion
        end local 7 // sun.security.ssl.CipherSuite$PRF prf
        end local 6 // java.lang.String keyMaterialAlg
        end local 5 // int expandedKeySize
        end local 4 // sun.security.ssl.CipherSuite$BulkCipher cipher
        end local 3 // boolean is_exportable
        end local 2 // int hashSize
        end local 1 // javax.crypto.SecretKey masterKey
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   97     0             this  Lsun/security/ssl/Handshaker;
            0   97     1        masterKey  Ljavax/crypto/SecretKey;
            1   97     2         hashSize  I
            2   97     3    is_exportable  Z
            3   97     4           cipher  Lsun/security/ssl/CipherSuite$BulkCipher;
            6   97     5  expandedKeySize  I
           13   15     6   keyMaterialAlg  Ljava/lang/String;
           18   20     6   keyMaterialAlg  Ljava/lang/String;
           22   24     6   keyMaterialAlg  Ljava/lang/String;
           25   97     6   keyMaterialAlg  Ljava/lang/String;
           14   15     7              prf  Lsun/security/ssl/CipherSuite$PRF;
           19   20     7              prf  Lsun/security/ssl/CipherSuite$PRF;
           23   24     7              prf  Lsun/security/ssl/CipherSuite$PRF;
           26   97     7              prf  Lsun/security/ssl/CipherSuite$PRF;
            7   97     8     majorVersion  B
            8   97     9     minorVersion  B
           27   97    10       prfHashAlg  Ljava/lang/String;
           28   97    11    prfHashLength  I
           29   97    12     prfBlockSize  I
           30   97    13           ivSize  I
           43   97    14             spec  Lsun/security/internal/spec/TlsKeyMaterialParameterSpec;
           44   52    15               kg  Ljavax/crypto/KeyGenerator;
           46   52    16          keySpec  Lsun/security/internal/spec/TlsKeyMaterialSpec;
           54   55    15                e  Ljava/security/GeneralSecurityException;
           58   92    16             dump  Lsun/security/util/HexDumpEncoder;
      Exception table:
        from    to  target  type
          43    52      53  Class java.security.GeneralSecurityException
          57    93      94  any
          94    95      94  any
    MethodParameters:
           Name  Flags
      masterKey  

  private static void printHex(sun.security.util.HexDumpEncoder, byte[]);
    descriptor: (Lsun/security/util/HexDumpEncoder;[B)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.util.HexDumpEncoder dump
        start local 1 // byte[] bytes
         0: .line 1510
            aload 1 /* bytes */
            ifnonnull 3
         1: .line 1511
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "(key bytes not available)"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 1512
            goto 6
         3: .line 1514
      StackMap locals:
      StackMap stack:
            aload 0 /* dump */
            aload 1 /* bytes */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual sun.security.util.HexDumpEncoder.encodeBuffer:([BLjava/io/OutputStream;)V
         4: .line 1515
            goto 6
      StackMap locals:
      StackMap stack: java.io.IOException
         5: pop
         6: .line 1519
      StackMap locals:
      StackMap stack:
            return
        end local 1 // byte[] bytes
        end local 0 // sun.security.util.HexDumpEncoder dump
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   dump  Lsun/security/util/HexDumpEncoder;
            0    7     1  bytes  [B
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.IOException
    MethodParameters:
       Name  Flags
      dump   
      bytes  

  private <T> void delegateTask(java.security.PrivilegedExceptionAction<T>);
    descriptor: (Ljava/security/PrivilegedExceptionAction;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // sun.security.ssl.Handshaker this
        start local 1 // java.security.PrivilegedExceptionAction pea
         0: .line 1553
            aload 0 /* this */
            new sun.security.ssl.Handshaker$DelegatedTask
            dup
            aload 0 /* this */
            aload 1 /* pea */
            invokespecial sun.security.ssl.Handshaker$DelegatedTask.<init>:(Lsun/security/ssl/Handshaker;Ljava/security/PrivilegedExceptionAction;)V
            putfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
         1: .line 1554
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.Handshaker.taskDelegated:Z
         2: .line 1555
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
         3: .line 1556
            return
        end local 1 // java.security.PrivilegedExceptionAction pea
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/ssl/Handshaker;
            0    4     1   pea  Ljava/security/PrivilegedExceptionAction<TT;>;
    Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;)V
    MethodParameters:
      Name  Flags
      pea   

  sun.security.ssl.Handshaker$DelegatedTask<?> getTask();
    descriptor: ()Lsun/security/ssl/Handshaker$DelegatedTask;
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1559
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.taskDelegated:Z
            ifne 3
         1: .line 1560
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.Handshaker.taskDelegated:Z
         2: .line 1561
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
            areturn
         3: .line 1563
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/ssl/Handshaker;
    Signature: ()Lsun/security/ssl/Handshaker$DelegatedTask<*>;

  boolean taskOutstanding();
    descriptor: ()Z
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1573
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
            ifnull 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/Handshaker;

  void checkThrown();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=4, args_size=1
        start local 0 // sun.security.ssl.Handshaker this
         0: .line 1583
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.thrownLock:Ljava/lang/Object;
            dup
            astore 1
            monitorenter
         1: .line 1584
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
            ifnull 22
         2: .line 1586
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            astore 2 /* msg */
        start local 2 // java.lang.String msg
         3: .line 1588
            aload 2 /* msg */
            ifnonnull 5
         4: .line 1589
            ldc "Delegated task threw Exception/Error"
            astore 2 /* msg */
         5: .line 1596
      StackMap locals: java.lang.Object java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
            astore 3 /* e */
        start local 3 // java.lang.Exception e
         6: .line 1597
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
         7: .line 1599
            aload 3 /* e */
            instanceof java.lang.RuntimeException
            ifeq 9
         8: .line 1600
            new java.lang.RuntimeException
            dup
            aload 2 /* msg */
            aload 3 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
         9: .line 1601
      StackMap locals: java.lang.Exception
      StackMap stack:
            aload 3 /* e */
            instanceof javax.net.ssl.SSLHandshakeException
            ifeq 12
        10: .line 1603
            new javax.net.ssl.SSLHandshakeException
            dup
            aload 2 /* msg */
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            aload 3 /* e */
            invokevirtual javax.net.ssl.SSLHandshakeException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
        11: .line 1602
            checkcast javax.net.ssl.SSLHandshakeException
            athrow
        12: .line 1604
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            instanceof javax.net.ssl.SSLKeyException
            ifeq 15
        13: .line 1606
            new javax.net.ssl.SSLKeyException
            dup
            aload 2 /* msg */
            invokespecial javax.net.ssl.SSLKeyException.<init>:(Ljava/lang/String;)V
            aload 3 /* e */
            invokevirtual javax.net.ssl.SSLKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
        14: .line 1605
            checkcast javax.net.ssl.SSLKeyException
            athrow
        15: .line 1607
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            instanceof javax.net.ssl.SSLPeerUnverifiedException
            ifeq 18
        16: .line 1609
            new javax.net.ssl.SSLPeerUnverifiedException
            dup
            aload 2 /* msg */
            invokespecial javax.net.ssl.SSLPeerUnverifiedException.<init>:(Ljava/lang/String;)V
            aload 3 /* e */
            invokevirtual javax.net.ssl.SSLPeerUnverifiedException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
        17: .line 1608
            checkcast javax.net.ssl.SSLPeerUnverifiedException
            athrow
        18: .line 1610
      StackMap locals:
      StackMap stack:
            aload 3 /* e */
            instanceof javax.net.ssl.SSLProtocolException
            ifeq 21
        19: .line 1612
            new javax.net.ssl.SSLProtocolException
            dup
            aload 2 /* msg */
            invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
            aload 3 /* e */
            invokevirtual javax.net.ssl.SSLProtocolException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
        20: .line 1611
            checkcast javax.net.ssl.SSLProtocolException
            athrow
        21: .line 1618
      StackMap locals:
      StackMap stack:
            new javax.net.ssl.SSLException
            dup
            aload 2 /* msg */
            aload 3 /* e */
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        end local 2 // java.lang.String msg
        22: .line 1583
      StackMap locals:
      StackMap stack:
            aload 1
            monitorexit
        23: goto 26
      StackMap locals:
      StackMap stack: java.lang.Throwable
        24: aload 1
            monitorexit
        25: athrow
        26: .line 1622
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.ssl.Handshaker this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   27     0  this  Lsun/security/ssl/Handshaker;
            3   22     2   msg  Ljava/lang/String;
            6   22     3     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    23      24  any
          24    25      24  any
    Exceptions:
      throws javax.net.ssl.SSLException
}
SourceFile: "Handshaker.java"
NestMembers:
  sun.security.ssl.Handshaker$1  sun.security.ssl.Handshaker$DelegatedTask
InnerClasses:
  final BulkCipher = sun.security.ssl.CipherSuite$BulkCipher of sun.security.ssl.CipherSuite
  final CipherType = sun.security.ssl.CipherSuite$CipherType of sun.security.ssl.CipherSuite
  final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
  final MacAlg = sun.security.ssl.CipherSuite$MacAlg of sun.security.ssl.CipherSuite
  final PRF = sun.security.ssl.CipherSuite$PRF of sun.security.ssl.CipherSuite
  final Finished = sun.security.ssl.HandshakeMessage$Finished of sun.security.ssl.HandshakeMessage
  sun.security.ssl.Handshaker$1
  DelegatedTask = sun.security.ssl.Handshaker$DelegatedTask of sun.security.ssl.Handshaker