public abstract class sun.security.ssl.SSLContextImpl extends javax.net.ssl.SSLContextSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: sun.security.ssl.SSLContextImpl
  super_class: javax.net.ssl.SSLContextSpi
{
  private final sun.security.ssl.EphemeralKeyManager ephemeralKeyManager;
    descriptor: Lsun/security/ssl/EphemeralKeyManager;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final sun.security.ssl.SSLSessionContextImpl clientCache;
    descriptor: Lsun/security/ssl/SSLSessionContextImpl;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final sun.security.ssl.SSLSessionContextImpl serverCache;
    descriptor: Lsun/security/ssl/SSLSessionContextImpl;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  private javax.net.ssl.X509ExtendedKeyManager keyManager;
    descriptor: Ljavax/net/ssl/X509ExtendedKeyManager;
    flags: (0x0002) ACC_PRIVATE

  private javax.net.ssl.X509TrustManager trustManager;
    descriptor: Ljavax/net/ssl/X509TrustManager;
    flags: (0x0002) ACC_PRIVATE

  private java.security.SecureRandom secureRandom;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0002) ACC_PRIVATE

  private volatile sun.security.ssl.HelloCookieManager$Builder helloCookieManagerBuilder;
    descriptor: Lsun/security/ssl/HelloCookieManager$Builder;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private final boolean clientEnableStapling;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean serverEnableStapling;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private static final java.util.Collection<sun.security.ssl.CipherSuite> clientCustomizedCipherSuites;
    descriptor: Ljava/util/Collection;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;

  private static final java.util.Collection<sun.security.ssl.CipherSuite> serverCustomizedCipherSuites;
    descriptor: Ljava/util/Collection;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;

  private volatile sun.security.ssl.StatusResponseManager statusResponseManager;
    descriptor: Lsun/security/ssl/StatusResponseManager;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private final java.util.concurrent.locks.ReentrantLock contextLock;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  final java.util.HashMap<java.lang.Integer, sun.security.ssl.SessionTicketExtension$StatelessKey> keyHashMap;
    descriptor: Ljava/util/HashMap;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/HashMap<Ljava/lang/Integer;Lsun/security/ssl/SessionTicketExtension$StatelessKey;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 67
            ldc "jdk.tls.client.cipherSuites"
            invokestatic sun.security.ssl.SSLContextImpl.getCustomizedCipherSuites:(Ljava/lang/String;)Ljava/util/Collection;
         1: .line 66
            putstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
         2: .line 69
            ldc "jdk.tls.server.cipherSuites"
            invokestatic sun.security.ssl.SSLContextImpl.getCustomizedCipherSuites:(Ljava/lang/String;)Ljava/util/Collection;
         3: .line 68
            putstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
         4: .line 69
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 78
            aload 0 /* this */
            invokespecial javax.net.ssl.SSLContextSpi.<init>:()V
         1: .line 62
            aload 0 /* this */
         2: .line 63
            ldc "jdk.tls.client.enableStatusRequestExtension"
            iconst_1
         3: .line 62
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            putfield sun.security.ssl.SSLContextImpl.clientEnableStapling:Z
         4: .line 64
            aload 0 /* this */
         5: .line 65
            ldc "jdk.tls.server.enableStatusRequestExtension"
            iconst_0
         6: .line 64
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            putfield sun.security.ssl.SSLContextImpl.serverEnableStapling:Z
         7: .line 73
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield sun.security.ssl.SSLContextImpl.contextLock:Ljava/util/concurrent/locks/ReentrantLock;
         8: .line 75
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield sun.security.ssl.SSLContextImpl.keyHashMap:Ljava/util/HashMap;
         9: .line 79
            aload 0 /* this */
            new sun.security.ssl.EphemeralKeyManager
            dup
            invokespecial sun.security.ssl.EphemeralKeyManager.<init>:()V
            putfield sun.security.ssl.SSLContextImpl.ephemeralKeyManager:Lsun/security/ssl/EphemeralKeyManager;
        10: .line 80
            aload 0 /* this */
            new sun.security.ssl.SSLSessionContextImpl
            dup
            iconst_0
            invokespecial sun.security.ssl.SSLSessionContextImpl.<init>:(Z)V
            putfield sun.security.ssl.SSLContextImpl.clientCache:Lsun/security/ssl/SSLSessionContextImpl;
        11: .line 81
            aload 0 /* this */
            new sun.security.ssl.SSLSessionContextImpl
            dup
            iconst_1
            invokespecial sun.security.ssl.SSLSessionContextImpl.<init>:(Z)V
            putfield sun.security.ssl.SSLContextImpl.serverCache:Lsun/security/ssl/SSLSessionContextImpl;
        12: .line 82
            return
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lsun/security/ssl/SSLContextImpl;

  protected void engineInit(javax.net.ssl.KeyManager[], javax.net.ssl.TrustManager[], java.security.SecureRandom);
    descriptor: ([Ljavax/net/ssl/KeyManager;[Ljavax/net/ssl/TrustManager;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=5, args_size=4
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // javax.net.ssl.KeyManager[] km
        start local 2 // javax.net.ssl.TrustManager[] tm
        start local 3 // java.security.SecureRandom sr
         0: .line 87
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLContextImpl.isInitialized:Z
         1: .line 88
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* km */
            invokevirtual sun.security.ssl.SSLContextImpl.chooseKeyManager:([Ljavax/net/ssl/KeyManager;)Ljavax/net/ssl/X509ExtendedKeyManager;
            putfield sun.security.ssl.SSLContextImpl.keyManager:Ljavax/net/ssl/X509ExtendedKeyManager;
         2: .line 90
            aload 2 /* tm */
            ifnonnull 9
         3: .line 93
            invokestatic javax.net.ssl.TrustManagerFactory.getDefaultAlgorithm:()Ljava/lang/String;
         4: .line 92
            invokestatic javax.net.ssl.TrustManagerFactory.getInstance:(Ljava/lang/String;)Ljavax/net/ssl/TrustManagerFactory;
            astore 4 /* tmf */
        start local 4 // javax.net.ssl.TrustManagerFactory tmf
         5: .line 94
            aload 4 /* tmf */
            aconst_null
            invokevirtual javax.net.ssl.TrustManagerFactory.init:(Ljava/security/KeyStore;)V
         6: .line 95
            aload 4 /* tmf */
            invokevirtual javax.net.ssl.TrustManagerFactory.getTrustManagers:()[Ljavax/net/ssl/TrustManager;
            astore 2 /* tm */
        end local 4 // javax.net.ssl.TrustManagerFactory tmf
         7: .line 96
            goto 9
      StackMap locals:
      StackMap stack: java.lang.Exception
         8: pop
         9: .line 100
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 2 /* tm */
            invokevirtual sun.security.ssl.SSLContextImpl.chooseTrustManager:([Ljavax/net/ssl/TrustManager;)Ljavax/net/ssl/X509TrustManager;
            putfield sun.security.ssl.SSLContextImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
        10: .line 102
            aload 3 /* sr */
            ifnonnull 13
        11: .line 103
            aload 0 /* this */
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            putfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
        12: .line 104
            goto 14
        13: .line 105
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* sr */
            putfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
        14: .line 114
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 16
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 16
        15: .line 115
            ldc "trigger seeding of SecureRandom"
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        16: .line 117
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
            invokevirtual java.security.SecureRandom.nextInt:()I
            pop
        17: .line 118
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 19
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 19
        18: .line 119
            ldc "done seeding of SecureRandom"
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        19: .line 122
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.SSLContextImpl.isInitialized:Z
        20: .line 123
            return
        end local 3 // java.security.SecureRandom sr
        end local 2 // javax.net.ssl.TrustManager[] tm
        end local 1 // javax.net.ssl.KeyManager[] km
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   21     0  this  Lsun/security/ssl/SSLContextImpl;
            0   21     1    km  [Ljavax/net/ssl/KeyManager;
            0   21     2    tm  [Ljavax/net/ssl/TrustManager;
            0   21     3    sr  Ljava/security/SecureRandom;
            5    7     4   tmf  Ljavax/net/ssl/TrustManagerFactory;
      Exception table:
        from    to  target  type
           3     7       8  Class java.lang.Exception
    Exceptions:
      throws java.security.KeyManagementException
    MethodParameters:
      Name  Flags
      km    
      tm    
      sr    

  private javax.net.ssl.X509TrustManager chooseTrustManager(javax.net.ssl.TrustManager[]);
    descriptor: ([Ljavax/net/ssl/TrustManager;)Ljavax/net/ssl/X509TrustManager;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // javax.net.ssl.TrustManager[] tm
         0: .line 128
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 9
         2: .line 129
      StackMap locals: int
      StackMap stack:
            aload 1 /* tm */
            iload 2 /* i */
            aaload
            instanceof javax.net.ssl.X509TrustManager
            ifeq 8
         3: .line 130
            aload 1 /* tm */
            iload 2 /* i */
            aaload
            instanceof javax.net.ssl.X509ExtendedTrustManager
            ifeq 5
         4: .line 131
            aload 1 /* tm */
            iload 2 /* i */
            aaload
            checkcast javax.net.ssl.X509TrustManager
            areturn
         5: .line 133
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.AbstractTrustManagerWrapper
            dup
         6: .line 134
            aload 1 /* tm */
            iload 2 /* i */
            aaload
            checkcast javax.net.ssl.X509TrustManager
         7: .line 133
            invokespecial sun.security.ssl.AbstractTrustManagerWrapper.<init>:(Ljavax/net/ssl/X509TrustManager;)V
            areturn
         8: .line 128
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: aload 1 /* tm */
            ifnull 10
            iload 2 /* i */
            aload 1 /* tm */
            arraylength
            if_icmplt 2
        end local 2 // int i
        10: .line 140
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.DummyX509TrustManager.INSTANCE:Ljavax/net/ssl/X509TrustManager;
            areturn
        end local 1 // javax.net.ssl.TrustManager[] tm
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lsun/security/ssl/SSLContextImpl;
            0   11     1    tm  [Ljavax/net/ssl/TrustManager;
            1   10     2     i  I
    Exceptions:
      throws java.security.KeyManagementException
    MethodParameters:
      Name  Flags
      tm    

  private javax.net.ssl.X509ExtendedKeyManager chooseKeyManager(javax.net.ssl.KeyManager[]);
    descriptor: ([Ljavax/net/ssl/KeyManager;)Ljavax/net/ssl/X509ExtendedKeyManager;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // javax.net.ssl.KeyManager[] kms
         0: .line 145
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         1: goto 12
         2: .line 146
      StackMap locals: int
      StackMap stack:
            aload 1 /* kms */
            iload 2 /* i */
            aaload
            astore 3 /* km */
        start local 3 // javax.net.ssl.KeyManager km
         3: .line 147
            aload 3 /* km */
            instanceof javax.net.ssl.X509KeyManager
            ifne 5
         4: .line 148
            goto 11
         5: .line 151
      StackMap locals: javax.net.ssl.KeyManager
      StackMap stack:
            aload 3 /* km */
            instanceof javax.net.ssl.X509ExtendedKeyManager
            ifeq 7
         6: .line 152
            aload 3 /* km */
            checkcast javax.net.ssl.X509ExtendedKeyManager
            areturn
         7: .line 155
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 10
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 10
         8: .line 157
            ldc "X509KeyManager passed to SSLContext.init():  need an X509ExtendedKeyManager for SSLEngine use"
            iconst_0
            anewarray java.lang.Object
         9: .line 156
            invokestatic sun.security.ssl.SSLLogger.warning:(Ljava/lang/String;[Ljava/lang/Object;)V
        10: .line 160
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.AbstractKeyManagerWrapper
            dup
            aload 3 /* km */
            checkcast javax.net.ssl.X509KeyManager
            invokespecial sun.security.ssl.AbstractKeyManagerWrapper.<init>:(Ljavax/net/ssl/X509KeyManager;)V
            areturn
        end local 3 // javax.net.ssl.KeyManager km
        11: .line 145
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
        12: aload 1 /* kms */
            ifnull 13
            iload 2 /* i */
            aload 1 /* kms */
            arraylength
            if_icmplt 2
        end local 2 // int i
        13: .line 164
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.DummyX509KeyManager.INSTANCE:Ljavax/net/ssl/X509ExtendedKeyManager;
            areturn
        end local 1 // javax.net.ssl.KeyManager[] kms
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Lsun/security/ssl/SSLContextImpl;
            0   14     1   kms  [Ljavax/net/ssl/KeyManager;
            1   13     2     i  I
            3   11     3    km  Ljavax/net/ssl/KeyManager;
    Exceptions:
      throws java.security.KeyManagementException
    MethodParameters:
      Name  Flags
      kms   

  abstract javax.net.ssl.SSLEngine createSSLEngineImpl();
    descriptor: ()Ljavax/net/ssl/SSLEngine;
    flags: (0x0400) ACC_ABSTRACT

  abstract javax.net.ssl.SSLEngine createSSLEngineImpl(java.lang.String, int);
    descriptor: (Ljava/lang/String;I)Ljavax/net/ssl/SSLEngine;
    flags: (0x0400) ACC_ABSTRACT
    MethodParameters:
      Name  Flags
      host  
      port  

  protected javax.net.ssl.SSLEngine engineCreateSSLEngine();
    descriptor: ()Ljavax/net/ssl/SSLEngine;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 172
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
            ifne 2
         1: .line 173
            new java.lang.IllegalStateException
            dup
            ldc "SSLContext is not initialized"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 175
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.createSSLEngineImpl:()Ljavax/net/ssl/SSLEngine;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/SSLContextImpl;

  protected javax.net.ssl.SSLEngine engineCreateSSLEngine(java.lang.String, int);
    descriptor: (Ljava/lang/String;I)Ljavax/net/ssl/SSLEngine;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // java.lang.String host
        start local 2 // int port
         0: .line 180
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
            ifne 2
         1: .line 181
            new java.lang.IllegalStateException
            dup
            ldc "SSLContext is not initialized"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 183
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* host */
            iload 2 /* port */
            invokevirtual sun.security.ssl.SSLContextImpl.createSSLEngineImpl:(Ljava/lang/String;I)Ljavax/net/ssl/SSLEngine;
            areturn
        end local 2 // int port
        end local 1 // java.lang.String host
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/SSLContextImpl;
            0    3     1  host  Ljava/lang/String;
            0    3     2  port  I
    MethodParameters:
      Name  Flags
      host  
      port  

  protected javax.net.ssl.SSLSocketFactory engineGetSocketFactory();
    descriptor: ()Ljavax/net/ssl/SSLSocketFactory;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 188
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
            ifne 2
         1: .line 189
            new java.lang.IllegalStateException
            dup
            ldc "SSLContext is not initialized"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 191
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.isDTLS:()Z
            ifeq 6
         3: .line 192
            new java.lang.UnsupportedOperationException
            dup
         4: .line 193
            ldc "DTLS not supported with SSLSocket"
         5: .line 192
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 195
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLSocketFactoryImpl
            dup
            aload 0 /* this */
            invokespecial sun.security.ssl.SSLSocketFactoryImpl.<init>:(Lsun/security/ssl/SSLContextImpl;)V
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/ssl/SSLContextImpl;

  protected javax.net.ssl.SSLServerSocketFactory engineGetServerSocketFactory();
    descriptor: ()Ljavax/net/ssl/SSLServerSocketFactory;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 200
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
            ifne 2
         1: .line 201
            new java.lang.IllegalStateException
            dup
            ldc "SSLContext is not initialized"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 203
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.isDTLS:()Z
            ifeq 6
         3: .line 204
            new java.lang.UnsupportedOperationException
            dup
         4: .line 205
            ldc "DTLS not supported with SSLServerSocket"
         5: .line 204
            invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 207
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.SSLServerSocketFactoryImpl
            dup
            aload 0 /* this */
            invokespecial sun.security.ssl.SSLServerSocketFactoryImpl.<init>:(Lsun/security/ssl/SSLContextImpl;)V
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/ssl/SSLContextImpl;

  protected javax.net.ssl.SSLSessionContext engineGetClientSessionContext();
    descriptor: ()Ljavax/net/ssl/SSLSessionContext;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 212
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.clientCache:Lsun/security/ssl/SSLSessionContextImpl;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/SSLContextImpl;

  protected javax.net.ssl.SSLSessionContext engineGetServerSessionContext();
    descriptor: ()Ljavax/net/ssl/SSLSessionContext;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 217
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.serverCache:Lsun/security/ssl/SSLSessionContextImpl;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/SSLContextImpl;

  java.security.SecureRandom getSecureRandom();
    descriptor: ()Ljava/security/SecureRandom;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 221
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/SSLContextImpl;

  javax.net.ssl.X509ExtendedKeyManager getX509KeyManager();
    descriptor: ()Ljavax/net/ssl/X509ExtendedKeyManager;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 225
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.keyManager:Ljavax/net/ssl/X509ExtendedKeyManager;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/SSLContextImpl;

  javax.net.ssl.X509TrustManager getX509TrustManager();
    descriptor: ()Ljavax/net/ssl/X509TrustManager;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 229
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/SSLContextImpl;

  sun.security.ssl.EphemeralKeyManager getEphemeralKeyManager();
    descriptor: ()Lsun/security/ssl/EphemeralKeyManager;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 233
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.ephemeralKeyManager:Lsun/security/ssl/EphemeralKeyManager;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/SSLContextImpl;

  sun.security.ssl.HelloCookieManager getHelloCookieManager(sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/HelloCookieManager;
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 238
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
            ifnonnull 11
         1: .line 239
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.contextLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         2: .line 241
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
            ifnonnull 10
         3: .line 242
            aload 0 /* this */
         4: .line 243
            new sun.security.ssl.HelloCookieManager$Builder
            dup
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
            invokespecial sun.security.ssl.HelloCookieManager$Builder.<init>:(Ljava/security/SecureRandom;)V
         5: .line 242
            putfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
         6: .line 245
            goto 10
      StackMap locals:
      StackMap stack: java.lang.Throwable
         7: astore 2
         8: .line 246
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.contextLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
         9: .line 247
            aload 2
            athrow
        10: .line 246
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.contextLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        11: .line 250
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
            aload 1 /* protocolVersion */
            invokevirtual sun.security.ssl.HelloCookieManager$Builder.valueOf:(Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/HelloCookieManager;
            areturn
        end local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   12     0             this  Lsun/security/ssl/SSLContextImpl;
            0   12     1  protocolVersion  Lsun/security/ssl/ProtocolVersion;
      Exception table:
        from    to  target  type
           2     7       7  any
    MethodParameters:
                 Name  Flags
      protocolVersion  

  sun.security.ssl.StatusResponseManager getStatusResponseManager();
    descriptor: ()Lsun/security/ssl/StatusResponseManager;
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl this
         0: .line 254
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.serverEnableStapling:Z
            ifeq 12
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
            ifnonnull 12
         1: .line 255
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.contextLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         2: .line 257
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
            ifnonnull 11
         3: .line 258
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 6
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 6
         4: .line 260
            ldc "Initializing StatusResponseManager"
            iconst_0
            anewarray java.lang.Object
         5: .line 259
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
         6: .line 262
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new sun.security.ssl.StatusResponseManager
            dup
            invokespecial sun.security.ssl.StatusResponseManager.<init>:()V
            putfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
         7: .line 264
            goto 11
      StackMap locals:
      StackMap stack: java.lang.Throwable
         8: astore 1
         9: .line 265
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.contextLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        10: .line 266
            aload 1
            athrow
        11: .line 265
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.contextLock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        12: .line 269
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
            areturn
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lsun/security/ssl/SSLContextImpl;
      Exception table:
        from    to  target  type
           2     8       8  any

  abstract java.util.List<sun.security.ssl.ProtocolVersion> getSupportedProtocolVersions();
    descriptor: ()Ljava/util/List;
    flags: (0x0400) ACC_ABSTRACT
    Signature: ()Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;

  abstract java.util.List<sun.security.ssl.ProtocolVersion> getServerDefaultProtocolVersions();
    descriptor: ()Ljava/util/List;
    flags: (0x0400) ACC_ABSTRACT
    Signature: ()Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;

  abstract java.util.List<sun.security.ssl.ProtocolVersion> getClientDefaultProtocolVersions();
    descriptor: ()Ljava/util/List;
    flags: (0x0400) ACC_ABSTRACT
    Signature: ()Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;

  abstract java.util.List<sun.security.ssl.CipherSuite> getSupportedCipherSuites();
    descriptor: ()Ljava/util/List;
    flags: (0x0400) ACC_ABSTRACT
    Signature: ()Ljava/util/List<Lsun/security/ssl/CipherSuite;>;

  abstract java.util.List<sun.security.ssl.CipherSuite> getServerDefaultCipherSuites();
    descriptor: ()Ljava/util/List;
    flags: (0x0400) ACC_ABSTRACT
    Signature: ()Ljava/util/List<Lsun/security/ssl/CipherSuite;>;

  abstract java.util.List<sun.security.ssl.CipherSuite> getClientDefaultCipherSuites();
    descriptor: ()Ljava/util/List;
    flags: (0x0400) ACC_ABSTRACT
    Signature: ()Ljava/util/List<Lsun/security/ssl/CipherSuite;>;

  abstract boolean isDTLS();
    descriptor: ()Z
    flags: (0x0400) ACC_ABSTRACT

  java.util.List<sun.security.ssl.ProtocolVersion> getDefaultProtocolVersions(boolean);
    descriptor: (Z)Ljava/util/List;
    flags: (0x0000) 
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // boolean roleIsServer
         0: .line 295
            iload 1 /* roleIsServer */
            ifeq 1
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultProtocolVersions:()Ljava/util/List;
            goto 2
         1: .line 296
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultProtocolVersions:()Ljava/util/List;
         2: .line 295
      StackMap locals:
      StackMap stack: java.util.List
            areturn
        end local 1 // boolean roleIsServer
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    3     0          this  Lsun/security/ssl/SSLContextImpl;
            0    3     1  roleIsServer  Z
    Signature: (Z)Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
    MethodParameters:
              Name  Flags
      roleIsServer  

  java.util.List<sun.security.ssl.CipherSuite> getDefaultCipherSuites(boolean);
    descriptor: (Z)Ljava/util/List;
    flags: (0x0000) 
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // boolean roleIsServer
         0: .line 301
            iload 1 /* roleIsServer */
            ifeq 1
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultCipherSuites:()Ljava/util/List;
            goto 2
         1: .line 302
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultCipherSuites:()Ljava/util/List;
         2: .line 301
      StackMap locals:
      StackMap stack: java.util.List
            areturn
        end local 1 // boolean roleIsServer
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    3     0          this  Lsun/security/ssl/SSLContextImpl;
            0    3     1  roleIsServer  Z
    Signature: (Z)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
    MethodParameters:
              Name  Flags
      roleIsServer  

  boolean isDefaultProtocolVesions(java.util.List<sun.security.ssl.ProtocolVersion>);
    descriptor: (Ljava/util/List;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // java.util.List protocols
         0: .line 310
            aload 1 /* protocols */
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultProtocolVersions:()Ljava/util/List;
            if_acmpeq 3
         1: .line 311
            aload 1 /* protocols */
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultProtocolVersions:()Ljava/util/List;
            if_acmpeq 3
         2: .line 310
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         3: iconst_1
            ireturn
        end local 1 // java.util.List protocols
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lsun/security/ssl/SSLContextImpl;
            0    4     1  protocols  Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
    Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)Z
    MethodParameters:
           Name  Flags
      protocols  

  boolean isDefaultCipherSuiteList(java.util.List<sun.security.ssl.CipherSuite>);
    descriptor: (Ljava/util/List;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // java.util.List cipherSuites
         0: .line 319
            aload 1 /* cipherSuites */
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultCipherSuites:()Ljava/util/List;
            if_acmpeq 3
         1: .line 320
            aload 1 /* cipherSuites */
            aload 0 /* this */
            invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultCipherSuites:()Ljava/util/List;
            if_acmpeq 3
         2: .line 319
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         3: iconst_1
            ireturn
        end local 1 // java.util.List cipherSuites
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    4     0          this  Lsun/security/ssl/SSLContextImpl;
            0    4     1  cipherSuites  Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
    Signature: (Ljava/util/List<Lsun/security/ssl/CipherSuite;>;)Z
    MethodParameters:
              Name  Flags
      cipherSuites  

  boolean isStaplingEnabled(boolean);
    descriptor: (Z)Z
    flags: (0x0000) 
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLContextImpl this
        start local 1 // boolean isClient
         0: .line 332
            iload 1 /* isClient */
            ifeq 1
            aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.clientEnableStapling:Z
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            getfield sun.security.ssl.SSLContextImpl.serverEnableStapling:Z
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 1 // boolean isClient
        end local 0 // sun.security.ssl.SSLContextImpl this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lsun/security/ssl/SSLContextImpl;
            0    3     1  isClient  Z
    MethodParameters:
          Name  Flags
      isClient  

  private static java.util.List<sun.security.ssl.CipherSuite> getApplicableSupportedCipherSuites(java.util.List<sun.security.ssl.ProtocolVersion>);
    descriptor: (Ljava/util/List;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.util.List protocols
         0: .line 343
            invokestatic sun.security.ssl.CipherSuite.allowedCipherSuites:()Ljava/util/Collection;
            aload 0 /* protocols */
         1: .line 342
            invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            areturn
        end local 0 // java.util.List protocols
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0  protocols  Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
    Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
    MethodParameters:
           Name  Flags
      protocols  

  private static java.util.List<sun.security.ssl.CipherSuite> getApplicableEnabledCipherSuites(java.util.List<sun.security.ssl.ProtocolVersion>, boolean);
    descriptor: (Ljava/util/List;Z)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.util.List protocols
        start local 1 // boolean isClient
         0: .line 353
            iload 1 /* isClient */
            ifeq 4
         1: .line 354
            getstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 7
         2: .line 356
            getstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
            aload 0 /* protocols */
         3: .line 355
            invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            areturn
         4: .line 359
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 7
         5: .line 361
            getstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
            aload 0 /* protocols */
         6: .line 360
            invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            areturn
         7: .line 366
      StackMap locals:
      StackMap stack:
            invokestatic sun.security.ssl.CipherSuite.defaultCipherSuites:()Ljava/util/Collection;
            aload 0 /* protocols */
         8: .line 365
            invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
            areturn
        end local 1 // boolean isClient
        end local 0 // java.util.List protocols
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0  protocols  Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
            0    9     1   isClient  Z
    Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;Z)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
    MethodParameters:
           Name  Flags
      protocols  
      isClient   

  private static java.util.List<sun.security.ssl.CipherSuite> getApplicableCipherSuites(java.util.Collection<sun.security.ssl.CipherSuite>, java.util.List<sun.security.ssl.ProtocolVersion>);
    descriptor: (Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=8, args_size=2
        start local 0 // java.util.Collection allowedCipherSuites
        start local 1 // java.util.List protocols
         0: .line 376
            new java.util.LinkedHashSet
            dup
            invokespecial java.util.LinkedHashSet.<init>:()V
            astore 2 /* suites */
        start local 2 // java.util.LinkedHashSet suites
         1: .line 377
            aload 1 /* protocols */
            ifnull 31
            aload 1 /* protocols */
            invokeinterface java.util.List.isEmpty:()Z
            ifne 31
         2: .line 378
            aload 0 /* allowedCipherSuites */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 30
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet top java.util.Iterator
      StackMap stack:
         3: 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
         4: .line 379
            aload 3 /* suite */
            invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
            ifne 6
         5: .line 380
            goto 30
         6: .line 383
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet sun.security.ssl.CipherSuite java.util.Iterator
      StackMap stack:
            iconst_0
            istore 5 /* isSupported */
        start local 5 // boolean isSupported
         7: .line 384
            aload 1 /* protocols */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 7
            goto 25
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet sun.security.ssl.CipherSuite java.util.Iterator int top java.util.Iterator
      StackMap stack:
         8: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 6 /* protocol */
        start local 6 // sun.security.ssl.ProtocolVersion protocol
         9: .line 385
            aload 3 /* suite */
            aload 6 /* protocol */
            invokevirtual sun.security.ssl.CipherSuite.supports:(Lsun/security/ssl/ProtocolVersion;)Z
            ifeq 25
        10: .line 386
            aload 3 /* suite */
            getfield sun.security.ssl.CipherSuite.bulkCipher:Lsun/security/ssl/SSLCipher;
            invokevirtual sun.security.ssl.SSLCipher.isAvailable:()Z
            ifne 12
        11: .line 387
            goto 25
        12: .line 390
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet sun.security.ssl.CipherSuite java.util.Iterator int sun.security.ssl.ProtocolVersion java.util.Iterator
      StackMap stack:
            getstatic sun.security.ssl.SSLAlgorithmConstraints.DEFAULT:Ljava/security/AlgorithmConstraints;
        13: .line 391
            getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
            invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
        14: .line 392
            aload 3 /* suite */
            getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
            aconst_null
        15: .line 390
            invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
        16: .line 392
            ifeq 20
        17: .line 393
            aload 2 /* suites */
            aload 3 /* suite */
            invokevirtual java.util.LinkedHashSet.add:(Ljava/lang/Object;)Z
            pop
        18: .line 394
            iconst_1
            istore 5 /* isSupported */
        19: .line 395
            goto 26
      StackMap locals:
      StackMap stack:
        20: getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 26
        21: .line 396
            ldc "ssl,sslctx,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 26
        22: .line 398
            new java.lang.StringBuilder
            dup
            ldc "Ignore disabled cipher suite: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* suite */
            getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        23: .line 397
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        24: .line 401
            goto 26
        end local 6 // sun.security.ssl.ProtocolVersion protocol
        25: .line 384
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet sun.security.ssl.CipherSuite java.util.Iterator int top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 8
        26: .line 404
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet sun.security.ssl.CipherSuite java.util.Iterator int
      StackMap stack:
            iload 5 /* isSupported */
            ifne 30
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 30
        27: .line 405
            ldc "ssl,sslctx,verbose"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 30
        28: .line 407
            new java.lang.StringBuilder
            dup
            ldc "Ignore 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;
            iconst_0
            anewarray java.lang.Object
        29: .line 406
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        end local 5 // boolean isSupported
        end local 3 // sun.security.ssl.CipherSuite suite
        30: .line 378
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        31: .line 412
      StackMap locals: java.util.Collection java.util.List java.util.LinkedHashSet
      StackMap stack:
            new java.util.ArrayList
            dup
            aload 2 /* suites */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            areturn
        end local 2 // java.util.LinkedHashSet suites
        end local 1 // java.util.List protocols
        end local 0 // java.util.Collection allowedCipherSuites
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   32     0  allowedCipherSuites  Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
            0   32     1            protocols  Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
            1   32     2               suites  Ljava/util/LinkedHashSet<Lsun/security/ssl/CipherSuite;>;
            4   30     3                suite  Lsun/security/ssl/CipherSuite;
            7   30     5          isSupported  Z
            9   25     6             protocol  Lsun/security/ssl/ProtocolVersion;
    Signature: (Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
    MethodParameters:
                     Name  Flags
      allowedCipherSuites  
      protocols            

  private static java.util.Collection<sun.security.ssl.CipherSuite> getCustomizedCipherSuites(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/Collection;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=1
        start local 0 // java.lang.String propertyName
         0: .line 421
            aload 0 /* propertyName */
            invokestatic sun.security.action.GetPropertyAction.privilegedGetProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* property */
        start local 1 // java.lang.String property
         1: .line 422
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 6
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 6
         2: .line 424
            new java.lang.StringBuilder
            dup
            ldc "System property "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* propertyName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " is set to '"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         3: .line 425
            aload 1 /* property */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "'"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         4: .line 424
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
         5: .line 423
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
         6: .line 427
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* property */
            ifnull 10
            aload 1 /* property */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 10
         7: .line 429
            aload 1 /* property */
            invokevirtual java.lang.String.length:()I
            iconst_1
            if_icmple 10
            aload 1 /* property */
            iconst_0
            invokevirtual java.lang.String.charAt:(I)C
            bipush 34
            if_icmpne 10
         8: .line 430
            aload 1 /* property */
            aload 1 /* property */
            invokevirtual java.lang.String.length:()I
            iconst_1
            isub
            invokevirtual java.lang.String.charAt:(I)C
            bipush 34
            if_icmpne 10
         9: .line 431
            aload 1 /* property */
            iconst_1
            aload 1 /* property */
            invokevirtual java.lang.String.length:()I
            iconst_1
            isub
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 1 /* property */
        10: .line 435
      StackMap locals:
      StackMap stack:
            aload 1 /* property */
            ifnull 39
            aload 1 /* property */
            invokevirtual java.lang.String.isEmpty:()Z
            ifne 39
        11: .line 436
            aload 1 /* property */
            ldc ","
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            astore 2 /* cipherSuiteNames */
        start local 2 // java.lang.String[] cipherSuiteNames
        12: .line 438
            new java.util.ArrayList
            dup
            aload 2 /* cipherSuiteNames */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
        13: .line 437
            astore 3 /* cipherSuites */
        start local 3 // java.util.Collection cipherSuites
        14: .line 439
            iconst_0
            istore 4 /* i */
        start local 4 // int i
        15: goto 37
        16: .line 440
      StackMap locals: java.lang.String[] java.util.Collection int
      StackMap stack:
            aload 2 /* cipherSuiteNames */
            iload 4 /* i */
            aload 2 /* cipherSuiteNames */
            iload 4 /* i */
            aaload
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            aastore
        17: .line 441
            aload 2 /* cipherSuiteNames */
            iload 4 /* i */
            aaload
            invokevirtual java.lang.String.isEmpty:()Z
            ifeq 19
        18: .line 442
            goto 36
        19: .line 447
      StackMap locals:
      StackMap stack:
            aload 2 /* cipherSuiteNames */
            iload 4 /* i */
            aaload
            invokestatic sun.security.ssl.CipherSuite.nameOf:(Ljava/lang/String;)Lsun/security/ssl/CipherSuite;
            astore 5 /* suite */
        start local 5 // sun.security.ssl.CipherSuite suite
        20: .line 448
            goto 28
        end local 5 // sun.security.ssl.CipherSuite suite
      StackMap locals:
      StackMap stack: java.lang.IllegalArgumentException
        21: pop
        22: .line 449
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 36
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 36
        23: .line 451
            new java.lang.StringBuilder
            dup
            ldc "Unknown or unsupported cipher suite name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        24: .line 452
            aload 2 /* cipherSuiteNames */
            iload 4 /* i */
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        25: .line 451
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        26: .line 450
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        27: .line 455
            goto 36
        start local 5 // sun.security.ssl.CipherSuite suite
        28: .line 458
      StackMap locals: sun.security.ssl.CipherSuite
      StackMap stack:
            aload 5 /* suite */
            ifnull 31
            aload 5 /* suite */
            invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
            ifeq 31
        29: .line 459
            aload 3 /* cipherSuites */
            aload 5 /* suite */
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        30: .line 460
            goto 36
        31: .line 461
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 36
            ldc "ssl,sslctx"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 36
        32: .line 463
            new java.lang.StringBuilder
            dup
            ldc "The current installed providers do not support cipher suite: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        33: .line 464
            aload 2 /* cipherSuiteNames */
            iload 4 /* i */
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        34: .line 463
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        35: .line 462
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        end local 5 // sun.security.ssl.CipherSuite suite
        36: .line 439
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        37: iload 4 /* i */
            aload 2 /* cipherSuiteNames */
            arraylength
            if_icmplt 16
        end local 4 // int i
        38: .line 469
            aload 3 /* cipherSuites */
            areturn
        end local 3 // java.util.Collection cipherSuites
        end local 2 // java.lang.String[] cipherSuiteNames
        39: .line 472
      StackMap locals:
      StackMap stack:
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
        end local 1 // java.lang.String property
        end local 0 // java.lang.String propertyName
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   40     0      propertyName  Ljava/lang/String;
            1   40     1          property  Ljava/lang/String;
           12   39     2  cipherSuiteNames  [Ljava/lang/String;
           14   39     3      cipherSuites  Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
           15   38     4                 i  I
           20   21     5             suite  Lsun/security/ssl/CipherSuite;
           28   36     5             suite  Lsun/security/ssl/CipherSuite;
      Exception table:
        from    to  target  type
          19    20      21  Class java.lang.IllegalArgumentException
    Signature: (Ljava/lang/String;)Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
    MethodParameters:
              Name  Flags
      propertyName  

  private static java.util.List<sun.security.ssl.ProtocolVersion> getAvailableProtocols(sun.security.ssl.ProtocolVersion[]);
    descriptor: ([Lsun/security/ssl/ProtocolVersion;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // sun.security.ssl.ProtocolVersion[] protocolCandidates
         0: .line 480
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
         1: .line 479
            astore 1 /* availableProtocols */
        start local 1 // java.util.List availableProtocols
         2: .line 481
            aload 0 /* protocolCandidates */
            ifnull 10
            aload 0 /* protocolCandidates */
            arraylength
            ifeq 10
         3: .line 482
            new java.util.ArrayList
            dup
            aload 0 /* protocolCandidates */
            arraylength
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 1 /* availableProtocols */
         4: .line 483
            aload 0 /* protocolCandidates */
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 9
      StackMap locals: sun.security.ssl.ProtocolVersion[] java.util.List top int int sun.security.ssl.ProtocolVersion[]
      StackMap stack:
         5: aload 5
            iload 3
            aaload
            astore 2 /* p */
        start local 2 // sun.security.ssl.ProtocolVersion p
         6: .line 484
            aload 2 /* p */
            getfield sun.security.ssl.ProtocolVersion.isAvailable:Z
            ifeq 8
         7: .line 485
            aload 1 /* availableProtocols */
            aload 2 /* p */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // sun.security.ssl.ProtocolVersion p
         8: .line 483
      StackMap locals:
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
         9: iload 3
            iload 4
            if_icmplt 5
        10: .line 490
      StackMap locals: sun.security.ssl.ProtocolVersion[] java.util.List
      StackMap stack:
            aload 1 /* availableProtocols */
            areturn
        end local 1 // java.util.List availableProtocols
        end local 0 // sun.security.ssl.ProtocolVersion[] protocolCandidates
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   11     0  protocolCandidates  [Lsun/security/ssl/ProtocolVersion;
            2   11     1  availableProtocols  Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
            6    8     2                   p  Lsun/security/ssl/ProtocolVersion;
    Signature: ([Lsun/security/ssl/ProtocolVersion;)Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
    MethodParameters:
                    Name  Flags
      protocolCandidates  
}
SourceFile: "SSLContextImpl.java"
NestMembers:
  sun.security.ssl.SSLContextImpl$AbstractDTLSContext  sun.security.ssl.SSLContextImpl$AbstractTLSContext  sun.security.ssl.SSLContextImpl$CustomizedDTLSContext  sun.security.ssl.SSLContextImpl$CustomizedSSLProtocols  sun.security.ssl.SSLContextImpl$CustomizedTLSContext  sun.security.ssl.SSLContextImpl$DTLS10Context  sun.security.ssl.SSLContextImpl$DTLS12Context  sun.security.ssl.SSLContextImpl$DTLSContext  sun.security.ssl.SSLContextImpl$DefaultManagersHolder  sun.security.ssl.SSLContextImpl$DefaultManagersHolder$1  sun.security.ssl.SSLContextImpl$DefaultManagersHolder$2  sun.security.ssl.SSLContextImpl$DefaultSSLContext  sun.security.ssl.SSLContextImpl$DefaultSSLContextHolder  sun.security.ssl.SSLContextImpl$TLS10Context  sun.security.ssl.SSLContextImpl$TLS11Context  sun.security.ssl.SSLContextImpl$TLS12Context  sun.security.ssl.SSLContextImpl$TLS13Context  sun.security.ssl.SSLContextImpl$TLSContext
InnerClasses:
  Builder = sun.security.ssl.HelloCookieManager$Builder of sun.security.ssl.HelloCookieManager
  private abstract AbstractDTLSContext = sun.security.ssl.SSLContextImpl$AbstractDTLSContext of sun.security.ssl.SSLContextImpl
  private abstract AbstractTLSContext = sun.security.ssl.SSLContextImpl$AbstractTLSContext of sun.security.ssl.SSLContextImpl
  private CustomizedDTLSContext = sun.security.ssl.SSLContextImpl$CustomizedDTLSContext of sun.security.ssl.SSLContextImpl
  private CustomizedSSLProtocols = sun.security.ssl.SSLContextImpl$CustomizedSSLProtocols of sun.security.ssl.SSLContextImpl
  private CustomizedTLSContext = sun.security.ssl.SSLContextImpl$CustomizedTLSContext of sun.security.ssl.SSLContextImpl
  public final DTLS10Context = sun.security.ssl.SSLContextImpl$DTLS10Context of sun.security.ssl.SSLContextImpl
  public final DTLS12Context = sun.security.ssl.SSLContextImpl$DTLS12Context of sun.security.ssl.SSLContextImpl
  public final DTLSContext = sun.security.ssl.SSLContextImpl$DTLSContext of sun.security.ssl.SSLContextImpl
  private final DefaultManagersHolder = sun.security.ssl.SSLContextImpl$DefaultManagersHolder of sun.security.ssl.SSLContextImpl
  public final DefaultSSLContext = sun.security.ssl.SSLContextImpl$DefaultSSLContext of sun.security.ssl.SSLContextImpl
  private final DefaultSSLContextHolder = sun.security.ssl.SSLContextImpl$DefaultSSLContextHolder of sun.security.ssl.SSLContextImpl
  public final TLS10Context = sun.security.ssl.SSLContextImpl$TLS10Context of sun.security.ssl.SSLContextImpl
  public final TLS11Context = sun.security.ssl.SSLContextImpl$TLS11Context of sun.security.ssl.SSLContextImpl
  public final TLS12Context = sun.security.ssl.SSLContextImpl$TLS12Context of sun.security.ssl.SSLContextImpl
  public final TLS13Context = sun.security.ssl.SSLContextImpl$TLS13Context of sun.security.ssl.SSLContextImpl
  public final TLSContext = sun.security.ssl.SSLContextImpl$TLSContext of sun.security.ssl.SSLContextImpl
  final StatelessKey = sun.security.ssl.SessionTicketExtension$StatelessKey of sun.security.ssl.SessionTicketExtension