public class org.bouncycastle.crypto.params.ECPublicKeyParameters extends org.bouncycastle.crypto.params.ECKeyParameters
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.crypto.params.ECPublicKeyParameters
  super_class: org.bouncycastle.crypto.params.ECKeyParameters
{
  private final org.bouncycastle.math.ec.ECPoint Q;
    descriptor: Lorg/bouncycastle/math/ec/ECPoint;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(org.bouncycastle.math.ec.ECPoint, org.bouncycastle.crypto.params.ECDomainParameters);
    descriptor: (Lorg/bouncycastle/math/ec/ECPoint;Lorg/bouncycastle/crypto/params/ECDomainParameters;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.bouncycastle.crypto.params.ECPublicKeyParameters this
        start local 1 // org.bouncycastle.math.ec.ECPoint Q
        start local 2 // org.bouncycastle.crypto.params.ECDomainParameters params
         0: .line 14
            aload 0 /* this */
            iconst_0
            aload 2 /* params */
            invokespecial org.bouncycastle.crypto.params.ECKeyParameters.<init>:(ZLorg/bouncycastle/crypto/params/ECDomainParameters;)V
         1: .line 16
            aload 0 /* this */
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 1 /* Q */
            invokestatic org.bouncycastle.crypto.params.ECDomainParameters.validate:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECPoint;)Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.crypto.params.ECPublicKeyParameters.Q:Lorg/bouncycastle/math/ec/ECPoint;
         2: .line 17
            return
        end local 2 // org.bouncycastle.crypto.params.ECDomainParameters params
        end local 1 // org.bouncycastle.math.ec.ECPoint Q
        end local 0 // org.bouncycastle.crypto.params.ECPublicKeyParameters this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;
            0    3     1       Q  Lorg/bouncycastle/math/ec/ECPoint;
            0    3     2  params  Lorg/bouncycastle/crypto/params/ECDomainParameters;
    MethodParameters:
        Name  Flags
      Q       
      params  

  public org.bouncycastle.math.ec.ECPoint getQ();
    descriptor: ()Lorg/bouncycastle/math/ec/ECPoint;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.crypto.params.ECPublicKeyParameters this
         0: .line 21
            aload 0 /* this */
            getfield org.bouncycastle.crypto.params.ECPublicKeyParameters.Q:Lorg/bouncycastle/math/ec/ECPoint;
            areturn
        end local 0 // org.bouncycastle.crypto.params.ECPublicKeyParameters this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;
}
SourceFile: "ECPublicKeyParameters.java"