final class sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage extends sun.security.ssl.SSLHandshake$HandshakeMessage
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage
  super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
  private final sun.security.ssl.SSLExtensions extensions;
    descriptor: Lsun/security/ssl/SSLExtensions;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(sun.security.ssl.HandshakeContext);
    descriptor: (Lsun/security/ssl/HandshakeContext;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
         0: .line 51
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 52
            aload 0 /* this */
            new sun.security.ssl.SSLExtensions
            dup
            aload 0 /* this */
            invokespecial sun.security.ssl.SSLExtensions.<init>:(Lsun/security/ssl/SSLHandshake$HandshakeMessage;)V
            putfield sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage.extensions:Lsun/security/ssl/SSLExtensions;
         2: .line 53
            return
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    3     0              this  Lsun/security/ssl/EncryptedExtensions$EncryptedExtensionsMessage;
            0    3     1  handshakeContext  Lsun/security/ssl/HandshakeContext;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                  Name  Flags
      handshakeContext  

  void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
    descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=4, args_size=3
        start local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
        start local 1 // sun.security.ssl.HandshakeContext handshakeContext
        start local 2 // java.nio.ByteBuffer m
         0: .line 57
            aload 0 /* this */
            aload 1 /* handshakeContext */
            invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
         1: .line 62
            aload 2 /* m */
            invokevirtual java.nio.ByteBuffer.remaining:()I
            iconst_2
            if_icmpge 5
         2: .line 63
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getstatic sun.security.ssl.Alert.ILLEGAL_PARAMETER:Lsun/security/ssl/Alert;
         3: .line 64
            ldc "Invalid EncryptedExtensions handshake message: no sufficient data"
         4: .line 63
            invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
            athrow
         5: .line 69
      StackMap locals: sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer
      StackMap stack:
            aload 1 /* handshakeContext */
            getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
         6: .line 70
            getstatic sun.security.ssl.SSLHandshake.ENCRYPTED_EXTENSIONS:Lsun/security/ssl/SSLHandshake;
         7: .line 69
            invokevirtual sun.security.ssl.SSLConfiguration.getEnabledExtensions:(Lsun/security/ssl/SSLHandshake;)[Lsun/security/ssl/SSLExtension;
         8: .line 68
            astore 3 /* encryptedExtensions */
        start local 3 // sun.security.ssl.SSLExtension[] encryptedExtensions
         9: .line 71
            aload 0 /* this */
            new sun.security.ssl.SSLExtensions
            dup
            aload 0 /* this */
            aload 2 /* m */
            aload 3 /* encryptedExtensions */
            invokespecial sun.security.ssl.SSLExtensions.<init>:(Lsun/security/ssl/SSLHandshake$HandshakeMessage;Ljava/nio/ByteBuffer;[Lsun/security/ssl/SSLExtension;)V
            putfield sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage.extensions:Lsun/security/ssl/SSLExtensions;
        10: .line 72
            return
        end local 3 // sun.security.ssl.SSLExtension[] encryptedExtensions
        end local 2 // java.nio.ByteBuffer m
        end local 1 // sun.security.ssl.HandshakeContext handshakeContext
        end local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   11     0                 this  Lsun/security/ssl/EncryptedExtensions$EncryptedExtensionsMessage;
            0   11     1     handshakeContext  Lsun/security/ssl/HandshakeContext;
            0   11     2                    m  Ljava/nio/ByteBuffer;
            9   11     3  encryptedExtensions  [Lsun/security/ssl/SSLExtension;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                  Name  Flags
      handshakeContext  
      m                 

  sun.security.ssl.SSLHandshake handshakeType();
    descriptor: ()Lsun/security/ssl/SSLHandshake;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
         0: .line 76
            getstatic sun.security.ssl.SSLHandshake.ENCRYPTED_EXTENSIONS:Lsun/security/ssl/SSLHandshake;
            areturn
        end local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/EncryptedExtensions$EncryptedExtensionsMessage;

  int messageLength();
    descriptor: ()I
    flags: (0x0000) 
    Code:
      stack=1, locals=2, args_size=1
        start local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
         0: .line 81
            aload 0 /* this */
            getfield sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.length:()I
            istore 1 /* extLen */
        start local 1 // int extLen
         1: .line 82
            iload 1 /* extLen */
            ifne 3
         2: .line 83
            iconst_2
            istore 1 /* extLen */
         3: .line 85
      StackMap locals: int
      StackMap stack:
            iload 1 /* extLen */
            ireturn
        end local 1 // int extLen
        end local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lsun/security/ssl/EncryptedExtensions$EncryptedExtensionsMessage;
            1    4     1  extLen  I

  void send(sun.security.ssl.HandshakeOutStream);
    descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
        start local 1 // sun.security.ssl.HandshakeOutStream hos
         0: .line 91
            aload 0 /* this */
            getfield sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.length:()I
            ifne 3
         1: .line 92
            aload 1 /* hos */
            iconst_0
            invokevirtual sun.security.ssl.HandshakeOutStream.putInt16:(I)V
         2: .line 93
            goto 4
         3: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage.extensions:Lsun/security/ssl/SSLExtensions;
            aload 1 /* hos */
            invokevirtual sun.security.ssl.SSLExtensions.send:(Lsun/security/ssl/HandshakeOutStream;)V
         4: .line 96
      StackMap locals:
      StackMap stack:
            return
        end local 1 // sun.security.ssl.HandshakeOutStream hos
        end local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/ssl/EncryptedExtensions$EncryptedExtensionsMessage;
            0    5     1   hos  Lsun/security/ssl/HandshakeOutStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      hos   

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
         0: .line 100
            new java.text.MessageFormat
            dup
         1: .line 101
            ldc "\"EncryptedExtensions\": [\n{0}\n]"
         2: .line 104
            getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
         3: .line 100
            invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
            astore 1 /* messageFormat */
        start local 1 // java.text.MessageFormat messageFormat
         4: .line 105
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
         5: .line 106
            aload 0 /* this */
            getfield sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage.extensions:Lsun/security/ssl/SSLExtensions;
            invokevirtual sun.security.ssl.SSLExtensions.toString:()Ljava/lang/String;
            invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;)Ljava/lang/String;
            aastore
         6: .line 105
            astore 2 /* messageFields */
        start local 2 // java.lang.Object[] messageFields
         7: .line 109
            aload 1 /* messageFormat */
            aload 2 /* messageFields */
            invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 2 // java.lang.Object[] messageFields
        end local 1 // java.text.MessageFormat messageFormat
        end local 0 // sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    8     0           this  Lsun/security/ssl/EncryptedExtensions$EncryptedExtensionsMessage;
            4    8     1  messageFormat  Ljava/text/MessageFormat;
            7    8     2  messageFields  [Ljava/lang/Object;
}
SourceFile: "EncryptedExtensions.java"
NestHost: sun.security.ssl.EncryptedExtensions
InnerClasses:
  final EncryptedExtensionsMessage = sun.security.ssl.EncryptedExtensions$EncryptedExtensionsMessage of sun.security.ssl.EncryptedExtensions
  abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake