final class sun.security.ssl.SSLConfiguration implements java.lang.Cloneable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.SSLConfiguration
  super_class: java.lang.Object
{
  java.security.AlgorithmConstraints userSpecifiedAlgorithmConstraints;
    descriptor: Ljava/security/AlgorithmConstraints;
    flags: (0x0000) 

  java.util.List<sun.security.ssl.ProtocolVersion> enabledProtocols;
    descriptor: Ljava/util/List;
    flags: (0x0000) 
    Signature: Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;

  java.util.List<sun.security.ssl.CipherSuite> enabledCipherSuites;
    descriptor: Ljava/util/List;
    flags: (0x0000) 
    Signature: Ljava/util/List<Lsun/security/ssl/CipherSuite;>;

  sun.security.ssl.ClientAuthType clientAuthType;
    descriptor: Lsun/security/ssl/ClientAuthType;
    flags: (0x0000) 

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

  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[] applicationProtocols;
    descriptor: [Ljava/lang/String;
    flags: (0x0000) 

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

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

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

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

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

  java.util.function.BiFunction<javax.net.ssl.SSLSocket, java.util.List<java.lang.String>, java.lang.String> socketAPSelector;
    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;>;

  java.util.function.BiFunction<javax.net.ssl.SSLEngine, java.util.List<java.lang.String>, java.lang.String> engineAPSelector;
    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.HashMap<javax.net.ssl.HandshakeCompletedListener, java.security.AccessControlContext> handshakeListeners;
    descriptor: Ljava/util/HashMap;
    flags: (0x0000) 
    Signature: Ljava/util/HashMap<Ljavax/net/ssl/HandshakeCompletedListener;Ljava/security/AccessControlContext;>;

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

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

  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

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

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

  private static volatile int[] $SWITCH_TABLE$sun$security$ssl$ClientAuthType;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: .line 88
            ldc "jdk.tls.allowLegacyResumption"
            iconst_1
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
         1: .line 87
            putstatic sun.security.ssl.SSLConfiguration.allowLegacyResumption:Z
         2: .line 92
            ldc "jdk.tls.allowLegacyMasterSecret"
            iconst_1
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
         3: .line 91
            putstatic sun.security.ssl.SSLConfiguration.allowLegacyMasterSecret:Z
         4: .line 96
            ldc "jdk.tls.client.useCompatibilityMode"
            iconst_1
         5: .line 95
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            putstatic sun.security.ssl.SSLConfiguration.useCompatibilityMode:Z
         6: .line 100
            ldc "jdk.tls.acknowledgeCloseNotify"
            iconst_0
         7: .line 99
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            putstatic sun.security.ssl.SSLConfiguration.acknowledgeCloseNotify:Z
         8: .line 105
            ldc "jdk.tls.useExtendedMasterSecret"
            iconst_1
         9: .line 104
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
            istore 0 /* supportExtendedMasterSecret */
        start local 0 // boolean supportExtendedMasterSecret
        10: .line 106
            iload 0 /* supportExtendedMasterSecret */
            ifeq 15
        11: .line 108
            ldc "SunTlsExtendedMasterSecret"
            invokestatic sun.security.ssl.JsseJce.getKeyGenerator:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            pop
        12: .line 109
            goto 15
      StackMap locals: int
      StackMap stack: java.security.NoSuchAlgorithmException
        13: pop
        14: .line 110
            iconst_0
            istore 0 /* supportExtendedMasterSecret */
        15: .line 113
      StackMap locals:
      StackMap stack:
            iload 0 /* supportExtendedMasterSecret */
            putstatic sun.security.ssl.SSLConfiguration.useExtendedMasterSecret:Z
        end local 0 // boolean supportExtendedMasterSecret
        16: .line 114
            return
      LocalVariableTable:
        Start  End  Slot                         Name  Signature
           10   16     0  supportExtendedMasterSecret  Z
      Exception table:
        from    to  target  type
          11    12      13  Class java.security.NoSuchAlgorithmException

  void <init>(sun.security.ssl.SSLContextImpl, boolean);
    descriptor: (Lsun/security/ssl/SSLContextImpl;Z)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLContextImpl sslContext
        start local 2 // boolean isClientMode
         0: .line 116
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 64
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLConfiguration.maximumPacketSize:I
         2: .line 119
            aload 0 /* this */
         3: .line 120
            getstatic sun.security.ssl.SSLAlgorithmConstraints.DEFAULT:Ljava/security/AlgorithmConstraints;
         4: .line 119
            putfield sun.security.ssl.SSLConfiguration.userSpecifiedAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
         5: .line 121
            aload 0 /* this */
         6: .line 122
            aload 1 /* sslContext */
            iload 2 /* isClientMode */
            ifeq 7
            iconst_0
            goto 8
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl
         7: iconst_1
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
         8: invokevirtual sun.security.ssl.SSLContextImpl.getDefaultProtocolVersions:(Z)Ljava/util/List;
         9: .line 121
            putfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
        10: .line 123
            aload 0 /* this */
        11: .line 124
            aload 1 /* sslContext */
            iload 2 /* isClientMode */
            ifeq 12
            iconst_0
            goto 13
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl
        12: iconst_1
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
      StackMap stack: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int
        13: invokevirtual sun.security.ssl.SSLContextImpl.getDefaultCipherSuites:(Z)Ljava/util/List;
        14: .line 123
            putfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
        15: .line 125
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        16: .line 127
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
        17: .line 128
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
        18: .line 129
            aload 0 /* this */
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
        19: .line 130
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
        20: .line 132
            aload 0 /* this */
            iconst_0
            anewarray java.lang.String
            putfield sun.security.ssl.SSLConfiguration.applicationProtocols:[Ljava/lang/String;
        21: .line 134
            aload 0 /* this */
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        22: .line 135
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 26
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLContextImpl int top java.util.Iterator
      StackMap stack:
        23: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 3 /* pv */
        start local 3 // sun.security.ssl.ProtocolVersion pv
        24: .line 136
            aload 3 /* pv */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.compareTo:(Ljava/lang/Enum;)I
            ifle 26
        25: .line 137
            aload 0 /* this */
            aload 3 /* pv */
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        end local 3 // sun.security.ssl.ProtocolVersion pv
        26: .line 135
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 23
        27: .line 142
            aload 0 /* this */
            iload 2 /* isClientMode */
            putfield sun.security.ssl.SSLConfiguration.isClientMode:Z
        28: .line 143
            aload 0 /* this */
            iconst_1
            putfield sun.security.ssl.SSLConfiguration.enableSessionCreation:Z
        29: .line 144
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.socketAPSelector:Ljava/util/function/BiFunction;
        30: .line 145
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.engineAPSelector:Ljava/util/function/BiFunction;
        31: .line 147
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
        32: .line 148
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLConfiguration.noSniExtension:Z
        33: .line 149
            aload 0 /* this */
            iconst_0
            putfield sun.security.ssl.SSLConfiguration.noSniMatcher:Z
        34: .line 150
            return
        end local 2 // boolean isClientMode
        end local 1 // sun.security.ssl.SSLContextImpl sslContext
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   35     0          this  Lsun/security/ssl/SSLConfiguration;
            0   35     1    sslContext  Lsun/security/ssl/SSLContextImpl;
            0   35     2  isClientMode  Z
           24   26     3            pv  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
              Name  Flags
      sslContext    
      isClientMode  

  javax.net.ssl.SSLParameters getSSLParameters();
    descriptor: ()Ljavax/net/ssl/SSLParameters;
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.ssl.SSLConfiguration this
         0: .line 153
            new javax.net.ssl.SSLParameters
            dup
            invokespecial javax.net.ssl.SSLParameters.<init>:()V
            astore 1 /* params */
        start local 1 // javax.net.ssl.SSLParameters params
         1: .line 155
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.userSpecifiedAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
            invokevirtual javax.net.ssl.SSLParameters.setAlgorithmConstraints:(Ljava/security/AlgorithmConstraints;)V
         2: .line 156
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokestatic sun.security.ssl.ProtocolVersion.toStringArray:(Ljava/util/List;)[Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setProtocols:([Ljava/lang/String;)V
         3: .line 157
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
            invokestatic sun.security.ssl.CipherSuite.namesOf:(Ljava/util/List;)[Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setCipherSuites:([Ljava/lang/String;)V
         4: .line 158
            invokestatic sun.security.ssl.SSLConfiguration.$SWITCH_TABLE$sun$security$ssl$ClientAuthType:()[I
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iaload
            tableswitch { // 2 - 3
                    2: 7
                    3: 5
              default: 9
          }
         5: .line 160
      StackMap locals: javax.net.ssl.SSLParameters
      StackMap stack:
            aload 1 /* params */
            iconst_1
            invokevirtual javax.net.ssl.SSLParameters.setNeedClientAuth:(Z)V
         6: .line 161
            goto 10
         7: .line 163
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            iconst_1
            invokevirtual javax.net.ssl.SSLParameters.setWantClientAuth:(Z)V
         8: .line 164
            goto 10
         9: .line 166
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            iconst_0
            invokevirtual javax.net.ssl.SSLParameters.setWantClientAuth:(Z)V
        10: .line 168
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setEndpointIdentificationAlgorithm:(Ljava/lang/String;)V
        11: .line 170
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 14
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.noSniExtension:Z
            ifne 14
        12: .line 172
            aload 1 /* params */
            aconst_null
            invokevirtual javax.net.ssl.SSLParameters.setServerNames:(Ljava/util/List;)V
        13: .line 173
            goto 15
        14: .line 174
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
            invokevirtual javax.net.ssl.SSLParameters.setServerNames:(Ljava/util/List;)V
        15: .line 177
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 18
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.noSniMatcher:Z
            ifne 18
        16: .line 179
            aload 1 /* params */
            aconst_null
            invokevirtual javax.net.ssl.SSLParameters.setSNIMatchers:(Ljava/util/Collection;)V
        17: .line 180
            goto 19
        18: .line 181
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
            invokevirtual javax.net.ssl.SSLParameters.setSNIMatchers:(Ljava/util/Collection;)V
        19: .line 184
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.applicationProtocols:[Ljava/lang/String;
            invokevirtual javax.net.ssl.SSLParameters.setApplicationProtocols:([Ljava/lang/String;)V
        20: .line 185
            aload 1 /* params */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
            invokevirtual javax.net.ssl.SSLParameters.setUseCipherSuitesOrder:(Z)V
        21: .line 187
            aload 1 /* params */
            areturn
        end local 1 // javax.net.ssl.SSLParameters params
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   22     0    this  Lsun/security/ssl/SSLConfiguration;
            1   22     1  params  Ljavax/net/ssl/SSLParameters;

  void setSSLParameters(javax.net.ssl.SSLParameters);
    descriptor: (Ljavax/net/ssl/SSLParameters;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // javax.net.ssl.SSLParameters params
         0: .line 191
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getAlgorithmConstraints:()Ljava/security/AlgorithmConstraints;
            astore 2 /* ac */
        start local 2 // java.security.AlgorithmConstraints ac
         1: .line 192
            aload 2 /* ac */
            ifnull 3
         2: .line 193
            aload 0 /* this */
            aload 2 /* ac */
            putfield sun.security.ssl.SSLConfiguration.userSpecifiedAlgorithmConstraints:Ljava/security/AlgorithmConstraints;
         3: .line 196
      StackMap locals: java.security.AlgorithmConstraints
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getCipherSuites:()[Ljava/lang/String;
            astore 3 /* sa */
        start local 3 // java.lang.String[] sa
         4: .line 197
            aload 3 /* sa */
            ifnull 6
         5: .line 198
            aload 0 /* this */
            aload 3 /* sa */
            invokestatic sun.security.ssl.CipherSuite.validValuesOf:([Ljava/lang/String;)Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.enabledCipherSuites:Ljava/util/List;
         6: .line 201
      StackMap locals: java.lang.String[]
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getProtocols:()[Ljava/lang/String;
            astore 3 /* sa */
         7: .line 202
            aload 3 /* sa */
            ifnull 15
         8: .line 203
            aload 0 /* this */
            aload 3 /* sa */
            invokestatic sun.security.ssl.ProtocolVersion.namesOf:([Ljava/lang/String;)Ljava/util/List;
            putfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
         9: .line 205
            aload 0 /* this */
            getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        10: .line 206
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 14
      StackMap locals: sun.security.ssl.SSLConfiguration javax.net.ssl.SSLParameters java.security.AlgorithmConstraints java.lang.String[] top java.util.Iterator
      StackMap stack:
        11: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 4 /* pv */
        start local 4 // sun.security.ssl.ProtocolVersion pv
        12: .line 207
            aload 4 /* pv */
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.compareTo:(Ljava/lang/Enum;)I
            ifle 14
        13: .line 208
            aload 0 /* this */
            aload 4 /* pv */
            putfield sun.security.ssl.SSLConfiguration.maximumProtocolVersion:Lsun/security/ssl/ProtocolVersion;
        end local 4 // sun.security.ssl.ProtocolVersion pv
        14: .line 206
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 11
        15: .line 213
      StackMap locals: sun.security.ssl.SSLConfiguration javax.net.ssl.SSLParameters java.security.AlgorithmConstraints java.lang.String[]
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getNeedClientAuth:()Z
            ifeq 18
        16: .line 214
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUIRED:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        17: .line 215
            goto 22
      StackMap locals:
      StackMap stack:
        18: aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getWantClientAuth:()Z
            ifeq 21
        19: .line 216
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUESTED:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        20: .line 217
            goto 22
        21: .line 218
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
            putfield sun.security.ssl.SSLConfiguration.clientAuthType:Lsun/security/ssl/ClientAuthType;
        22: .line 221
      StackMap locals:
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
            astore 4 /* s */
        start local 4 // java.lang.String s
        23: .line 222
            aload 4 /* s */
            ifnull 25
        24: .line 223
            aload 0 /* this */
            aload 4 /* s */
            putfield sun.security.ssl.SSLConfiguration.identificationProtocol:Ljava/lang/String;
        25: .line 226
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getServerNames:()Ljava/util/List;
            astore 5 /* sniNames */
        start local 5 // java.util.List sniNames
        26: .line 227
            aload 5 /* sniNames */
            ifnull 29
        27: .line 228
            aload 0 /* this */
            aload 5 /* sniNames */
            invokeinterface java.util.List.isEmpty:()Z
            putfield sun.security.ssl.SSLConfiguration.noSniExtension:Z
        28: .line 229
            aload 0 /* this */
            aload 5 /* sniNames */
            putfield sun.security.ssl.SSLConfiguration.serverNames:Ljava/util/List;
        29: .line 232
      StackMap locals: java.util.List
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getSNIMatchers:()Ljava/util/Collection;
            astore 6 /* matchers */
        start local 6 // java.util.Collection matchers
        30: .line 233
            aload 6 /* matchers */
            ifnull 33
        31: .line 234
            aload 0 /* this */
            aload 6 /* matchers */
            invokeinterface java.util.Collection.isEmpty:()Z
            putfield sun.security.ssl.SSLConfiguration.noSniMatcher:Z
        32: .line 235
            aload 0 /* this */
            aload 6 /* matchers */
            putfield sun.security.ssl.SSLConfiguration.sniMatchers:Ljava/util/Collection;
        33: .line 238
      StackMap locals: java.util.Collection
      StackMap stack:
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getApplicationProtocols:()[Ljava/lang/String;
            astore 3 /* sa */
        34: .line 239
            aload 3 /* sa */
            ifnull 36
        35: .line 240
            aload 0 /* this */
            aload 3 /* sa */
            putfield sun.security.ssl.SSLConfiguration.applicationProtocols:[Ljava/lang/String;
        36: .line 243
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* params */
            invokevirtual javax.net.ssl.SSLParameters.getUseCipherSuitesOrder:()Z
            putfield sun.security.ssl.SSLConfiguration.preferLocalCipherSuites:Z
        37: .line 244
            return
        end local 6 // java.util.Collection matchers
        end local 5 // java.util.List sniNames
        end local 4 // java.lang.String s
        end local 3 // java.lang.String[] sa
        end local 2 // java.security.AlgorithmConstraints ac
        end local 1 // javax.net.ssl.SSLParameters params
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   38     0      this  Lsun/security/ssl/SSLConfiguration;
            0   38     1    params  Ljavax/net/ssl/SSLParameters;
            1   38     2        ac  Ljava/security/AlgorithmConstraints;
            4   38     3        sa  [Ljava/lang/String;
           12   14     4        pv  Lsun/security/ssl/ProtocolVersion;
           23   38     4         s  Ljava/lang/String;
           26   38     5  sniNames  Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
           30   38     6  matchers  Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;
    MethodParameters:
        Name  Flags
      params  

  void addHandshakeCompletedListener(javax.net.ssl.HandshakeCompletedListener);
    descriptor: (Ljavax/net/ssl/HandshakeCompletedListener;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // javax.net.ssl.HandshakeCompletedListener listener
         0: .line 250
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            ifnonnull 2
         1: .line 251
            aload 0 /* this */
            new java.util.HashMap
            dup
            iconst_4
            invokespecial java.util.HashMap.<init>:(I)V
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
         2: .line 254
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            aload 1 /* listener */
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 255
            return
        end local 1 // javax.net.ssl.HandshakeCompletedListener listener
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0      this  Lsun/security/ssl/SSLConfiguration;
            0    4     1  listener  Ljavax/net/ssl/HandshakeCompletedListener;
    MethodParameters:
          Name  Flags
      listener  

  void removeHandshakeCompletedListener(javax.net.ssl.HandshakeCompletedListener);
    descriptor: (Ljavax/net/ssl/HandshakeCompletedListener;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // javax.net.ssl.HandshakeCompletedListener listener
         0: .line 261
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            ifnonnull 2
         1: .line 262
            new java.lang.IllegalArgumentException
            dup
            ldc "no listeners"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 265
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            aload 1 /* listener */
            invokevirtual java.util.HashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnonnull 4
         3: .line 266
            new java.lang.IllegalArgumentException
            dup
            ldc "listener not registered"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 269
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.isEmpty:()Z
            ifeq 6
         5: .line 270
            aload 0 /* this */
            aconst_null
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
         6: .line 272
      StackMap locals:
      StackMap stack:
            return
        end local 1 // javax.net.ssl.HandshakeCompletedListener listener
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lsun/security/ssl/SSLConfiguration;
            0    7     1  listener  Ljavax/net/ssl/HandshakeCompletedListener;
    MethodParameters:
          Name  Flags
      listener  

  boolean isAvailable(sun.security.ssl.SSLExtension);
    descriptor: (Lsun/security/ssl/SSLExtension;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLExtension extension
         0: .line 278
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.enabledProtocols:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLExtension top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 2 /* protocolVersion */
        start local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         2: .line 279
            aload 1 /* extension */
            aload 2 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLExtension.isAvailable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifeq 7
         3: .line 280
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            ifeq 5
         4: .line 281
            getstatic sun.security.ssl.SSLExtension$ClientExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 7
            goto 6
         5: .line 282
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLExtension sun.security.ssl.ProtocolVersion java.util.Iterator
      StackMap stack:
            getstatic sun.security.ssl.SSLExtension$ServerExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 7
         6: .line 283
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         7: .line 278
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLExtension top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         8: .line 288
            iconst_0
            ireturn
        end local 1 // sun.security.ssl.SSLExtension extension
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Lsun/security/ssl/SSLConfiguration;
            0    9     1        extension  Lsun/security/ssl/SSLExtension;
            2    7     2  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
           Name  Flags
      extension  

  boolean isAvailable(sun.security.ssl.SSLExtension, sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/SSLExtension;Lsun/security/ssl/ProtocolVersion;)Z
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLExtension extension
        start local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 296
            aload 1 /* extension */
            aload 2 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLExtension.isAvailable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifeq 4
         1: .line 297
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            ifeq 2
            getstatic sun.security.ssl.SSLExtension$ClientExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 4
            goto 3
         2: .line 298
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLExtension$ServerExtensions.defaults:Ljava/util/Collection;
            aload 1 /* extension */
            invokeinterface java.util.Collection.contains:(Ljava/lang/Object;)Z
            ifeq 4
         3: .line 296
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         4: iconst_0
            ireturn
        end local 2 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 1 // sun.security.ssl.SSLExtension extension
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lsun/security/ssl/SSLConfiguration;
            0    5     1        extension  Lsun/security/ssl/SSLExtension;
            0    5     2  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      extension        
      protocolVersion  

  sun.security.ssl.SSLExtension[] getEnabledExtensions(sun.security.ssl.SSLHandshake);
    descriptor: (Lsun/security/ssl/SSLHandshake;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
         0: .line 307
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* extensions */
        start local 2 // java.util.List extensions
         1: .line 308
            invokestatic sun.security.ssl.SSLExtension.values:()[Lsun/security/ssl/SSLExtension;
            dup
            astore 6
            arraylength
            istore 5
            iconst_0
            istore 4
            goto 7
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
         2: aload 6
            iload 4
            aaload
            astore 3 /* extension */
        start local 3 // sun.security.ssl.SSLExtension extension
         3: .line 309
            aload 3 /* extension */
            getfield sun.security.ssl.SSLExtension.handshakeType:Lsun/security/ssl/SSLHandshake;
            aload 1 /* handshakeType */
            if_acmpne 6
         4: .line 310
            aload 0 /* this */
            aload 3 /* extension */
            invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
            ifeq 6
         5: .line 311
            aload 2 /* extensions */
            aload 3 /* extension */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // sun.security.ssl.SSLExtension extension
         6: .line 308
      StackMap locals:
      StackMap stack:
            iinc 4 1
      StackMap locals:
      StackMap stack:
         7: iload 4
            iload 5
            if_icmplt 2
         8: .line 316
            aload 2 /* extensions */
            iconst_0
            anewarray sun.security.ssl.SSLExtension
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.ssl.SSLExtension[]
            areturn
        end local 2 // java.util.List extensions
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/ssl/SSLConfiguration;
            0    9     1  handshakeType  Lsun/security/ssl/SSLHandshake;
            1    9     2     extensions  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            3    6     3      extension  Lsun/security/ssl/SSLExtension;
    MethodParameters:
               Name  Flags
      handshakeType  

  sun.security.ssl.SSLExtension[] getExclusiveExtensions(sun.security.ssl.SSLHandshake, java.util.List<sun.security.ssl.SSLExtension>);
    descriptor: (Lsun/security/ssl/SSLHandshake;Ljava/util/List;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=2, locals=8, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
        start local 2 // java.util.List excluded
         0: .line 327
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 3 /* extensions */
        start local 3 // java.util.List extensions
         1: .line 328
            invokestatic sun.security.ssl.SSLExtension.values:()[Lsun/security/ssl/SSLExtension;
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 7
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
         2: aload 7
            iload 5
            aaload
            astore 4 /* extension */
        start local 4 // sun.security.ssl.SSLExtension extension
         3: .line 329
            aload 4 /* extension */
            getfield sun.security.ssl.SSLExtension.handshakeType:Lsun/security/ssl/SSLHandshake;
            aload 1 /* handshakeType */
            if_acmpne 6
         4: .line 330
            aload 0 /* this */
            aload 4 /* extension */
            invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
            ifeq 6
            aload 2 /* excluded */
            aload 4 /* extension */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifne 6
         5: .line 331
            aload 3 /* extensions */
            aload 4 /* extension */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // sun.security.ssl.SSLExtension extension
         6: .line 328
      StackMap locals:
      StackMap stack:
            iinc 5 1
      StackMap locals:
      StackMap stack:
         7: iload 5
            iload 6
            if_icmplt 2
         8: .line 336
            aload 3 /* extensions */
            iconst_0
            anewarray sun.security.ssl.SSLExtension
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.ssl.SSLExtension[]
            areturn
        end local 3 // java.util.List extensions
        end local 2 // java.util.List excluded
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/ssl/SSLConfiguration;
            0    9     1  handshakeType  Lsun/security/ssl/SSLHandshake;
            0    9     2       excluded  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            1    9     3     extensions  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            3    6     4      extension  Lsun/security/ssl/SSLExtension;
    Signature: (Lsun/security/ssl/SSLHandshake;Ljava/util/List<Lsun/security/ssl/SSLExtension;>;)[Lsun/security/ssl/SSLExtension;
    MethodParameters:
               Name  Flags
      handshakeType  
      excluded       

  sun.security.ssl.SSLExtension[] getEnabledExtensions(sun.security.ssl.SSLHandshake, sun.security.ssl.ProtocolVersion);
    descriptor: (Lsun/security/ssl/SSLHandshake;Lsun/security/ssl/ProtocolVersion;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
        start local 2 // sun.security.ssl.ProtocolVersion protocolVersion
         0: .line 348
            aload 0 /* this */
         1: .line 349
            aload 1 /* handshakeType */
            iconst_1
            anewarray sun.security.ssl.ProtocolVersion
            dup
            iconst_0
            aload 2 /* protocolVersion */
            aastore
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
         2: .line 348
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;Ljava/util/List;)[Lsun/security/ssl/SSLExtension;
            areturn
        end local 2 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lsun/security/ssl/SSLConfiguration;
            0    3     1    handshakeType  Lsun/security/ssl/SSLHandshake;
            0    3     2  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    MethodParameters:
                 Name  Flags
      handshakeType    
      protocolVersion  

  sun.security.ssl.SSLExtension[] getEnabledExtensions(sun.security.ssl.SSLHandshake, java.util.List<sun.security.ssl.ProtocolVersion>);
    descriptor: (Lsun/security/ssl/SSLHandshake;Ljava/util/List;)[Lsun/security/ssl/SSLExtension;
    flags: (0x0000) 
    Code:
      stack=2, locals=10, args_size=3
        start local 0 // sun.security.ssl.SSLConfiguration this
        start local 1 // sun.security.ssl.SSLHandshake handshakeType
        start local 2 // java.util.List activeProtocols
         0: .line 361
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 3 /* extensions */
        start local 3 // java.util.List extensions
         1: .line 362
            invokestatic sun.security.ssl.SSLExtension.values:()[Lsun/security/ssl/SSLExtension;
            dup
            astore 7
            arraylength
            istore 6
            iconst_0
            istore 5
            goto 13
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
         2: aload 7
            iload 5
            aaload
            astore 4 /* extension */
        start local 4 // sun.security.ssl.SSLExtension extension
         3: .line 363
            aload 4 /* extension */
            getfield sun.security.ssl.SSLExtension.handshakeType:Lsun/security/ssl/SSLHandshake;
            aload 1 /* handshakeType */
            if_acmpne 12
         4: .line 364
            aload 0 /* this */
            aload 4 /* extension */
            invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
            ifne 6
         5: .line 365
            goto 12
         6: .line 368
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List sun.security.ssl.SSLExtension int int sun.security.ssl.SSLExtension[]
      StackMap stack:
            aload 2 /* activeProtocols */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 11
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List sun.security.ssl.SSLExtension int int sun.security.ssl.SSLExtension[] top java.util.Iterator
      StackMap stack:
         7: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.ssl.ProtocolVersion
            astore 8 /* protocolVersion */
        start local 8 // sun.security.ssl.ProtocolVersion protocolVersion
         8: .line 369
            aload 4 /* extension */
            aload 8 /* protocolVersion */
            invokevirtual sun.security.ssl.SSLExtension.isAvailable:(Lsun/security/ssl/ProtocolVersion;)Z
            ifeq 11
         9: .line 370
            aload 3 /* extensions */
            aload 4 /* extension */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        10: .line 371
            goto 12
        end local 8 // sun.security.ssl.ProtocolVersion protocolVersion
        11: .line 368
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        end local 4 // sun.security.ssl.SSLExtension extension
        12: .line 362
      StackMap locals: sun.security.ssl.SSLConfiguration sun.security.ssl.SSLHandshake java.util.List java.util.List top int int sun.security.ssl.SSLExtension[]
      StackMap stack:
            iinc 5 1
      StackMap locals:
      StackMap stack:
        13: iload 5
            iload 6
            if_icmplt 2
        14: .line 377
            aload 3 /* extensions */
            iconst_0
            anewarray sun.security.ssl.SSLExtension
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast sun.security.ssl.SSLExtension[]
            areturn
        end local 3 // java.util.List extensions
        end local 2 // java.util.List activeProtocols
        end local 1 // sun.security.ssl.SSLHandshake handshakeType
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   15     0             this  Lsun/security/ssl/SSLConfiguration;
            0   15     1    handshakeType  Lsun/security/ssl/SSLHandshake;
            0   15     2  activeProtocols  Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
            1   15     3       extensions  Ljava/util/List<Lsun/security/ssl/SSLExtension;>;
            3   12     4        extension  Lsun/security/ssl/SSLExtension;
            8   11     8  protocolVersion  Lsun/security/ssl/ProtocolVersion;
    Signature: (Lsun/security/ssl/SSLHandshake;Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)[Lsun/security/ssl/SSLExtension;
    MethodParameters:
                 Name  Flags
      handshakeType    
      activeProtocols  

  public java.lang.Object clone();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // sun.security.ssl.SSLConfiguration this
         0: .line 385
            aload 0 /* this */
            invokespecial java.lang.Object.clone:()Ljava/lang/Object;
            checkcast sun.security.ssl.SSLConfiguration
            astore 1 /* config */
        start local 1 // sun.security.ssl.SSLConfiguration config
         1: .line 386
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            ifnull 6
         2: .line 387
            aload 1 /* config */
         3: .line 389
            aload 0 /* this */
            getfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.clone:()Ljava/lang/Object;
         4: .line 388
            checkcast java.util.HashMap
         5: .line 387
            putfield sun.security.ssl.SSLConfiguration.handshakeListeners:Ljava/util/HashMap;
         6: .line 392
      StackMap locals: sun.security.ssl.SSLConfiguration
      StackMap stack:
            aload 1 /* config */
         7: areturn
        end local 1 // sun.security.ssl.SSLConfiguration config
         8: .line 393
      StackMap locals: sun.security.ssl.SSLConfiguration
      StackMap stack: java.lang.CloneNotSupportedException
            pop
         9: .line 397
            aconst_null
            areturn
        end local 0 // sun.security.ssl.SSLConfiguration this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Lsun/security/ssl/SSLConfiguration;
            1    8     1  config  Lsun/security/ssl/SSLConfiguration;
      Exception table:
        from    to  target  type
           0     7       8  Class java.lang.CloneNotSupportedException

  static int[] $SWITCH_TABLE$sun$security$ssl$ClientAuthType();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 53
            getstatic sun.security.ssl.SSLConfiguration.$SWITCH_TABLE$sun$security$ssl$ClientAuthType:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic sun.security.ssl.ClientAuthType.values:()[Lsun/security/ssl/ClientAuthType;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_NONE:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iconst_1
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUESTED:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iconst_2
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic sun.security.ssl.ClientAuthType.CLIENT_AUTH_REQUIRED:Lsun/security/ssl/ClientAuthType;
            invokevirtual sun.security.ssl.ClientAuthType.ordinal:()I
            iconst_3
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            dup
            putstatic sun.security.ssl.SSLConfiguration.$SWITCH_TABLE$sun$security$ssl$ClientAuthType:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError
}
SourceFile: "SSLConfiguration.java"
InnerClasses:
  final ClientExtensions = sun.security.ssl.SSLExtension$ClientExtensions of sun.security.ssl.SSLExtension
  final ServerExtensions = sun.security.ssl.SSLExtension$ServerExtensions of sun.security.ssl.SSLExtension