class sun.security.ssl.NamedGroup$ECDHEScheme implements sun.security.ssl.NamedGroup$NamedGroupScheme
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.ssl.NamedGroup$ECDHEScheme
  super_class: java.lang.Object
{
  private static final sun.security.ssl.NamedGroup$ECDHEScheme instance;
    descriptor: Lsun/security/ssl/NamedGroup$ECDHEScheme;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 599
            new sun.security.ssl.NamedGroup$ECDHEScheme
            dup
            invokespecial sun.security.ssl.NamedGroup$ECDHEScheme.<init>:()V
            putstatic sun.security.ssl.NamedGroup$ECDHEScheme.instance:Lsun/security/ssl/NamedGroup$ECDHEScheme;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
         0: .line 598
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/NamedGroup$ECDHEScheme;

  public byte[] encodePossessionPublicKey(sun.security.ssl.NamedGroupPossession);
    descriptor: (Lsun/security/ssl/NamedGroupPossession;)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
        start local 1 // sun.security.ssl.NamedGroupPossession namedGroupPossession
         0: .line 604
            aload 1 /* namedGroupPossession */
            checkcast sun.security.ssl.ECDHKeyExchange$ECDHEPossession
            invokevirtual sun.security.ssl.ECDHKeyExchange$ECDHEPossession.encode:()[B
            areturn
        end local 1 // sun.security.ssl.NamedGroupPossession namedGroupPossession
        end local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0    1     0                  this  Lsun/security/ssl/NamedGroup$ECDHEScheme;
            0    1     1  namedGroupPossession  Lsun/security/ssl/NamedGroupPossession;
    MethodParameters:
                      Name  Flags
      namedGroupPossession  

  public sun.security.ssl.SSLCredentials decodeCredentials(sun.security.ssl.NamedGroup, byte[], java.security.AlgorithmConstraints, sun.security.ssl.NamedGroup$ExceptionSupplier);
    descriptor: (Lsun/security/ssl/NamedGroup;[BLjava/security/AlgorithmConstraints;Lsun/security/ssl/NamedGroup$ExceptionSupplier;)Lsun/security/ssl/SSLCredentials;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=5
        start local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
        start local 1 // sun.security.ssl.NamedGroup ng
        start local 2 // byte[] encoded
        start local 3 // java.security.AlgorithmConstraints constraints
        start local 4 // sun.security.ssl.NamedGroup$ExceptionSupplier onConstraintFail
         0: .line 614
            aload 1 /* ng */
            aload 2 /* encoded */
            invokestatic sun.security.ssl.ECDHKeyExchange$ECDHECredentials.valueOf:(Lsun/security/ssl/NamedGroup;[B)Lsun/security/ssl/ECDHKeyExchange$ECDHECredentials;
         1: .line 613
            astore 5 /* result */
        start local 5 // sun.security.ssl.ECDHKeyExchange$ECDHECredentials result
         2: .line 616
            aload 0 /* this */
            aload 5 /* result */
            invokevirtual sun.security.ssl.ECDHKeyExchange$ECDHECredentials.getPublicKey:()Ljava/security/PublicKey;
            aload 3 /* constraints */
         3: .line 617
            aload 4 /* onConstraintFail */
         4: .line 616
            invokevirtual sun.security.ssl.NamedGroup$ECDHEScheme.checkConstraints:(Ljava/security/PublicKey;Ljava/security/AlgorithmConstraints;Lsun/security/ssl/NamedGroup$ExceptionSupplier;)V
         5: .line 619
            aload 5 /* result */
            areturn
        end local 5 // sun.security.ssl.ECDHKeyExchange$ECDHECredentials result
        end local 4 // sun.security.ssl.NamedGroup$ExceptionSupplier onConstraintFail
        end local 3 // java.security.AlgorithmConstraints constraints
        end local 2 // byte[] encoded
        end local 1 // sun.security.ssl.NamedGroup ng
        end local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    6     0              this  Lsun/security/ssl/NamedGroup$ECDHEScheme;
            0    6     1                ng  Lsun/security/ssl/NamedGroup;
            0    6     2           encoded  [B
            0    6     3       constraints  Ljava/security/AlgorithmConstraints;
            0    6     4  onConstraintFail  Lsun/security/ssl/NamedGroup$ExceptionSupplier;
            2    6     5            result  Lsun/security/ssl/ECDHKeyExchange$ECDHECredentials;
    Exceptions:
      throws java.io.IOException, java.security.GeneralSecurityException
    MethodParameters:
                  Name  Flags
      ng                
      encoded           
      constraints       
      onConstraintFail  

  public sun.security.ssl.SSLPossession createPossession(sun.security.ssl.NamedGroup, java.security.SecureRandom);
    descriptor: (Lsun/security/ssl/NamedGroup;Ljava/security/SecureRandom;)Lsun/security/ssl/SSLPossession;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
        start local 1 // sun.security.ssl.NamedGroup ng
        start local 2 // java.security.SecureRandom random
         0: .line 625
            new sun.security.ssl.ECDHKeyExchange$ECDHEPossession
            dup
            aload 1 /* ng */
            aload 2 /* random */
            invokespecial sun.security.ssl.ECDHKeyExchange$ECDHEPossession.<init>:(Lsun/security/ssl/NamedGroup;Ljava/security/SecureRandom;)V
            areturn
        end local 2 // java.security.SecureRandom random
        end local 1 // sun.security.ssl.NamedGroup ng
        end local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lsun/security/ssl/NamedGroup$ECDHEScheme;
            0    1     1      ng  Lsun/security/ssl/NamedGroup;
            0    1     2  random  Ljava/security/SecureRandom;
    MethodParameters:
        Name  Flags
      ng      
      random  

  public sun.security.ssl.SSLKeyDerivation createKeyDerivation(sun.security.ssl.HandshakeContext);
    descriptor: (Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SSLKeyDerivation;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
        start local 1 // sun.security.ssl.HandshakeContext hc
         0: .line 631
            getstatic sun.security.ssl.ECDHKeyExchange.ecdheKAGenerator:Lsun/security/ssl/SSLKeyAgreementGenerator;
            aload 1 /* hc */
            invokeinterface sun.security.ssl.SSLKeyAgreementGenerator.createKeyDerivation:(Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SSLKeyDerivation;
            areturn
        end local 1 // sun.security.ssl.HandshakeContext hc
        end local 0 // sun.security.ssl.NamedGroup$ECDHEScheme this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/NamedGroup$ECDHEScheme;
            0    1     1    hc  Lsun/security/ssl/HandshakeContext;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      hc    
}
SourceFile: "NamedGroup.java"
NestHost: sun.security.ssl.NamedGroup
InnerClasses:
  final ECDHECredentials = sun.security.ssl.ECDHKeyExchange$ECDHECredentials of sun.security.ssl.ECDHKeyExchange
  final ECDHEPossession = sun.security.ssl.ECDHKeyExchange$ECDHEPossession of sun.security.ssl.ECDHKeyExchange
  private ECDHEScheme = sun.security.ssl.NamedGroup$ECDHEScheme of sun.security.ssl.NamedGroup
  abstract ExceptionSupplier = sun.security.ssl.NamedGroup$ExceptionSupplier of sun.security.ssl.NamedGroup
  private abstract NamedGroupScheme = sun.security.ssl.NamedGroup$NamedGroupScheme of sun.security.ssl.NamedGroup