public class org.bouncycastle.jce.provider.JCEECPublicKey implements java.security.interfaces.ECPublicKey, org.bouncycastle.jce.interfaces.ECPublicKey, org.bouncycastle.jce.interfaces.ECPointEncoder
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.jce.provider.JCEECPublicKey
  super_class: java.lang.Object
{
  private java.lang.String algorithm;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private org.bouncycastle.math.ec.ECPoint q;
    descriptor: Lorg/bouncycastle/math/ec/ECPoint;
    flags: (0x0002) ACC_PRIVATE

  private java.security.spec.ECParameterSpec ecSpec;
    descriptor: Ljava/security/spec/ECParameterSpec;
    flags: (0x0002) ACC_PRIVATE

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

  private org.bouncycastle.asn1.cryptopro.GOST3410PublicKeyAlgParameters gostParams;
    descriptor: Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
    flags: (0x0002) ACC_PRIVATE

  public void <init>(java.lang.String, org.bouncycastle.jce.provider.JCEECPublicKey);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/jce/provider/JCEECPublicKey;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.jce.provider.JCEECPublicKey key
         0: .line 51
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 55
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         3: .line 56
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
         4: .line 57
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         5: .line 58
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
         6: .line 59
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.gostParams:Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.gostParams:Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
         7: .line 60
            return
        end local 2 // org.bouncycastle.jce.provider.JCEECPublicKey key
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    8     0       this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    8     1  algorithm  Ljava/lang/String;
            0    8     2        key  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
    MethodParameters:
           Name  Flags
      algorithm  
      key        

  public void <init>(java.lang.String, java.security.spec.ECPublicKeySpec);
    descriptor: (Ljava/lang/String;Ljava/security/spec/ECPublicKeySpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.String algorithm
        start local 2 // java.security.spec.ECPublicKeySpec spec
         0: .line 62
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 66
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         3: .line 67
            aload 0 /* this */
            aload 2 /* spec */
            invokevirtual java.security.spec.ECPublicKeySpec.getParams:()Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         4: .line 68
            aload 0 /* this */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            aload 2 /* spec */
            invokevirtual java.security.spec.ECPublicKeySpec.getW:()Ljava/security/spec/ECPoint;
            iconst_0
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertPoint:(Ljava/security/spec/ECParameterSpec;Ljava/security/spec/ECPoint;Z)Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
         5: .line 69
            return
        end local 2 // java.security.spec.ECPublicKeySpec spec
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    6     1  algorithm  Ljava/lang/String;
            0    6     2       spec  Ljava/security/spec/ECPublicKeySpec;
    MethodParameters:
           Name  Flags
      algorithm  
      spec       

  public void <init>(java.lang.String, org.bouncycastle.jce.spec.ECPublicKeySpec);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/jce/spec/ECPublicKeySpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.jce.spec.ECPublicKeySpec spec
         0: .line 71
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 75
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         3: .line 76
            aload 0 /* this */
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPublicKeySpec.getQ:()Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
         4: .line 78
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPublicKeySpec.getParams:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            ifnull 9
         5: .line 80
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPublicKeySpec.getParams:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            astore 3 /* curve */
        start local 3 // org.bouncycastle.math.ec.ECCurve curve
         6: .line 81
            aload 3 /* curve */
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPublicKeySpec.getParams:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getSeed:()[B
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Lorg/bouncycastle/math/ec/ECCurve;[B)Ljava/security/spec/EllipticCurve;
            astore 4 /* ellipticCurve */
        start local 4 // java.security.spec.EllipticCurve ellipticCurve
         7: .line 83
            aload 0 /* this */
            aload 4 /* ellipticCurve */
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPublicKeySpec.getParams:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertSpec:(Ljava/security/spec/EllipticCurve;Lorg/bouncycastle/jce/spec/ECParameterSpec;)Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 4 // java.security.spec.EllipticCurve ellipticCurve
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
         8: .line 84
            goto 13
         9: .line 87
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey java.lang.String org.bouncycastle.jce.spec.ECPublicKeySpec
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            ifnonnull 12
        10: .line 89
            invokestatic org.bouncycastle.jce.provider.ProviderUtil.getEcImplicitlyCa:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            astore 3 /* s */
        start local 3 // org.bouncycastle.jce.spec.ECParameterSpec s
        11: .line 91
            aload 0 /* this */
            aload 3 /* s */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            iconst_0
            invokevirtual org.bouncycastle.math.ec.ECCurve.createPoint:(Ljava/math/BigInteger;Ljava/math/BigInteger;Z)Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
        end local 3 // org.bouncycastle.jce.spec.ECParameterSpec s
        12: .line 93
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        13: .line 95
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.bouncycastle.jce.spec.ECPublicKeySpec spec
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   14     0           this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0   14     1      algorithm  Ljava/lang/String;
            0   14     2           spec  Lorg/bouncycastle/jce/spec/ECPublicKeySpec;
            6    8     3          curve  Lorg/bouncycastle/math/ec/ECCurve;
            7    8     4  ellipticCurve  Ljava/security/spec/EllipticCurve;
           11   12     3              s  Lorg/bouncycastle/jce/spec/ECParameterSpec;
    MethodParameters:
           Name  Flags
      algorithm  
      spec       

  public void <init>(java.lang.String, org.bouncycastle.crypto.params.ECPublicKeyParameters, java.security.spec.ECParameterSpec);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;Ljava/security/spec/ECParameterSpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.crypto.params.ECPublicKeyParameters params
        start local 3 // java.security.spec.ECParameterSpec spec
         0: .line 97
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 102
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPublicKeyParameters.getParameters:()Lorg/bouncycastle/crypto/params/ECDomainParameters;
            astore 4 /* dp */
        start local 4 // org.bouncycastle.crypto.params.ECDomainParameters dp
         3: .line 104
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         4: .line 105
            aload 0 /* this */
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPublicKeyParameters.getQ:()Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
         5: .line 107
            aload 3 /* spec */
            ifnonnull 9
         6: .line 109
            aload 4 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 4 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getSeed:()[B
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Lorg/bouncycastle/math/ec/ECCurve;[B)Ljava/security/spec/EllipticCurve;
            astore 5 /* ellipticCurve */
        start local 5 // java.security.spec.EllipticCurve ellipticCurve
         7: .line 111
            aload 0 /* this */
            aload 0 /* this */
            aload 5 /* ellipticCurve */
            aload 4 /* dp */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.createSpec:(Ljava/security/spec/EllipticCurve;Lorg/bouncycastle/crypto/params/ECDomainParameters;)Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 5 // java.security.spec.EllipticCurve ellipticCurve
         8: .line 112
            goto 10
         9: .line 115
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey java.lang.String org.bouncycastle.crypto.params.ECPublicKeyParameters java.security.spec.ECParameterSpec org.bouncycastle.crypto.params.ECDomainParameters
      StackMap stack:
            aload 0 /* this */
            aload 3 /* spec */
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        10: .line 117
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.bouncycastle.crypto.params.ECDomainParameters dp
        end local 3 // java.security.spec.ECParameterSpec spec
        end local 2 // org.bouncycastle.crypto.params.ECPublicKeyParameters params
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   11     0           this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0   11     1      algorithm  Ljava/lang/String;
            0   11     2         params  Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;
            0   11     3           spec  Ljava/security/spec/ECParameterSpec;
            3   11     4             dp  Lorg/bouncycastle/crypto/params/ECDomainParameters;
            7    8     5  ellipticCurve  Ljava/security/spec/EllipticCurve;
    MethodParameters:
           Name  Flags
      algorithm  
      params     
      spec       

  public void <init>(java.lang.String, org.bouncycastle.crypto.params.ECPublicKeyParameters, org.bouncycastle.jce.spec.ECParameterSpec);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;Lorg/bouncycastle/jce/spec/ECParameterSpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=6, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.crypto.params.ECPublicKeyParameters params
        start local 3 // org.bouncycastle.jce.spec.ECParameterSpec spec
         0: .line 119
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 124
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPublicKeyParameters.getParameters:()Lorg/bouncycastle/crypto/params/ECDomainParameters;
            astore 4 /* dp */
        start local 4 // org.bouncycastle.crypto.params.ECDomainParameters dp
         3: .line 126
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         4: .line 127
            aload 0 /* this */
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPublicKeyParameters.getQ:()Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
         5: .line 129
            aload 3 /* spec */
            ifnonnull 9
         6: .line 131
            aload 4 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 4 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getSeed:()[B
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Lorg/bouncycastle/math/ec/ECCurve;[B)Ljava/security/spec/EllipticCurve;
            astore 5 /* ellipticCurve */
        start local 5 // java.security.spec.EllipticCurve ellipticCurve
         7: .line 133
            aload 0 /* this */
            aload 0 /* this */
            aload 5 /* ellipticCurve */
            aload 4 /* dp */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.createSpec:(Ljava/security/spec/EllipticCurve;Lorg/bouncycastle/crypto/params/ECDomainParameters;)Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 5 // java.security.spec.EllipticCurve ellipticCurve
         8: .line 134
            goto 11
         9: .line 137
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey java.lang.String org.bouncycastle.crypto.params.ECPublicKeyParameters org.bouncycastle.jce.spec.ECParameterSpec org.bouncycastle.crypto.params.ECDomainParameters
      StackMap stack:
            aload 3 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 3 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getSeed:()[B
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Lorg/bouncycastle/math/ec/ECCurve;[B)Ljava/security/spec/EllipticCurve;
            astore 5 /* ellipticCurve */
        start local 5 // java.security.spec.EllipticCurve ellipticCurve
        10: .line 139
            aload 0 /* this */
            aload 5 /* ellipticCurve */
            aload 3 /* spec */
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertSpec:(Ljava/security/spec/EllipticCurve;Lorg/bouncycastle/jce/spec/ECParameterSpec;)Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 5 // java.security.spec.EllipticCurve ellipticCurve
        11: .line 141
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.bouncycastle.crypto.params.ECDomainParameters dp
        end local 3 // org.bouncycastle.jce.spec.ECParameterSpec spec
        end local 2 // org.bouncycastle.crypto.params.ECPublicKeyParameters params
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0   12     1      algorithm  Ljava/lang/String;
            0   12     2         params  Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;
            0   12     3           spec  Lorg/bouncycastle/jce/spec/ECParameterSpec;
            3   12     4             dp  Lorg/bouncycastle/crypto/params/ECDomainParameters;
            7    8     5  ellipticCurve  Ljava/security/spec/EllipticCurve;
           10   11     5  ellipticCurve  Ljava/security/spec/EllipticCurve;
    MethodParameters:
           Name  Flags
      algorithm  
      params     
      spec       

  public void <init>(java.lang.String, org.bouncycastle.crypto.params.ECPublicKeyParameters);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.crypto.params.ECPublicKeyParameters params
         0: .line 146
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 150
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         3: .line 151
            aload 0 /* this */
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPublicKeyParameters.getQ:()Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
         4: .line 152
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         5: .line 153
            return
        end local 2 // org.bouncycastle.crypto.params.ECPublicKeyParameters params
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    6     1  algorithm  Ljava/lang/String;
            0    6     2     params  Lorg/bouncycastle/crypto/params/ECPublicKeyParameters;
    MethodParameters:
           Name  Flags
      algorithm  
      params     

  private java.security.spec.ECParameterSpec createSpec(java.security.spec.EllipticCurve, org.bouncycastle.crypto.params.ECDomainParameters);
    descriptor: (Ljava/security/spec/EllipticCurve;Lorg/bouncycastle/crypto/params/ECDomainParameters;)Ljava/security/spec/ECParameterSpec;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.security.spec.EllipticCurve ellipticCurve
        start local 2 // org.bouncycastle.crypto.params.ECDomainParameters dp
         0: .line 157
            new java.security.spec.ECParameterSpec
            dup
         1: .line 158
            aload 1 /* ellipticCurve */
         2: .line 159
            new java.security.spec.ECPoint
            dup
         3: .line 160
            aload 2 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
         4: .line 161
            aload 2 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
         5: .line 159
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
         6: .line 162
            aload 2 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getN:()Ljava/math/BigInteger;
         7: .line 163
            aload 2 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getH:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.intValue:()I
         8: .line 157
            invokespecial java.security.spec.ECParameterSpec.<init>:(Ljava/security/spec/EllipticCurve;Ljava/security/spec/ECPoint;Ljava/math/BigInteger;I)V
            areturn
        end local 2 // org.bouncycastle.crypto.params.ECDomainParameters dp
        end local 1 // java.security.spec.EllipticCurve ellipticCurve
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    9     1  ellipticCurve  Ljava/security/spec/EllipticCurve;
            0    9     2             dp  Lorg/bouncycastle/crypto/params/ECDomainParameters;
    MethodParameters:
               Name  Flags
      ellipticCurve  
      dp             

  public void <init>(java.security.interfaces.ECPublicKey);
    descriptor: (Ljava/security/interfaces/ECPublicKey;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.security.interfaces.ECPublicKey key
         0: .line 166
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 169
            aload 0 /* this */
            aload 1 /* key */
            invokeinterface java.security.interfaces.ECPublicKey.getAlgorithm:()Ljava/lang/String;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         3: .line 170
            aload 0 /* this */
            aload 1 /* key */
            invokeinterface java.security.interfaces.ECPublicKey.getParams:()Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         4: .line 171
            aload 0 /* this */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            aload 1 /* key */
            invokeinterface java.security.interfaces.ECPublicKey.getW:()Ljava/security/spec/ECPoint;
            iconst_0
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertPoint:(Ljava/security/spec/ECParameterSpec;Ljava/security/spec/ECPoint;Z)Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
         5: .line 172
            return
        end local 1 // java.security.interfaces.ECPublicKey key
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    6     1   key  Ljava/security/interfaces/ECPublicKey;
    MethodParameters:
      Name  Flags
      key   

  void <init>(org.bouncycastle.asn1.x509.SubjectPublicKeyInfo);
    descriptor: (Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
         0: .line 174
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 45
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         2: .line 177
            aload 0 /* this */
            aload 1 /* info */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.populateFromPubKeyInfo:(Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;)V
         3: .line 178
            return
        end local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    4     1  info  Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
    MethodParameters:
      Name  Flags
      info  

  private void populateFromPubKeyInfo(org.bouncycastle.asn1.x509.SubjectPublicKeyInfo);
    descriptor: (Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=10, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
         0: .line 182
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getAlgorithmId:()Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getObjectId:()Lorg/bouncycastle/asn1/DERObjectIdentifier;
            getstatic org.bouncycastle.asn1.cryptopro.CryptoProObjectIdentifiers.gostR3410_2001:Lorg/bouncycastle/asn1/DERObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.DERObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 35
         1: .line 184
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getPublicKeyData:()Lorg/bouncycastle/asn1/DERBitString;
            astore 2 /* bits */
        start local 2 // org.bouncycastle.asn1.DERBitString bits
         2: .line 186
            aload 0 /* this */
            ldc "ECGOST3410"
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         3: .line 190
            aload 2 /* bits */
            invokevirtual org.bouncycastle.asn1.DERBitString.getBytes:()[B
            invokestatic org.bouncycastle.asn1.ASN1Object.fromByteArray:([B)Lorg/bouncycastle/asn1/ASN1Object;
            checkcast org.bouncycastle.asn1.ASN1OctetString
            astore 3 /* key */
        start local 3 // org.bouncycastle.asn1.ASN1OctetString key
         4: .line 191
            goto 7
        end local 3 // org.bouncycastle.asn1.ASN1OctetString key
         5: .line 192
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey org.bouncycastle.asn1.x509.SubjectPublicKeyInfo org.bouncycastle.asn1.DERBitString
      StackMap stack: java.io.IOException
            pop
         6: .line 194
            new java.lang.IllegalArgumentException
            dup
            ldc "error recovering public key"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        start local 3 // org.bouncycastle.asn1.ASN1OctetString key
         7: .line 197
      StackMap locals: org.bouncycastle.asn1.ASN1OctetString
      StackMap stack:
            aload 3 /* key */
            invokevirtual org.bouncycastle.asn1.ASN1OctetString.getOctets:()[B
            astore 4 /* keyEnc */
        start local 4 // byte[] keyEnc
         8: .line 198
            bipush 32
            newarray 8
            astore 5 /* x */
        start local 5 // byte[] x
         9: .line 199
            bipush 32
            newarray 8
            astore 6 /* y */
        start local 6 // byte[] y
        10: .line 201
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        11: goto 14
        12: .line 203
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey org.bouncycastle.asn1.x509.SubjectPublicKeyInfo org.bouncycastle.asn1.DERBitString org.bouncycastle.asn1.ASN1OctetString byte[] byte[] byte[] int
      StackMap stack:
            aload 5 /* x */
            iload 7 /* i */
            aload 4 /* keyEnc */
            bipush 31
            iload 7 /* i */
            isub
            baload
            bastore
        13: .line 201
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        14: iload 7 /* i */
            aload 5 /* x */
            arraylength
            if_icmpne 12
        end local 7 // int i
        15: .line 206
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        16: goto 19
        17: .line 208
      StackMap locals:
      StackMap stack:
            aload 6 /* y */
            iload 7 /* i */
            aload 4 /* keyEnc */
            bipush 63
            iload 7 /* i */
            isub
            baload
            bastore
        18: .line 206
            iinc 7 /* i */ 1
      StackMap locals:
      StackMap stack:
        19: iload 7 /* i */
            aload 6 /* y */
            arraylength
            if_icmpne 17
        end local 7 // int i
        20: .line 211
            aload 0 /* this */
            new org.bouncycastle.asn1.cryptopro.GOST3410PublicKeyAlgParameters
            dup
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getAlgorithmId:()Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getParameters:()Lorg/bouncycastle/asn1/DEREncodable;
            checkcast org.bouncycastle.asn1.ASN1Sequence
            invokespecial org.bouncycastle.asn1.cryptopro.GOST3410PublicKeyAlgParameters.<init>:(Lorg/bouncycastle/asn1/ASN1Sequence;)V
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.gostParams:Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
        21: .line 213
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.gostParams:Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
            invokevirtual org.bouncycastle.asn1.cryptopro.GOST3410PublicKeyAlgParameters.getPublicKeyParamSet:()Lorg/bouncycastle/asn1/DERObjectIdentifier;
            invokestatic org.bouncycastle.asn1.cryptopro.ECGOST3410NamedCurves.getName:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Ljava/lang/String;
            invokestatic org.bouncycastle.jce.ECGOST3410NamedCurveTable.getParameterSpec:(Ljava/lang/String;)Lorg/bouncycastle/jce/spec/ECNamedCurveParameterSpec;
            astore 7 /* spec */
        start local 7 // org.bouncycastle.jce.spec.ECNamedCurveParameterSpec spec
        22: .line 215
            aload 7 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveParameterSpec.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            astore 8 /* curve */
        start local 8 // org.bouncycastle.math.ec.ECCurve curve
        23: .line 216
            aload 8 /* curve */
            aload 7 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveParameterSpec.getSeed:()[B
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Lorg/bouncycastle/math/ec/ECCurve;[B)Ljava/security/spec/EllipticCurve;
            astore 9 /* ellipticCurve */
        start local 9 // java.security.spec.EllipticCurve ellipticCurve
        24: .line 218
            aload 0 /* this */
            aload 8 /* curve */
            new java.math.BigInteger
            dup
            iconst_1
            aload 5 /* x */
            invokespecial java.math.BigInteger.<init>:(I[B)V
            new java.math.BigInteger
            dup
            iconst_1
            aload 6 /* y */
            invokespecial java.math.BigInteger.<init>:(I[B)V
            iconst_0
            invokevirtual org.bouncycastle.math.ec.ECCurve.createPoint:(Ljava/math/BigInteger;Ljava/math/BigInteger;Z)Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
        25: .line 220
            aload 0 /* this */
            new org.bouncycastle.jce.spec.ECNamedCurveSpec
            dup
        26: .line 221
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.gostParams:Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
            invokevirtual org.bouncycastle.asn1.cryptopro.GOST3410PublicKeyAlgParameters.getPublicKeyParamSet:()Lorg/bouncycastle/asn1/DERObjectIdentifier;
            invokestatic org.bouncycastle.asn1.cryptopro.ECGOST3410NamedCurves.getName:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Ljava/lang/String;
        27: .line 222
            aload 9 /* ellipticCurve */
        28: .line 223
            new java.security.spec.ECPoint
            dup
        29: .line 224
            aload 7 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveParameterSpec.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
        30: .line 225
            aload 7 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveParameterSpec.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
        31: .line 223
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        32: .line 226
            aload 7 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveParameterSpec.getN:()Ljava/math/BigInteger;
            aload 7 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveParameterSpec.getH:()Ljava/math/BigInteger;
            invokespecial org.bouncycastle.jce.spec.ECNamedCurveSpec.<init>:(Ljava/lang/String;Ljava/security/spec/EllipticCurve;Ljava/security/spec/ECPoint;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        33: .line 220
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 9 // java.security.spec.EllipticCurve ellipticCurve
        end local 8 // org.bouncycastle.math.ec.ECCurve curve
        end local 7 // org.bouncycastle.jce.spec.ECNamedCurveParameterSpec spec
        end local 6 // byte[] y
        end local 5 // byte[] x
        end local 4 // byte[] keyEnc
        end local 3 // org.bouncycastle.asn1.ASN1OctetString key
        end local 2 // org.bouncycastle.asn1.DERBitString bits
        34: .line 228
            goto 81
        35: .line 231
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey org.bouncycastle.asn1.x509.SubjectPublicKeyInfo
      StackMap stack:
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getAlgorithmId:()Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
            invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getParameters:()Lorg/bouncycastle/asn1/DEREncodable;
            checkcast org.bouncycastle.asn1.DERObject
            invokespecial org.bouncycastle.asn1.x9.X962Parameters.<init>:(Lorg/bouncycastle/asn1/DERObject;)V
            astore 2 /* params */
        start local 2 // org.bouncycastle.asn1.x9.X962Parameters params
        36: .line 235
            aload 2 /* params */
            invokevirtual org.bouncycastle.asn1.x9.X962Parameters.isNamedCurve:()Z
            ifeq 52
        37: .line 237
            aload 2 /* params */
            invokevirtual org.bouncycastle.asn1.x9.X962Parameters.getParameters:()Lorg/bouncycastle/asn1/DERObject;
            checkcast org.bouncycastle.asn1.DERObjectIdentifier
            astore 5 /* oid */
        start local 5 // org.bouncycastle.asn1.DERObjectIdentifier oid
        38: .line 238
            aload 5 /* oid */
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.ECUtil.getNamedCurveByOid:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Lorg/bouncycastle/asn1/x9/X9ECParameters;
            astore 6 /* ecP */
        start local 6 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        39: .line 240
            aload 6 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            astore 3 /* curve */
        start local 3 // org.bouncycastle.math.ec.ECCurve curve
        40: .line 241
            aload 3 /* curve */
            aload 6 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getSeed:()[B
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Lorg/bouncycastle/math/ec/ECCurve;[B)Ljava/security/spec/EllipticCurve;
            astore 4 /* ellipticCurve */
        start local 4 // java.security.spec.EllipticCurve ellipticCurve
        41: .line 243
            aload 0 /* this */
            new org.bouncycastle.jce.spec.ECNamedCurveSpec
            dup
        42: .line 244
            aload 5 /* oid */
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.ECUtil.getCurveName:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Ljava/lang/String;
        43: .line 245
            aload 4 /* ellipticCurve */
        44: .line 246
            new java.security.spec.ECPoint
            dup
        45: .line 247
            aload 6 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
        46: .line 248
            aload 6 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
        47: .line 246
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        48: .line 249
            aload 6 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getN:()Ljava/math/BigInteger;
        49: .line 250
            aload 6 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getH:()Ljava/math/BigInteger;
            invokespecial org.bouncycastle.jce.spec.ECNamedCurveSpec.<init>:(Ljava/lang/String;Ljava/security/spec/EllipticCurve;Ljava/security/spec/ECPoint;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        50: .line 243
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 6 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        end local 5 // org.bouncycastle.asn1.DERObjectIdentifier oid
        51: .line 251
            goto 68
        end local 4 // java.security.spec.EllipticCurve ellipticCurve
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
        52: .line 252
      StackMap locals: org.bouncycastle.asn1.x9.X962Parameters
      StackMap stack:
            aload 2 /* params */
            invokevirtual org.bouncycastle.asn1.x9.X962Parameters.isImplicitlyCA:()Z
            ifeq 56
        53: .line 254
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        54: .line 255
            invokestatic org.bouncycastle.jce.provider.ProviderUtil.getEcImplicitlyCa:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            astore 3 /* curve */
        start local 3 // org.bouncycastle.math.ec.ECCurve curve
        55: .line 256
            goto 68
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
        56: .line 259
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.x9.X9ECParameters
            dup
            aload 2 /* params */
            invokevirtual org.bouncycastle.asn1.x9.X962Parameters.getParameters:()Lorg/bouncycastle/asn1/DERObject;
            checkcast org.bouncycastle.asn1.ASN1Sequence
            invokespecial org.bouncycastle.asn1.x9.X9ECParameters.<init>:(Lorg/bouncycastle/asn1/ASN1Sequence;)V
            astore 5 /* ecP */
        start local 5 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        57: .line 261
            aload 5 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            astore 3 /* curve */
        start local 3 // org.bouncycastle.math.ec.ECCurve curve
        58: .line 262
            aload 3 /* curve */
            aload 5 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getSeed:()[B
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Lorg/bouncycastle/math/ec/ECCurve;[B)Ljava/security/spec/EllipticCurve;
            astore 4 /* ellipticCurve */
        start local 4 // java.security.spec.EllipticCurve ellipticCurve
        59: .line 264
            aload 0 /* this */
            new java.security.spec.ECParameterSpec
            dup
        60: .line 265
            aload 4 /* ellipticCurve */
        61: .line 266
            new java.security.spec.ECPoint
            dup
        62: .line 267
            aload 5 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
        63: .line 268
            aload 5 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getG:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
        64: .line 266
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        65: .line 269
            aload 5 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getN:()Ljava/math/BigInteger;
        66: .line 270
            aload 5 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getH:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.intValue:()I
            invokespecial java.security.spec.ECParameterSpec.<init>:(Ljava/security/spec/EllipticCurve;Ljava/security/spec/ECPoint;Ljava/math/BigInteger;I)V
        67: .line 264
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 5 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        end local 4 // java.security.spec.EllipticCurve ellipticCurve
        68: .line 273
      StackMap locals: org.bouncycastle.math.ec.ECCurve
      StackMap stack:
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getPublicKeyData:()Lorg/bouncycastle/asn1/DERBitString;
            astore 5 /* bits */
        start local 5 // org.bouncycastle.asn1.DERBitString bits
        69: .line 274
            aload 5 /* bits */
            invokevirtual org.bouncycastle.asn1.DERBitString.getBytes:()[B
            astore 6 /* data */
        start local 6 // byte[] data
        70: .line 275
            new org.bouncycastle.asn1.DEROctetString
            dup
            aload 6 /* data */
            invokespecial org.bouncycastle.asn1.DEROctetString.<init>:([B)V
            astore 7 /* key */
        start local 7 // org.bouncycastle.asn1.ASN1OctetString key
        71: .line 280
            aload 6 /* data */
            iconst_0
            baload
            iconst_4
            if_icmpne 79
            aload 6 /* data */
            iconst_1
            baload
            aload 6 /* data */
            arraylength
            iconst_2
            isub
            if_icmpne 79
        72: .line 281
            aload 6 /* data */
            iconst_2
            baload
            iconst_2
            if_icmpeq 73
            aload 6 /* data */
            iconst_2
            baload
            iconst_3
            if_icmpne 79
        73: .line 283
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey org.bouncycastle.asn1.x509.SubjectPublicKeyInfo org.bouncycastle.asn1.x9.X962Parameters org.bouncycastle.math.ec.ECCurve top org.bouncycastle.asn1.DERBitString byte[] org.bouncycastle.asn1.ASN1OctetString
      StackMap stack:
            new org.bouncycastle.asn1.x9.X9IntegerConverter
            dup
            invokespecial org.bouncycastle.asn1.x9.X9IntegerConverter.<init>:()V
            aload 3 /* curve */
            invokevirtual org.bouncycastle.asn1.x9.X9IntegerConverter.getByteLength:(Lorg/bouncycastle/math/ec/ECCurve;)I
            istore 8 /* qLength */
        start local 8 // int qLength
        74: .line 285
            iload 8 /* qLength */
            aload 6 /* data */
            arraylength
            iconst_3
            isub
            if_icmplt 79
        75: .line 289
            aload 6 /* data */
            invokestatic org.bouncycastle.asn1.ASN1Object.fromByteArray:([B)Lorg/bouncycastle/asn1/ASN1Object;
            checkcast org.bouncycastle.asn1.ASN1OctetString
            astore 7 /* key */
        76: .line 290
            goto 79
        77: .line 291
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey org.bouncycastle.asn1.x509.SubjectPublicKeyInfo org.bouncycastle.asn1.x9.X962Parameters org.bouncycastle.math.ec.ECCurve top org.bouncycastle.asn1.DERBitString byte[] org.bouncycastle.asn1.ASN1OctetString int
      StackMap stack: java.io.IOException
            pop
        78: .line 293
            new java.lang.IllegalArgumentException
            dup
            ldc "error recovering public key"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        end local 8 // int qLength
        79: .line 297
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.x9.X9ECPoint
            dup
            aload 3 /* curve */
            aload 7 /* key */
            invokespecial org.bouncycastle.asn1.x9.X9ECPoint.<init>:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/asn1/ASN1OctetString;)V
            astore 8 /* derQ */
        start local 8 // org.bouncycastle.asn1.x9.X9ECPoint derQ
        80: .line 299
            aload 0 /* this */
            aload 8 /* derQ */
            invokevirtual org.bouncycastle.asn1.x9.X9ECPoint.getPoint:()Lorg/bouncycastle/math/ec/ECPoint;
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
        end local 8 // org.bouncycastle.asn1.x9.X9ECPoint derQ
        end local 7 // org.bouncycastle.asn1.ASN1OctetString key
        end local 6 // byte[] data
        end local 5 // org.bouncycastle.asn1.DERBitString bits
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
        end local 2 // org.bouncycastle.asn1.x9.X962Parameters params
        81: .line 301
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey org.bouncycastle.asn1.x509.SubjectPublicKeyInfo
      StackMap stack:
            return
        end local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   82     0           this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0   82     1           info  Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
            2   34     2           bits  Lorg/bouncycastle/asn1/DERBitString;
            4    5     3            key  Lorg/bouncycastle/asn1/ASN1OctetString;
            7   34     3            key  Lorg/bouncycastle/asn1/ASN1OctetString;
            8   34     4         keyEnc  [B
            9   34     5              x  [B
           10   34     6              y  [B
           11   15     7              i  I
           16   20     7              i  I
           22   34     7           spec  Lorg/bouncycastle/jce/spec/ECNamedCurveParameterSpec;
           23   34     8          curve  Lorg/bouncycastle/math/ec/ECCurve;
           24   34     9  ellipticCurve  Ljava/security/spec/EllipticCurve;
           36   81     2         params  Lorg/bouncycastle/asn1/x9/X962Parameters;
           40   52     3          curve  Lorg/bouncycastle/math/ec/ECCurve;
           55   56     3          curve  Lorg/bouncycastle/math/ec/ECCurve;
           58   81     3          curve  Lorg/bouncycastle/math/ec/ECCurve;
           41   52     4  ellipticCurve  Ljava/security/spec/EllipticCurve;
           59   68     4  ellipticCurve  Ljava/security/spec/EllipticCurve;
           38   51     5            oid  Lorg/bouncycastle/asn1/DERObjectIdentifier;
           39   51     6            ecP  Lorg/bouncycastle/asn1/x9/X9ECParameters;
           57   68     5            ecP  Lorg/bouncycastle/asn1/x9/X9ECParameters;
           69   81     5           bits  Lorg/bouncycastle/asn1/DERBitString;
           70   81     6           data  [B
           71   81     7            key  Lorg/bouncycastle/asn1/ASN1OctetString;
           74   79     8        qLength  I
           80   81     8           derQ  Lorg/bouncycastle/asn1/x9/X9ECPoint;
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.IOException
          75    76      77  Class java.io.IOException
    MethodParameters:
      Name  Flags
      info  

  public java.lang.String getAlgorithm();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 305
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  public java.lang.String getFormat();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 310
            ldc "X.509"
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 318
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
            ldc "ECGOST3410"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 26
         1: .line 320
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.gostParams:Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
            ifnull 4
         2: .line 322
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.gostParams:Lorg/bouncycastle/asn1/cryptopro/GOST3410PublicKeyAlgParameters;
            astore 1 /* params */
        start local 1 // org.bouncycastle.asn1.ASN1Encodable params
         3: .line 323
            goto 19
        end local 1 // org.bouncycastle.asn1.ASN1Encodable params
         4: .line 326
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            instanceof org.bouncycastle.jce.spec.ECNamedCurveSpec
            ifeq 10
         5: .line 328
            new org.bouncycastle.asn1.cryptopro.GOST3410PublicKeyAlgParameters
            dup
         6: .line 329
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            checkcast org.bouncycastle.jce.spec.ECNamedCurveSpec
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveSpec.getName:()Ljava/lang/String;
            invokestatic org.bouncycastle.asn1.cryptopro.ECGOST3410NamedCurves.getOID:(Ljava/lang/String;)Lorg/bouncycastle/asn1/DERObjectIdentifier;
         7: .line 330
            getstatic org.bouncycastle.asn1.cryptopro.CryptoProObjectIdentifiers.gostR3411_94_CryptoProParamSet:Lorg/bouncycastle/asn1/DERObjectIdentifier;
         8: .line 328
            invokespecial org.bouncycastle.asn1.cryptopro.GOST3410PublicKeyAlgParameters.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DERObjectIdentifier;)V
            astore 1 /* params */
        start local 1 // org.bouncycastle.asn1.ASN1Encodable params
         9: .line 331
            goto 19
        end local 1 // org.bouncycastle.asn1.ASN1Encodable params
        10: .line 334
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCurve:()Ljava/security/spec/EllipticCurve;
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Ljava/security/spec/EllipticCurve;)Lorg/bouncycastle/math/ec/ECCurve;
            astore 3 /* curve */
        start local 3 // org.bouncycastle.math.ec.ECCurve curve
        11: .line 336
            new org.bouncycastle.asn1.x9.X9ECParameters
            dup
        12: .line 337
            aload 3 /* curve */
        13: .line 338
            aload 3 /* curve */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getGenerator:()Ljava/security/spec/ECPoint;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertPoint:(Lorg/bouncycastle/math/ec/ECCurve;Ljava/security/spec/ECPoint;Z)Lorg/bouncycastle/math/ec/ECPoint;
        14: .line 339
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getOrder:()Ljava/math/BigInteger;
        15: .line 340
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCofactor:()I
            i2l
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
        16: .line 341
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCurve:()Ljava/security/spec/EllipticCurve;
            invokevirtual java.security.spec.EllipticCurve.getSeed:()[B
        17: .line 336
            invokespecial org.bouncycastle.asn1.x9.X9ECParameters.<init>:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECPoint;Ljava/math/BigInteger;Ljava/math/BigInteger;[B)V
            astore 4 /* ecP */
        start local 4 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        18: .line 343
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            aload 4 /* ecP */
            invokespecial org.bouncycastle.asn1.x9.X962Parameters.<init>:(Lorg/bouncycastle/asn1/x9/X9ECParameters;)V
            astore 1 /* params */
        end local 4 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
        start local 1 // org.bouncycastle.asn1.ASN1Encodable params
        19: .line 347
      StackMap locals: org.bouncycastle.asn1.ASN1Encodable
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            astore 3 /* bX */
        start local 3 // java.math.BigInteger bX
        20: .line 348
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            astore 4 /* bY */
        start local 4 // java.math.BigInteger bY
        21: .line 349
            bipush 64
            newarray 8
            astore 5 /* encKey */
        start local 5 // byte[] encKey
        22: .line 351
            aload 0 /* this */
            aload 5 /* encKey */
            iconst_0
            aload 3 /* bX */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.extractBytes:([BILjava/math/BigInteger;)V
        23: .line 352
            aload 0 /* this */
            aload 5 /* encKey */
            bipush 32
            aload 4 /* bY */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.extractBytes:([BILjava/math/BigInteger;)V
        24: .line 354
            new org.bouncycastle.asn1.x509.SubjectPublicKeyInfo
            dup
            new org.bouncycastle.asn1.x509.AlgorithmIdentifier
            dup
            getstatic org.bouncycastle.asn1.cryptopro.CryptoProObjectIdentifiers.gostR3410_2001:Lorg/bouncycastle/asn1/DERObjectIdentifier;
            aload 1 /* params */
            invokevirtual org.bouncycastle.asn1.ASN1Encodable.getDERObject:()Lorg/bouncycastle/asn1/DERObject;
            invokespecial org.bouncycastle.asn1.x509.AlgorithmIdentifier.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
            new org.bouncycastle.asn1.DEROctetString
            dup
            aload 5 /* encKey */
            invokespecial org.bouncycastle.asn1.DEROctetString.<init>:([B)V
            invokespecial org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.<init>:(Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
            astore 2 /* info */
        end local 5 // byte[] encKey
        end local 4 // java.math.BigInteger bY
        end local 3 // java.math.BigInteger bX
        start local 2 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        25: .line 355
            goto 48
        end local 2 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        end local 1 // org.bouncycastle.asn1.ASN1Encodable params
        26: .line 358
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            instanceof org.bouncycastle.jce.spec.ECNamedCurveSpec
            ifeq 32
        27: .line 360
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            checkcast org.bouncycastle.jce.spec.ECNamedCurveSpec
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveSpec.getName:()Ljava/lang/String;
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.ECUtil.getNamedCurveOid:(Ljava/lang/String;)Lorg/bouncycastle/asn1/DERObjectIdentifier;
            astore 3 /* curveOid */
        start local 3 // org.bouncycastle.asn1.DERObjectIdentifier curveOid
        28: .line 361
            aload 3 /* curveOid */
            ifnonnull 30
        29: .line 363
            new org.bouncycastle.asn1.DERObjectIdentifier
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            checkcast org.bouncycastle.jce.spec.ECNamedCurveSpec
            invokevirtual org.bouncycastle.jce.spec.ECNamedCurveSpec.getName:()Ljava/lang/String;
            invokespecial org.bouncycastle.asn1.DERObjectIdentifier.<init>:(Ljava/lang/String;)V
            astore 3 /* curveOid */
        30: .line 365
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey top top org.bouncycastle.asn1.DERObjectIdentifier
      StackMap stack:
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            aload 3 /* curveOid */
            invokespecial org.bouncycastle.asn1.x9.X962Parameters.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)V
            astore 1 /* params */
        end local 3 // org.bouncycastle.asn1.DERObjectIdentifier curveOid
        start local 1 // org.bouncycastle.asn1.ASN1Encodable params
        31: .line 366
            goto 44
        end local 1 // org.bouncycastle.asn1.ASN1Encodable params
        32: .line 367
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            ifnonnull 35
        33: .line 369
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            getstatic org.bouncycastle.asn1.DERNull.INSTANCE:Lorg/bouncycastle/asn1/DERNull;
            invokespecial org.bouncycastle.asn1.x9.X962Parameters.<init>:(Lorg/bouncycastle/asn1/DERObject;)V
            astore 1 /* params */
        start local 1 // org.bouncycastle.asn1.ASN1Encodable params
        34: .line 370
            goto 44
        end local 1 // org.bouncycastle.asn1.ASN1Encodable params
        35: .line 373
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCurve:()Ljava/security/spec/EllipticCurve;
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertCurve:(Ljava/security/spec/EllipticCurve;)Lorg/bouncycastle/math/ec/ECCurve;
            astore 3 /* curve */
        start local 3 // org.bouncycastle.math.ec.ECCurve curve
        36: .line 375
            new org.bouncycastle.asn1.x9.X9ECParameters
            dup
        37: .line 376
            aload 3 /* curve */
        38: .line 377
            aload 3 /* curve */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getGenerator:()Ljava/security/spec/ECPoint;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertPoint:(Lorg/bouncycastle/math/ec/ECCurve;Ljava/security/spec/ECPoint;Z)Lorg/bouncycastle/math/ec/ECPoint;
        39: .line 378
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getOrder:()Ljava/math/BigInteger;
        40: .line 379
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCofactor:()I
            i2l
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
        41: .line 380
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCurve:()Ljava/security/spec/EllipticCurve;
            invokevirtual java.security.spec.EllipticCurve.getSeed:()[B
        42: .line 375
            invokespecial org.bouncycastle.asn1.x9.X9ECParameters.<init>:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECPoint;Ljava/math/BigInteger;Ljava/math/BigInteger;[B)V
            astore 4 /* ecP */
        start local 4 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        43: .line 382
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            aload 4 /* ecP */
            invokespecial org.bouncycastle.asn1.x9.X962Parameters.<init>:(Lorg/bouncycastle/asn1/x9/X9ECParameters;)V
            astore 1 /* params */
        end local 4 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
        start local 1 // org.bouncycastle.asn1.ASN1Encodable params
        44: .line 385
      StackMap locals: org.bouncycastle.asn1.ASN1Encodable
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.engineGetQ:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            astore 3 /* curve */
        start local 3 // org.bouncycastle.math.ec.ECCurve curve
        45: .line 387
            new org.bouncycastle.asn1.x9.X9ECPoint
            dup
            aload 3 /* curve */
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.getQ:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.getQ:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
            invokevirtual org.bouncycastle.math.ec.ECCurve.createPoint:(Ljava/math/BigInteger;Ljava/math/BigInteger;Z)Lorg/bouncycastle/math/ec/ECPoint;
            invokespecial org.bouncycastle.asn1.x9.X9ECPoint.<init>:(Lorg/bouncycastle/math/ec/ECPoint;)V
            invokevirtual org.bouncycastle.asn1.x9.X9ECPoint.getDERObject:()Lorg/bouncycastle/asn1/DERObject;
        46: .line 386
            checkcast org.bouncycastle.asn1.ASN1OctetString
            astore 4 /* p */
        start local 4 // org.bouncycastle.asn1.ASN1OctetString p
        47: .line 389
            new org.bouncycastle.asn1.x509.SubjectPublicKeyInfo
            dup
            new org.bouncycastle.asn1.x509.AlgorithmIdentifier
            dup
            getstatic org.bouncycastle.asn1.x9.X9ObjectIdentifiers.id_ecPublicKey:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            aload 1 /* params */
            invokevirtual org.bouncycastle.asn1.ASN1Encodable.getDERObject:()Lorg/bouncycastle/asn1/DERObject;
            invokespecial org.bouncycastle.asn1.x509.AlgorithmIdentifier.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
            aload 4 /* p */
            invokevirtual org.bouncycastle.asn1.ASN1OctetString.getOctets:()[B
            invokespecial org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.<init>:(Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;[B)V
            astore 2 /* info */
        end local 4 // org.bouncycastle.asn1.ASN1OctetString p
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
        start local 2 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        48: .line 392
      StackMap locals: org.bouncycastle.asn1.x509.SubjectPublicKeyInfo
      StackMap stack:
            aload 2 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getDEREncoded:()[B
            areturn
        end local 2 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        end local 1 // org.bouncycastle.asn1.ASN1Encodable params
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   49     0      this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            3    4     1    params  Lorg/bouncycastle/asn1/ASN1Encodable;
            9   10     1    params  Lorg/bouncycastle/asn1/ASN1Encodable;
           19   26     1    params  Lorg/bouncycastle/asn1/ASN1Encodable;
           31   32     1    params  Lorg/bouncycastle/asn1/ASN1Encodable;
           34   35     1    params  Lorg/bouncycastle/asn1/ASN1Encodable;
           44   49     1    params  Lorg/bouncycastle/asn1/ASN1Encodable;
           25   26     2      info  Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
           48   49     2      info  Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
           11   19     3     curve  Lorg/bouncycastle/math/ec/ECCurve;
           18   19     4       ecP  Lorg/bouncycastle/asn1/x9/X9ECParameters;
           20   25     3        bX  Ljava/math/BigInteger;
           21   25     4        bY  Ljava/math/BigInteger;
           22   25     5    encKey  [B
           28   31     3  curveOid  Lorg/bouncycastle/asn1/DERObjectIdentifier;
           36   44     3     curve  Lorg/bouncycastle/math/ec/ECCurve;
           43   44     4       ecP  Lorg/bouncycastle/asn1/x9/X9ECParameters;
           45   48     3     curve  Lorg/bouncycastle/math/ec/ECCurve;
           47   48     4         p  Lorg/bouncycastle/asn1/ASN1OctetString;

  private void extractBytes(byte[], int, java.math.BigInteger);
    descriptor: ([BILjava/math/BigInteger;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // byte[] encKey
        start local 2 // int offSet
        start local 3 // java.math.BigInteger bI
         0: .line 397
            aload 3 /* bI */
            invokevirtual java.math.BigInteger.toByteArray:()[B
            astore 4 /* val */
        start local 4 // byte[] val
         1: .line 398
            aload 4 /* val */
            arraylength
            bipush 32
            if_icmpge 5
         2: .line 400
            bipush 32
            newarray 8
            astore 5 /* tmp */
        start local 5 // byte[] tmp
         3: .line 401
            aload 4 /* val */
            iconst_0
            aload 5 /* tmp */
            aload 5 /* tmp */
            arraylength
            aload 4 /* val */
            arraylength
            isub
            aload 4 /* val */
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         4: .line 402
            aload 5 /* tmp */
            astore 4 /* val */
        end local 5 // byte[] tmp
         5: .line 405
      StackMap locals: byte[]
      StackMap stack:
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         6: goto 9
         7: .line 407
      StackMap locals: int
      StackMap stack:
            aload 1 /* encKey */
            iload 2 /* offSet */
            iload 5 /* i */
            iadd
            aload 4 /* val */
            aload 4 /* val */
            arraylength
            iconst_1
            isub
            iload 5 /* i */
            isub
            baload
            bastore
         8: .line 405
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 5 /* i */
            bipush 32
            if_icmpne 7
        end local 5 // int i
        10: .line 409
            return
        end local 4 // byte[] val
        end local 3 // java.math.BigInteger bI
        end local 2 // int offSet
        end local 1 // byte[] encKey
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0   11     1  encKey  [B
            0   11     2  offSet  I
            0   11     3      bI  Ljava/math/BigInteger;
            1   11     4     val  [B
            3    5     5     tmp  [B
            6   10     5       i  I
    MethodParameters:
        Name  Flags
      encKey  
      offSet  
      bI      

  public java.security.spec.ECParameterSpec getParams();
    descriptor: ()Ljava/security/spec/ECParameterSpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 413
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  public org.bouncycastle.jce.spec.ECParameterSpec getParameters();
    descriptor: ()Lorg/bouncycastle/jce/spec/ECParameterSpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 418
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            ifnonnull 2
         1: .line 420
            aconst_null
            areturn
         2: .line 423
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertSpec:(Ljava/security/spec/ECParameterSpec;Z)Lorg/bouncycastle/jce/spec/ECParameterSpec;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  public java.security.spec.ECPoint getW();
    descriptor: ()Ljava/security/spec/ECPoint;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 428
            new java.security.spec.ECPoint
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  public org.bouncycastle.math.ec.ECPoint getQ();
    descriptor: ()Lorg/bouncycastle/math/ec/ECPoint;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 433
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            ifnonnull 4
         1: .line 435
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            instanceof org.bouncycastle.math.ec.ECPoint$Fp
            ifeq 3
         2: .line 437
            new org.bouncycastle.math.ec.ECPoint$Fp
            dup
            aconst_null
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokespecial org.bouncycastle.math.ec.ECPoint$Fp.<init>:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;)V
            areturn
         3: .line 441
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.math.ec.ECPoint$F2m
            dup
            aconst_null
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokespecial org.bouncycastle.math.ec.ECPoint$F2m.<init>:(Lorg/bouncycastle/math/ec/ECCurve;Lorg/bouncycastle/math/ec/ECFieldElement;Lorg/bouncycastle/math/ec/ECFieldElement;)V
            areturn
         4: .line 445
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  public org.bouncycastle.math.ec.ECPoint engineGetQ();
    descriptor: ()Lorg/bouncycastle/math/ec/ECPoint;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 450
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  org.bouncycastle.jce.spec.ECParameterSpec engineGetSpec();
    descriptor: ()Lorg/bouncycastle/jce/spec/ECParameterSpec;
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 455
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            ifnull 2
         1: .line 457
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertSpec:(Ljava/security/spec/ECParameterSpec;Z)Lorg/bouncycastle/jce/spec/ECParameterSpec;
            areturn
         2: .line 460
      StackMap locals:
      StackMap stack:
            invokestatic org.bouncycastle.jce.provider.ProviderUtil.getEcImplicitlyCa:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 465
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 1 /* buf */
        start local 1 // java.lang.StringBuffer buf
         1: .line 466
            ldc "line.separator"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* nl */
        start local 2 // java.lang.String nl
         2: .line 468
            aload 1 /* buf */
            ldc "EC Public Key"
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 2 /* nl */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         3: .line 469
            aload 1 /* buf */
            ldc "            X: "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getX:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            bipush 16
            invokevirtual java.math.BigInteger.toString:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 2 /* nl */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         4: .line 470
            aload 1 /* buf */
            ldc "            Y: "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.q:Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.getY:()Lorg/bouncycastle/math/ec/ECFieldElement;
            invokevirtual org.bouncycastle.math.ec.ECFieldElement.toBigInteger:()Ljava/math/BigInteger;
            bipush 16
            invokevirtual java.math.BigInteger.toString:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 2 /* nl */
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
         5: .line 472
            aload 1 /* buf */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 2 // java.lang.String nl
        end local 1 // java.lang.StringBuffer buf
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            1    6     1   buf  Ljava/lang/StringBuffer;
            2    6     2    nl  Ljava/lang/String;

  public void setPointFormat(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.String style
         0: .line 478
            aload 0 /* this */
            ldc "UNCOMPRESSED"
            aload 1 /* style */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack: org.bouncycastle.jce.provider.JCEECPublicKey
         1: iconst_1
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey java.lang.String
      StackMap stack: org.bouncycastle.jce.provider.JCEECPublicKey int
         2: putfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
         3: .line 479
            return
        end local 1 // java.lang.String style
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    4     1  style  Ljava/lang/String;
    MethodParameters:
       Name  Flags
      style  

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.lang.Object o
         0: .line 483
            aload 1 /* o */
            instanceof org.bouncycastle.jce.provider.JCEECPublicKey
            ifne 2
         1: .line 485
            iconst_0
            ireturn
         2: .line 488
      StackMap locals:
      StackMap stack:
            aload 1 /* o */
            checkcast org.bouncycastle.jce.provider.JCEECPublicKey
            astore 2 /* other */
        start local 2 // org.bouncycastle.jce.provider.JCEECPublicKey other
         3: .line 490
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.engineGetQ:()Lorg/bouncycastle/math/ec/ECPoint;
            aload 2 /* other */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.engineGetQ:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.equals:(Ljava/lang/Object;)Z
            ifeq 4
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.engineGetSpec:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            aload 2 /* other */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.engineGetSpec:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.equals:(Ljava/lang/Object;)Z
            ifeq 4
            iconst_1
            ireturn
      StackMap locals: org.bouncycastle.jce.provider.JCEECPublicKey
      StackMap stack:
         4: iconst_0
            ireturn
        end local 2 // org.bouncycastle.jce.provider.JCEECPublicKey other
        end local 1 // java.lang.Object o
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    5     1      o  Ljava/lang/Object;
            3    5     2  other  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
    MethodParameters:
      Name  Flags
      o     

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
         0: .line 495
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.engineGetQ:()Lorg/bouncycastle/math/ec/ECPoint;
            invokevirtual org.bouncycastle.math.ec.ECPoint.hashCode:()I
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.engineGetSpec:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.hashCode:()I
            ixor
            ireturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;

  private void readObject(java.io.ObjectInputStream);
    descriptor: (Ljava/io/ObjectInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.io.ObjectInputStream in
         0: .line 502
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            checkcast byte[]
            astore 2 /* enc */
        start local 2 // byte[] enc
         1: .line 504
            aload 0 /* this */
            aload 2 /* enc */
            invokestatic org.bouncycastle.asn1.ASN1Object.fromByteArray:([B)Lorg/bouncycastle/asn1/ASN1Object;
            invokestatic org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.populateFromPubKeyInfo:(Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;)V
         2: .line 506
            aload 0 /* this */
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            checkcast java.lang.String
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
         3: .line 507
            aload 0 /* this */
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readBoolean:()Z
            putfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
         4: .line 508
            return
        end local 2 // byte[] enc
        end local 1 // java.io.ObjectInputStream in
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    5     1    in  Ljava/io/ObjectInputStream;
            1    5     2   enc  [B
    Exceptions:
      throws java.io.IOException, java.lang.ClassNotFoundException
    MethodParameters:
      Name  Flags
      in    

  private void writeObject(java.io.ObjectOutputStream);
    descriptor: (Ljava/io/ObjectOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
        start local 1 // java.io.ObjectOutputStream out
         0: .line 514
            aload 1 /* out */
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.getEncoded:()[B
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         1: .line 515
            aload 1 /* out */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.algorithm:Ljava/lang/String;
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         2: .line 516
            aload 1 /* out */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPublicKey.withCompression:Z
            invokevirtual java.io.ObjectOutputStream.writeBoolean:(Z)V
         3: .line 517
            return
        end local 1 // java.io.ObjectOutputStream out
        end local 0 // org.bouncycastle.jce.provider.JCEECPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0    4     1   out  Ljava/io/ObjectOutputStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      out   
}
SourceFile: "JCEECPublicKey.java"
InnerClasses:
  public F2m = org.bouncycastle.math.ec.ECPoint$F2m of org.bouncycastle.math.ec.ECPoint
  public Fp = org.bouncycastle.math.ec.ECPoint$Fp of org.bouncycastle.math.ec.ECPoint