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

  private java.math.BigInteger d;
    descriptor: Ljava/math/BigInteger;
    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.DERBitString publicKey;
    descriptor: Lorg/bouncycastle/asn1/DERBitString;
    flags: (0x0002) ACC_PRIVATE

  private org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl attrCarrier;
    descriptor: Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
    flags: (0x0002) ACC_PRIVATE

  protected void <init>();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
         0: .line 52
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 54
            return
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  public void <init>(java.security.interfaces.ECPrivateKey);
    descriptor: (Ljava/security/interfaces/ECPrivateKey;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.security.interfaces.ECPrivateKey key
         0: .line 56
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 59
            aload 0 /* this */
            aload 1 /* key */
            invokeinterface java.security.interfaces.ECPrivateKey.getS:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
         4: .line 60
            aload 0 /* this */
            aload 1 /* key */
            invokeinterface java.security.interfaces.ECPrivateKey.getAlgorithm:()Ljava/lang/String;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         5: .line 61
            aload 0 /* this */
            aload 1 /* key */
            invokeinterface java.security.interfaces.ECPrivateKey.getParams:()Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         6: .line 62
            return
        end local 1 // java.security.interfaces.ECPrivateKey key
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    7     1   key  Ljava/security/interfaces/ECPrivateKey;
    MethodParameters:
      Name  Flags
      key   

  public void <init>(java.lang.String, org.bouncycastle.jce.spec.ECPrivateKeySpec);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/jce/spec/ECPrivateKeySpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.jce.spec.ECPrivateKeySpec spec
         0: .line 64
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 68
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         4: .line 69
            aload 0 /* this */
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPrivateKeySpec.getD:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
         5: .line 71
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPrivateKeySpec.getParams:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            ifnull 10
         6: .line 73
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPrivateKeySpec.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
         7: .line 76
            aload 3 /* curve */
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPrivateKeySpec.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
         8: .line 78
            aload 0 /* this */
            aload 4 /* ellipticCurve */
            aload 2 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECPrivateKeySpec.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.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 4 // java.security.spec.EllipticCurve ellipticCurve
        end local 3 // org.bouncycastle.math.ec.ECCurve curve
         9: .line 79
            goto 11
        10: .line 82
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey java.lang.String org.bouncycastle.jce.spec.ECPrivateKeySpec
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        11: .line 84
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.bouncycastle.jce.spec.ECPrivateKeySpec spec
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0   12     1      algorithm  Ljava/lang/String;
            0   12     2           spec  Lorg/bouncycastle/jce/spec/ECPrivateKeySpec;
            7    9     3          curve  Lorg/bouncycastle/math/ec/ECCurve;
            8    9     4  ellipticCurve  Ljava/security/spec/EllipticCurve;
    MethodParameters:
           Name  Flags
      algorithm  
      spec       

  public void <init>(java.lang.String, java.security.spec.ECPrivateKeySpec);
    descriptor: (Ljava/lang/String;Ljava/security/spec/ECPrivateKeySpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.lang.String algorithm
        start local 2 // java.security.spec.ECPrivateKeySpec spec
         0: .line 87
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 91
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         4: .line 92
            aload 0 /* this */
            aload 2 /* spec */
            invokevirtual java.security.spec.ECPrivateKeySpec.getS:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
         5: .line 93
            aload 0 /* this */
            aload 2 /* spec */
            invokevirtual java.security.spec.ECPrivateKeySpec.getParams:()Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         6: .line 94
            return
        end local 2 // java.security.spec.ECPrivateKeySpec spec
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    7     1  algorithm  Ljava/lang/String;
            0    7     2       spec  Ljava/security/spec/ECPrivateKeySpec;
    MethodParameters:
           Name  Flags
      algorithm  
      spec       

  public void <init>(java.lang.String, org.bouncycastle.jce.provider.JCEECPrivateKey);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/jce/provider/JCEECPrivateKey;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.jce.provider.JCEECPrivateKey key
         0: .line 96
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 100
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         4: .line 101
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
         5: .line 102
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         6: .line 103
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.withCompression:Z
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.withCompression:Z
         7: .line 104
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         8: .line 105
            aload 0 /* this */
            aload 2 /* key */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.publicKey:Lorg/bouncycastle/asn1/DERBitString;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.publicKey:Lorg/bouncycastle/asn1/DERBitString;
         9: .line 106
            return
        end local 2 // org.bouncycastle.jce.provider.JCEECPrivateKey key
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   10     0       this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0   10     1  algorithm  Ljava/lang/String;
            0   10     2        key  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
    MethodParameters:
           Name  Flags
      algorithm  
      key        

  public void <init>(java.lang.String, org.bouncycastle.crypto.params.ECPrivateKeyParameters, org.bouncycastle.jce.provider.JCEECPublicKey, java.security.spec.ECParameterSpec);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/crypto/params/ECPrivateKeyParameters;Lorg/bouncycastle/jce/provider/JCEECPublicKey;Ljava/security/spec/ECParameterSpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=7, args_size=5
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.crypto.params.ECPrivateKeyParameters params
        start local 3 // org.bouncycastle.jce.provider.JCEECPublicKey pubKey
        start local 4 // java.security.spec.ECParameterSpec spec
         0: .line 108
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 114
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPrivateKeyParameters.getParameters:()Lorg/bouncycastle/crypto/params/ECDomainParameters;
            astore 5 /* dp */
        start local 5 // org.bouncycastle.crypto.params.ECDomainParameters dp
         4: .line 116
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         5: .line 117
            aload 0 /* this */
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPrivateKeyParameters.getD:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
         6: .line 119
            aload 4 /* spec */
            ifnonnull 18
         7: .line 121
            aload 5 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 5 /* 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 6 /* ellipticCurve */
        start local 6 // java.security.spec.EllipticCurve ellipticCurve
         8: .line 123
            aload 0 /* this */
            new java.security.spec.ECParameterSpec
            dup
         9: .line 124
            aload 6 /* ellipticCurve */
        10: .line 125
            new java.security.spec.ECPoint
            dup
        11: .line 126
            aload 5 /* 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;
        12: .line 127
            aload 5 /* 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;
        13: .line 125
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        14: .line 128
            aload 5 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getN:()Ljava/math/BigInteger;
        15: .line 129
            aload 5 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.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
        16: .line 123
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 6 // java.security.spec.EllipticCurve ellipticCurve
        17: .line 130
            goto 19
        18: .line 133
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey java.lang.String org.bouncycastle.crypto.params.ECPrivateKeyParameters org.bouncycastle.jce.provider.JCEECPublicKey java.security.spec.ECParameterSpec org.bouncycastle.crypto.params.ECDomainParameters
      StackMap stack:
            aload 0 /* this */
            aload 4 /* spec */
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        19: .line 136
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 3 /* pubKey */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getPublicKeyDetails:(Lorg/bouncycastle/jce/provider/JCEECPublicKey;)Lorg/bouncycastle/asn1/DERBitString;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.publicKey:Lorg/bouncycastle/asn1/DERBitString;
        20: .line 137
            return
        end local 5 // org.bouncycastle.crypto.params.ECDomainParameters dp
        end local 4 // java.security.spec.ECParameterSpec spec
        end local 3 // org.bouncycastle.jce.provider.JCEECPublicKey pubKey
        end local 2 // org.bouncycastle.crypto.params.ECPrivateKeyParameters params
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   21     0           this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0   21     1      algorithm  Ljava/lang/String;
            0   21     2         params  Lorg/bouncycastle/crypto/params/ECPrivateKeyParameters;
            0   21     3         pubKey  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0   21     4           spec  Ljava/security/spec/ECParameterSpec;
            4   21     5             dp  Lorg/bouncycastle/crypto/params/ECDomainParameters;
            8   17     6  ellipticCurve  Ljava/security/spec/EllipticCurve;
    MethodParameters:
           Name  Flags
      algorithm  
      params     
      pubKey     
      spec       

  public void <init>(java.lang.String, org.bouncycastle.crypto.params.ECPrivateKeyParameters, org.bouncycastle.jce.provider.JCEECPublicKey, org.bouncycastle.jce.spec.ECParameterSpec);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/crypto/params/ECPrivateKeyParameters;Lorg/bouncycastle/jce/provider/JCEECPublicKey;Lorg/bouncycastle/jce/spec/ECParameterSpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=7, args_size=5
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.crypto.params.ECPrivateKeyParameters params
        start local 3 // org.bouncycastle.jce.provider.JCEECPublicKey pubKey
        start local 4 // org.bouncycastle.jce.spec.ECParameterSpec spec
         0: .line 139
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 145
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPrivateKeyParameters.getParameters:()Lorg/bouncycastle/crypto/params/ECDomainParameters;
            astore 5 /* dp */
        start local 5 // org.bouncycastle.crypto.params.ECDomainParameters dp
         4: .line 147
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         5: .line 148
            aload 0 /* this */
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPrivateKeyParameters.getD:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
         6: .line 150
            aload 4 /* spec */
            ifnonnull 18
         7: .line 152
            aload 5 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 5 /* 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 6 /* ellipticCurve */
        start local 6 // java.security.spec.EllipticCurve ellipticCurve
         8: .line 154
            aload 0 /* this */
            new java.security.spec.ECParameterSpec
            dup
         9: .line 155
            aload 6 /* ellipticCurve */
        10: .line 156
            new java.security.spec.ECPoint
            dup
        11: .line 157
            aload 5 /* 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;
        12: .line 158
            aload 5 /* 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;
        13: .line 156
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        14: .line 159
            aload 5 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getN:()Ljava/math/BigInteger;
        15: .line 160
            aload 5 /* dp */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.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
        16: .line 154
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 6 // java.security.spec.EllipticCurve ellipticCurve
        17: .line 161
            goto 28
        18: .line 164
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey java.lang.String org.bouncycastle.crypto.params.ECPrivateKeyParameters org.bouncycastle.jce.provider.JCEECPublicKey org.bouncycastle.jce.spec.ECParameterSpec org.bouncycastle.crypto.params.ECDomainParameters
      StackMap stack:
            aload 4 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 4 /* 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 6 /* ellipticCurve */
        start local 6 // java.security.spec.EllipticCurve ellipticCurve
        19: .line 166
            aload 0 /* this */
            new java.security.spec.ECParameterSpec
            dup
        20: .line 167
            aload 6 /* ellipticCurve */
        21: .line 168
            new java.security.spec.ECPoint
            dup
        22: .line 169
            aload 4 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.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;
        23: .line 170
            aload 4 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.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;
        24: .line 168
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        25: .line 171
            aload 4 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.getN:()Ljava/math/BigInteger;
        26: .line 172
            aload 4 /* spec */
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.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
        27: .line 166
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 6 // java.security.spec.EllipticCurve ellipticCurve
        28: .line 175
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 3 /* pubKey */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getPublicKeyDetails:(Lorg/bouncycastle/jce/provider/JCEECPublicKey;)Lorg/bouncycastle/asn1/DERBitString;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.publicKey:Lorg/bouncycastle/asn1/DERBitString;
        29: .line 176
            return
        end local 5 // org.bouncycastle.crypto.params.ECDomainParameters dp
        end local 4 // org.bouncycastle.jce.spec.ECParameterSpec spec
        end local 3 // org.bouncycastle.jce.provider.JCEECPublicKey pubKey
        end local 2 // org.bouncycastle.crypto.params.ECPrivateKeyParameters params
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   30     0           this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0   30     1      algorithm  Ljava/lang/String;
            0   30     2         params  Lorg/bouncycastle/crypto/params/ECPrivateKeyParameters;
            0   30     3         pubKey  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            0   30     4           spec  Lorg/bouncycastle/jce/spec/ECParameterSpec;
            4   30     5             dp  Lorg/bouncycastle/crypto/params/ECDomainParameters;
            8   17     6  ellipticCurve  Ljava/security/spec/EllipticCurve;
           19   28     6  ellipticCurve  Ljava/security/spec/EllipticCurve;
    MethodParameters:
           Name  Flags
      algorithm  
      params     
      pubKey     
      spec       

  public void <init>(java.lang.String, org.bouncycastle.crypto.params.ECPrivateKeyParameters);
    descriptor: (Ljava/lang/String;Lorg/bouncycastle/crypto/params/ECPrivateKeyParameters;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.lang.String algorithm
        start local 2 // org.bouncycastle.crypto.params.ECPrivateKeyParameters params
         0: .line 178
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 182
            aload 0 /* this */
            aload 1 /* algorithm */
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         4: .line 183
            aload 0 /* this */
            aload 2 /* params */
            invokevirtual org.bouncycastle.crypto.params.ECPrivateKeyParameters.getD:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
         5: .line 184
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
         6: .line 185
            return
        end local 2 // org.bouncycastle.crypto.params.ECPrivateKeyParameters params
        end local 1 // java.lang.String algorithm
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    7     1  algorithm  Ljava/lang/String;
            0    7     2     params  Lorg/bouncycastle/crypto/params/ECPrivateKeyParameters;
    MethodParameters:
           Name  Flags
      algorithm  
      params     

  void <init>(org.bouncycastle.asn1.pkcs.PrivateKeyInfo);
    descriptor: (Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
         0: .line 187
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 43
            aload 0 /* this */
            ldc "EC"
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         2: .line 50
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         3: .line 190
            aload 0 /* this */
            aload 1 /* info */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.populateFromPrivKeyInfo:(Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;)V
         4: .line 191
            return
        end local 1 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    5     1  info  Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;
    MethodParameters:
      Name  Flags
      info  

  private void populateFromPrivKeyInfo(org.bouncycastle.asn1.pkcs.PrivateKeyInfo);
    descriptor: (Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=7, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
         0: .line 195
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.pkcs.PrivateKeyInfo.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
         1: .line 197
            aload 2 /* params */
            invokevirtual org.bouncycastle.asn1.x9.X962Parameters.isNamedCurve:()Z
            ifeq 30
         2: .line 199
            aload 2 /* params */
            invokevirtual org.bouncycastle.asn1.x9.X962Parameters.getParameters:()Lorg/bouncycastle/asn1/DERObject;
            checkcast org.bouncycastle.asn1.DERObjectIdentifier
            astore 3 /* oid */
        start local 3 // org.bouncycastle.asn1.DERObjectIdentifier oid
         3: .line 200
            aload 3 /* oid */
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.ECUtil.getNamedCurveByOid:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Lorg/bouncycastle/asn1/x9/X9ECParameters;
            astore 4 /* ecP */
        start local 4 // org.bouncycastle.asn1.x9.X9ECParameters ecP
         4: .line 202
            aload 4 /* ecP */
            ifnonnull 18
         5: .line 204
            aload 3 /* oid */
            invokestatic org.bouncycastle.asn1.cryptopro.ECGOST3410NamedCurves.getByOID:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Lorg/bouncycastle/crypto/params/ECDomainParameters;
            astore 5 /* gParam */
        start local 5 // org.bouncycastle.crypto.params.ECDomainParameters gParam
         6: .line 205
            aload 5 /* gParam */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 5 /* gParam */
            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 6 /* ellipticCurve */
        start local 6 // java.security.spec.EllipticCurve ellipticCurve
         7: .line 207
            aload 0 /* this */
            new org.bouncycastle.jce.spec.ECNamedCurveSpec
            dup
         8: .line 208
            aload 3 /* oid */
            invokestatic org.bouncycastle.asn1.cryptopro.ECGOST3410NamedCurves.getName:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Ljava/lang/String;
         9: .line 209
            aload 6 /* ellipticCurve */
        10: .line 210
            new java.security.spec.ECPoint
            dup
        11: .line 211
            aload 5 /* gParam */
            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;
        12: .line 212
            aload 5 /* gParam */
            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;
        13: .line 210
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        14: .line 213
            aload 5 /* gParam */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.getN:()Ljava/math/BigInteger;
        15: .line 214
            aload 5 /* gParam */
            invokevirtual org.bouncycastle.crypto.params.ECDomainParameters.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
        16: .line 207
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 6 // java.security.spec.EllipticCurve ellipticCurve
        end local 5 // org.bouncycastle.crypto.params.ECDomainParameters gParam
        17: .line 215
            goto 44
        18: .line 218
      StackMap locals: org.bouncycastle.asn1.x9.X962Parameters org.bouncycastle.asn1.DERObjectIdentifier org.bouncycastle.asn1.x9.X9ECParameters
      StackMap stack:
            aload 4 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 4 /* 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 5 /* ellipticCurve */
        start local 5 // java.security.spec.EllipticCurve ellipticCurve
        19: .line 220
            aload 0 /* this */
            new org.bouncycastle.jce.spec.ECNamedCurveSpec
            dup
        20: .line 221
            aload 3 /* oid */
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.ECUtil.getCurveName:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Ljava/lang/String;
        21: .line 222
            aload 5 /* ellipticCurve */
        22: .line 223
            new java.security.spec.ECPoint
            dup
        23: .line 224
            aload 4 /* 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;
        24: .line 225
            aload 4 /* 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;
        25: .line 223
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        26: .line 226
            aload 4 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getN:()Ljava/math/BigInteger;
        27: .line 227
            aload 4 /* 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
        28: .line 220
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 5 // java.security.spec.EllipticCurve ellipticCurve
        end local 4 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        end local 3 // org.bouncycastle.asn1.DERObjectIdentifier oid
        29: .line 229
            goto 44
        30: .line 230
      StackMap locals:
      StackMap stack:
            aload 2 /* params */
            invokevirtual org.bouncycastle.asn1.x9.X962Parameters.isImplicitlyCA:()Z
            ifeq 33
        31: .line 232
            aload 0 /* this */
            aconst_null
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        32: .line 233
            goto 44
        33: .line 236
      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 3 /* ecP */
        start local 3 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        34: .line 237
            aload 3 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getCurve:()Lorg/bouncycastle/math/ec/ECCurve;
            aload 3 /* 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
        35: .line 239
            aload 0 /* this */
            new java.security.spec.ECParameterSpec
            dup
        36: .line 240
            aload 4 /* ellipticCurve */
        37: .line 241
            new java.security.spec.ECPoint
            dup
        38: .line 242
            aload 3 /* 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;
        39: .line 243
            aload 3 /* 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;
        40: .line 241
            invokespecial java.security.spec.ECPoint.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
        41: .line 244
            aload 3 /* ecP */
            invokevirtual org.bouncycastle.asn1.x9.X9ECParameters.getN:()Ljava/math/BigInteger;
        42: .line 245
            aload 3 /* 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
        43: .line 239
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
        end local 4 // java.security.spec.EllipticCurve ellipticCurve
        end local 3 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        44: .line 248
      StackMap locals:
      StackMap stack:
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.pkcs.PrivateKeyInfo.getPrivateKey:()Lorg/bouncycastle/asn1/DERObject;
            instanceof org.bouncycastle.asn1.DERInteger
            ifeq 48
        45: .line 250
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.pkcs.PrivateKeyInfo.getPrivateKey:()Lorg/bouncycastle/asn1/DERObject;
            checkcast org.bouncycastle.asn1.DERInteger
            astore 3 /* derD */
        start local 3 // org.bouncycastle.asn1.DERInteger derD
        46: .line 252
            aload 0 /* this */
            aload 3 /* derD */
            invokevirtual org.bouncycastle.asn1.DERInteger.getValue:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
        end local 3 // org.bouncycastle.asn1.DERInteger derD
        47: .line 253
            goto 51
        48: .line 256
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.sec.ECPrivateKeyStructure
            dup
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.pkcs.PrivateKeyInfo.getPrivateKey:()Lorg/bouncycastle/asn1/DERObject;
            checkcast org.bouncycastle.asn1.ASN1Sequence
            invokespecial org.bouncycastle.asn1.sec.ECPrivateKeyStructure.<init>:(Lorg/bouncycastle/asn1/ASN1Sequence;)V
            astore 3 /* ec */
        start local 3 // org.bouncycastle.asn1.sec.ECPrivateKeyStructure ec
        49: .line 258
            aload 0 /* this */
            aload 3 /* ec */
            invokevirtual org.bouncycastle.asn1.sec.ECPrivateKeyStructure.getKey:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
        50: .line 259
            aload 0 /* this */
            aload 3 /* ec */
            invokevirtual org.bouncycastle.asn1.sec.ECPrivateKeyStructure.getPublicKey:()Lorg/bouncycastle/asn1/DERBitString;
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.publicKey:Lorg/bouncycastle/asn1/DERBitString;
        end local 3 // org.bouncycastle.asn1.sec.ECPrivateKeyStructure ec
        51: .line 261
      StackMap locals:
      StackMap stack:
            return
        end local 2 // org.bouncycastle.asn1.x9.X962Parameters params
        end local 1 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   52     0           this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0   52     1           info  Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;
            1   52     2         params  Lorg/bouncycastle/asn1/x9/X962Parameters;
            3   29     3            oid  Lorg/bouncycastle/asn1/DERObjectIdentifier;
            4   29     4            ecP  Lorg/bouncycastle/asn1/x9/X9ECParameters;
            6   17     5         gParam  Lorg/bouncycastle/crypto/params/ECDomainParameters;
            7   17     6  ellipticCurve  Ljava/security/spec/EllipticCurve;
           19   29     5  ellipticCurve  Ljava/security/spec/EllipticCurve;
           34   44     3            ecP  Lorg/bouncycastle/asn1/x9/X9ECParameters;
           35   44     4  ellipticCurve  Ljava/security/spec/EllipticCurve;
           46   47     3           derD  Lorg/bouncycastle/asn1/DERInteger;
           49   51     3             ec  Lorg/bouncycastle/asn1/sec/ECPrivateKeyStructure;
    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.JCEECPrivateKey this
         0: .line 265
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  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.JCEECPrivateKey this
         0: .line 275
            ldc "PKCS#8"
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
         0: .line 288
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            instanceof org.bouncycastle.jce.spec.ECNamedCurveSpec
            ifeq 6
         1: .line 290
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.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 2 /* curveOid */
        start local 2 // org.bouncycastle.asn1.DERObjectIdentifier curveOid
         2: .line 291
            aload 2 /* curveOid */
            ifnonnull 4
         3: .line 293
            new org.bouncycastle.asn1.DERObjectIdentifier
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.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 2 /* curveOid */
         4: .line 295
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey top org.bouncycastle.asn1.DERObjectIdentifier
      StackMap stack:
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            aload 2 /* curveOid */
            invokespecial org.bouncycastle.asn1.x9.X962Parameters.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)V
            astore 1 /* params */
        end local 2 // org.bouncycastle.asn1.DERObjectIdentifier curveOid
        start local 1 // org.bouncycastle.asn1.x9.X962Parameters params
         5: .line 296
            goto 18
        end local 1 // org.bouncycastle.asn1.x9.X962Parameters params
         6: .line 297
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            ifnonnull 9
         7: .line 299
            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.x9.X962Parameters params
         8: .line 300
            goto 18
        end local 1 // org.bouncycastle.asn1.x9.X962Parameters params
         9: .line 303
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.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 2 /* curve */
        start local 2 // org.bouncycastle.math.ec.ECCurve curve
        10: .line 305
            new org.bouncycastle.asn1.x9.X9ECParameters
            dup
        11: .line 306
            aload 2 /* curve */
        12: .line 307
            aload 2 /* curve */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getGenerator:()Ljava/security/spec/ECPoint;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.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;
        13: .line 308
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getOrder:()Ljava/math/BigInteger;
        14: .line 309
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCofactor:()I
            i2l
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
        15: .line 310
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            invokevirtual java.security.spec.ECParameterSpec.getCurve:()Ljava/security/spec/EllipticCurve;
            invokevirtual java.security.spec.EllipticCurve.getSeed:()[B
        16: .line 305
            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 3 /* ecP */
        start local 3 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        17: .line 312
            new org.bouncycastle.asn1.x9.X962Parameters
            dup
            aload 3 /* ecP */
            invokespecial org.bouncycastle.asn1.x9.X962Parameters.<init>:(Lorg/bouncycastle/asn1/x9/X9ECParameters;)V
            astore 1 /* params */
        end local 3 // org.bouncycastle.asn1.x9.X9ECParameters ecP
        end local 2 // org.bouncycastle.math.ec.ECCurve curve
        start local 1 // org.bouncycastle.asn1.x9.X962Parameters params
        18: .line 318
      StackMap locals: org.bouncycastle.asn1.x9.X962Parameters
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.publicKey:Lorg/bouncycastle/asn1/DERBitString;
            ifnull 21
        19: .line 320
            new org.bouncycastle.asn1.sec.ECPrivateKeyStructure
            dup
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getS:()Ljava/math/BigInteger;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.publicKey:Lorg/bouncycastle/asn1/DERBitString;
            aload 1 /* params */
            invokespecial org.bouncycastle.asn1.sec.ECPrivateKeyStructure.<init>:(Ljava/math/BigInteger;Lorg/bouncycastle/asn1/DERBitString;Lorg/bouncycastle/asn1/ASN1Encodable;)V
            astore 3 /* keyStructure */
        start local 3 // org.bouncycastle.asn1.sec.ECPrivateKeyStructure keyStructure
        20: .line 321
            goto 22
        end local 3 // org.bouncycastle.asn1.sec.ECPrivateKeyStructure keyStructure
        21: .line 324
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.sec.ECPrivateKeyStructure
            dup
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getS:()Ljava/math/BigInteger;
            aload 1 /* params */
            invokespecial org.bouncycastle.asn1.sec.ECPrivateKeyStructure.<init>:(Ljava/math/BigInteger;Lorg/bouncycastle/asn1/ASN1Encodable;)V
            astore 3 /* keyStructure */
        start local 3 // org.bouncycastle.asn1.sec.ECPrivateKeyStructure keyStructure
        22: .line 327
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey org.bouncycastle.asn1.x9.X962Parameters top org.bouncycastle.asn1.sec.ECPrivateKeyStructure
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
            ldc "ECGOST3410"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 25
        23: .line 329
            new org.bouncycastle.asn1.pkcs.PrivateKeyInfo
            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.x9.X962Parameters.getDERObject:()Lorg/bouncycastle/asn1/DERObject;
            invokespecial org.bouncycastle.asn1.x509.AlgorithmIdentifier.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
            aload 3 /* keyStructure */
            invokevirtual org.bouncycastle.asn1.sec.ECPrivateKeyStructure.getDERObject:()Lorg/bouncycastle/asn1/DERObject;
            invokespecial org.bouncycastle.asn1.pkcs.PrivateKeyInfo.<init>:(Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;Lorg/bouncycastle/asn1/DERObject;)V
            astore 2 /* info */
        start local 2 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
        24: .line 330
            goto 26
        end local 2 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
        25: .line 334
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.pkcs.PrivateKeyInfo
            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.x9.X962Parameters.getDERObject:()Lorg/bouncycastle/asn1/DERObject;
            invokespecial org.bouncycastle.asn1.x509.AlgorithmIdentifier.<init>:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
            aload 3 /* keyStructure */
            invokevirtual org.bouncycastle.asn1.sec.ECPrivateKeyStructure.getDERObject:()Lorg/bouncycastle/asn1/DERObject;
            invokespecial org.bouncycastle.asn1.pkcs.PrivateKeyInfo.<init>:(Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;Lorg/bouncycastle/asn1/DERObject;)V
            astore 2 /* info */
        start local 2 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
        26: .line 337
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey org.bouncycastle.asn1.x9.X962Parameters org.bouncycastle.asn1.pkcs.PrivateKeyInfo org.bouncycastle.asn1.sec.ECPrivateKeyStructure
      StackMap stack:
            aload 2 /* info */
            invokevirtual org.bouncycastle.asn1.pkcs.PrivateKeyInfo.getDEREncoded:()[B
            areturn
        end local 3 // org.bouncycastle.asn1.sec.ECPrivateKeyStructure keyStructure
        end local 2 // org.bouncycastle.asn1.pkcs.PrivateKeyInfo info
        end local 1 // org.bouncycastle.asn1.x9.X962Parameters params
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   27     0          this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            5    6     1        params  Lorg/bouncycastle/asn1/x9/X962Parameters;
            8    9     1        params  Lorg/bouncycastle/asn1/x9/X962Parameters;
           18   27     1        params  Lorg/bouncycastle/asn1/x9/X962Parameters;
            2    5     2      curveOid  Lorg/bouncycastle/asn1/DERObjectIdentifier;
           10   18     2         curve  Lorg/bouncycastle/math/ec/ECCurve;
           17   18     3           ecP  Lorg/bouncycastle/asn1/x9/X9ECParameters;
           24   25     2          info  Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;
           26   27     2          info  Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;
           20   21     3  keyStructure  Lorg/bouncycastle/asn1/sec/ECPrivateKeyStructure;
           22   27     3  keyStructure  Lorg/bouncycastle/asn1/sec/ECPrivateKeyStructure;

  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.JCEECPrivateKey this
         0: .line 342
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  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.JCEECPrivateKey this
         0: .line 347
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            ifnonnull 2
         1: .line 349
            aconst_null
            areturn
         2: .line 352
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.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.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  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.JCEECPrivateKey this
         0: .line 357
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            ifnull 2
         1: .line 359
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.ecSpec:Ljava/security/spec/ECParameterSpec;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.withCompression:Z
            invokestatic org.bouncycastle.jce.provider.asymmetric.ec.EC5Util.convertSpec:(Ljava/security/spec/ECParameterSpec;Z)Lorg/bouncycastle/jce/spec/ECParameterSpec;
            areturn
         2: .line 362
      StackMap locals:
      StackMap stack:
            invokestatic org.bouncycastle.jce.provider.ProviderUtil.getEcImplicitlyCa:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  public java.math.BigInteger getS();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
         0: .line 367
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  public java.math.BigInteger getD();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
         0: .line 372
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.d:Ljava/math/BigInteger;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  public void setBagAttribute(org.bouncycastle.asn1.DERObjectIdentifier, org.bouncycastle.asn1.DEREncodable);
    descriptor: (Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // org.bouncycastle.asn1.DERObjectIdentifier oid
        start local 2 // org.bouncycastle.asn1.DEREncodable attribute
         0: .line 379
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
            aload 1 /* oid */
            aload 2 /* attribute */
            invokevirtual org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.setBagAttribute:(Lorg/bouncycastle/asn1/DERObjectIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
         1: .line 380
            return
        end local 2 // org.bouncycastle.asn1.DEREncodable attribute
        end local 1 // org.bouncycastle.asn1.DERObjectIdentifier oid
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    2     1        oid  Lorg/bouncycastle/asn1/DERObjectIdentifier;
            0    2     2  attribute  Lorg/bouncycastle/asn1/DEREncodable;
    MethodParameters:
           Name  Flags
      oid        
      attribute  

  public org.bouncycastle.asn1.DEREncodable getBagAttribute(org.bouncycastle.asn1.DERObjectIdentifier);
    descriptor: (Lorg/bouncycastle/asn1/DERObjectIdentifier;)Lorg/bouncycastle/asn1/DEREncodable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // org.bouncycastle.asn1.DERObjectIdentifier oid
         0: .line 385
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
            aload 1 /* oid */
            invokevirtual org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.getBagAttribute:(Lorg/bouncycastle/asn1/DERObjectIdentifier;)Lorg/bouncycastle/asn1/DEREncodable;
            areturn
        end local 1 // org.bouncycastle.asn1.DERObjectIdentifier oid
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    1     1   oid  Lorg/bouncycastle/asn1/DERObjectIdentifier;
    MethodParameters:
      Name  Flags
      oid   

  public java.util.Enumeration getBagAttributeKeys();
    descriptor: ()Ljava/util/Enumeration;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
         0: .line 390
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
            invokevirtual org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.getBagAttributeKeys:()Ljava/util/Enumeration;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  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.JCEECPrivateKey this
        start local 1 // java.lang.String style
         0: .line 395
            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.JCEECPrivateKey
         1: iconst_1
      StackMap locals: org.bouncycastle.jce.provider.JCEECPrivateKey java.lang.String
      StackMap stack: org.bouncycastle.jce.provider.JCEECPrivateKey int
         2: putfield org.bouncycastle.jce.provider.JCEECPrivateKey.withCompression:Z
         3: .line 396
            return
        end local 1 // java.lang.String style
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            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.JCEECPrivateKey this
        start local 1 // java.lang.Object o
         0: .line 400
            aload 1 /* o */
            instanceof org.bouncycastle.jce.provider.JCEECPrivateKey
            ifne 2
         1: .line 402
            iconst_0
            ireturn
         2: .line 405
      StackMap locals:
      StackMap stack:
            aload 1 /* o */
            checkcast org.bouncycastle.jce.provider.JCEECPrivateKey
            astore 2 /* other */
        start local 2 // org.bouncycastle.jce.provider.JCEECPrivateKey other
         3: .line 407
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getD:()Ljava/math/BigInteger;
            aload 2 /* other */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getD:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.equals:(Ljava/lang/Object;)Z
            ifeq 4
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.engineGetSpec:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            aload 2 /* other */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.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.JCEECPrivateKey
      StackMap stack:
         4: iconst_0
            ireturn
        end local 2 // org.bouncycastle.jce.provider.JCEECPrivateKey other
        end local 1 // java.lang.Object o
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    5     0   this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    5     1      o  Ljava/lang/Object;
            3    5     2  other  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
    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.JCEECPrivateKey this
         0: .line 412
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getD:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.hashCode:()I
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.engineGetSpec:()Lorg/bouncycastle/jce/spec/ECParameterSpec;
            invokevirtual org.bouncycastle.jce.spec.ECParameterSpec.hashCode:()I
            ixor
            ireturn
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;

  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.JCEECPrivateKey this
         0: .line 417
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 1 /* buf */
        start local 1 // java.lang.StringBuffer buf
         1: .line 418
            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 420
            aload 1 /* buf */
            ldc "EC Private 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 421
            aload 1 /* buf */
            ldc "             S: "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.d: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 423
            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.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            1    5     1   buf  Ljava/lang/StringBuffer;
            2    5     2    nl  Ljava/lang/String;

  private org.bouncycastle.asn1.DERBitString getPublicKeyDetails(org.bouncycastle.jce.provider.JCEECPublicKey);
    descriptor: (Lorg/bouncycastle/jce/provider/JCEECPublicKey;)Lorg/bouncycastle/asn1/DERBitString;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // org.bouncycastle.jce.provider.JCEECPublicKey pub
         0: .line 431
            aload 1 /* pub */
            invokevirtual org.bouncycastle.jce.provider.JCEECPublicKey.getEncoded:()[B
            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;
            astore 2 /* info */
        start local 2 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
         1: .line 433
            aload 2 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getPublicKeyData:()Lorg/bouncycastle/asn1/DERBitString;
         2: areturn
        end local 2 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
         3: .line 435
      StackMap locals:
      StackMap stack: java.io.IOException
            pop
         4: .line 437
            aconst_null
            areturn
        end local 1 // org.bouncycastle.jce.provider.JCEECPublicKey pub
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    5     1   pub  Lorg/bouncycastle/jce/provider/JCEECPublicKey;
            1    3     2  info  Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
      Exception table:
        from    to  target  type
           0     2       3  Class java.io.IOException
    MethodParameters:
      Name  Flags
      pub   

  private void readObject(java.io.ObjectInputStream);
    descriptor: (Ljava/io/ObjectInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
        start local 1 // java.io.ObjectInputStream in
         0: .line 445
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            checkcast byte[]
            astore 2 /* enc */
        start local 2 // byte[] enc
         1: .line 447
            aload 0 /* this */
            aload 2 /* enc */
            invokestatic org.bouncycastle.asn1.ASN1Object.fromByteArray:([B)Lorg/bouncycastle/asn1/ASN1Object;
            invokestatic org.bouncycastle.asn1.pkcs.PrivateKeyInfo.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.populateFromPrivKeyInfo:(Lorg/bouncycastle/asn1/pkcs/PrivateKeyInfo;)V
         2: .line 449
            aload 0 /* this */
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            checkcast java.lang.String
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
         3: .line 450
            aload 0 /* this */
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readBoolean:()Z
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.withCompression:Z
         4: .line 451
            aload 0 /* this */
            new org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl
            dup
            invokespecial org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.<init>:()V
            putfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
         5: .line 453
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
            aload 1 /* in */
            invokevirtual org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.readObject:(Ljava/io/ObjectInputStream;)V
         6: .line 454
            return
        end local 2 // byte[] enc
        end local 1 // java.io.ObjectInputStream in
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    7     1    in  Ljava/io/ObjectInputStream;
            1    7     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.JCEECPrivateKey this
        start local 1 // java.io.ObjectOutputStream out
         0: .line 460
            aload 1 /* out */
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEECPrivateKey.getEncoded:()[B
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         1: .line 461
            aload 1 /* out */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.algorithm:Ljava/lang/String;
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         2: .line 462
            aload 1 /* out */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.withCompression:Z
            invokevirtual java.io.ObjectOutputStream.writeBoolean:(Z)V
         3: .line 464
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEECPrivateKey.attrCarrier:Lorg/bouncycastle/jce/provider/PKCS12BagAttributeCarrierImpl;
            aload 1 /* out */
            invokevirtual org.bouncycastle.jce.provider.PKCS12BagAttributeCarrierImpl.writeObject:(Ljava/io/ObjectOutputStream;)V
         4: .line 465
            return
        end local 1 // java.io.ObjectOutputStream out
        end local 0 // org.bouncycastle.jce.provider.JCEECPrivateKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/jce/provider/JCEECPrivateKey;
            0    5     1   out  Ljava/io/ObjectOutputStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      out   
}
SourceFile: "JCEECPrivateKey.java"