public class org.bouncycastle.jce.provider.JCEDHPublicKey implements javax.crypto.interfaces.DHPublicKey
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.bouncycastle.jce.provider.JCEDHPublicKey
  super_class: java.lang.Object
{
  static final long serialVersionUID;
    descriptor: J
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: -216691575254424324

  private java.math.BigInteger y;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0002) ACC_PRIVATE

  private javax.crypto.spec.DHParameterSpec dhSpec;
    descriptor: Ljavax/crypto/spec/DHParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  private org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info;
    descriptor: Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
    flags: (0x0002) ACC_PRIVATE

  void <init>(javax.crypto.spec.DHPublicKeySpec);
    descriptor: (Ljavax/crypto/spec/DHPublicKeySpec;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
        start local 1 // javax.crypto.spec.DHPublicKeySpec spec
         0: .line 32
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 35
            aload 0 /* this */
            aload 1 /* spec */
            invokevirtual javax.crypto.spec.DHPublicKeySpec.getY:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.y:Ljava/math/BigInteger;
         2: .line 36
            aload 0 /* this */
            new javax.crypto.spec.DHParameterSpec
            dup
            aload 1 /* spec */
            invokevirtual javax.crypto.spec.DHPublicKeySpec.getP:()Ljava/math/BigInteger;
            aload 1 /* spec */
            invokevirtual javax.crypto.spec.DHPublicKeySpec.getG:()Ljava/math/BigInteger;
            invokespecial javax.crypto.spec.DHParameterSpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
         3: .line 37
            return
        end local 1 // javax.crypto.spec.DHPublicKeySpec spec
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0    4     1  spec  Ljavax/crypto/spec/DHPublicKeySpec;
    MethodParameters:
      Name  Flags
      spec  

  void <init>(javax.crypto.interfaces.DHPublicKey);
    descriptor: (Ljavax/crypto/interfaces/DHPublicKey;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
        start local 1 // javax.crypto.interfaces.DHPublicKey key
         0: .line 39
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 42
            aload 0 /* this */
            aload 1 /* key */
            invokeinterface javax.crypto.interfaces.DHPublicKey.getY:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.y:Ljava/math/BigInteger;
         2: .line 43
            aload 0 /* this */
            aload 1 /* key */
            invokeinterface javax.crypto.interfaces.DHPublicKey.getParams:()Ljavax/crypto/spec/DHParameterSpec;
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
         3: .line 44
            return
        end local 1 // javax.crypto.interfaces.DHPublicKey key
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0    4     1   key  Ljavax/crypto/interfaces/DHPublicKey;
    MethodParameters:
      Name  Flags
      key   

  void <init>(org.bouncycastle.crypto.params.DHPublicKeyParameters);
    descriptor: (Lorg/bouncycastle/crypto/params/DHPublicKeyParameters;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
        start local 1 // org.bouncycastle.crypto.params.DHPublicKeyParameters params
         0: .line 46
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 49
            aload 0 /* this */
            aload 1 /* params */
            invokevirtual org.bouncycastle.crypto.params.DHPublicKeyParameters.getY:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.y:Ljava/math/BigInteger;
         2: .line 50
            aload 0 /* this */
            new javax.crypto.spec.DHParameterSpec
            dup
            aload 1 /* params */
            invokevirtual org.bouncycastle.crypto.params.DHPublicKeyParameters.getParameters:()Lorg/bouncycastle/crypto/params/DHParameters;
            invokevirtual org.bouncycastle.crypto.params.DHParameters.getP:()Ljava/math/BigInteger;
            aload 1 /* params */
            invokevirtual org.bouncycastle.crypto.params.DHPublicKeyParameters.getParameters:()Lorg/bouncycastle/crypto/params/DHParameters;
            invokevirtual org.bouncycastle.crypto.params.DHParameters.getG:()Ljava/math/BigInteger;
            aload 1 /* params */
            invokevirtual org.bouncycastle.crypto.params.DHPublicKeyParameters.getParameters:()Lorg/bouncycastle/crypto/params/DHParameters;
            invokevirtual org.bouncycastle.crypto.params.DHParameters.getL:()I
            invokespecial javax.crypto.spec.DHParameterSpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;I)V
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
         3: .line 51
            return
        end local 1 // org.bouncycastle.crypto.params.DHPublicKeyParameters params
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0    4     1  params  Lorg/bouncycastle/crypto/params/DHPublicKeyParameters;
    MethodParameters:
        Name  Flags
      params  

  void <init>(java.math.BigInteger, javax.crypto.spec.DHParameterSpec);
    descriptor: (Ljava/math/BigInteger;Ljavax/crypto/spec/DHParameterSpec;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
        start local 1 // java.math.BigInteger y
        start local 2 // javax.crypto.spec.DHParameterSpec dhSpec
         0: .line 53
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 57
            aload 0 /* this */
            aload 1 /* y */
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.y:Ljava/math/BigInteger;
         2: .line 58
            aload 0 /* this */
            aload 2 /* dhSpec */
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
         3: .line 59
            return
        end local 2 // javax.crypto.spec.DHParameterSpec dhSpec
        end local 1 // java.math.BigInteger y
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0    4     1       y  Ljava/math/BigInteger;
            0    4     2  dhSpec  Ljavax/crypto/spec/DHParameterSpec;
    MethodParameters:
        Name  Flags
      y       
      dhSpec  

  void <init>(org.bouncycastle.asn1.x509.SubjectPublicKeyInfo);
    descriptor: (Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=6, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
        start local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
         0: .line 61
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 64
            aload 0 /* this */
            aload 1 /* info */
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.info:Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
         2: .line 69
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getPublicKey:()Lorg/bouncycastle/asn1/DERObject;
            checkcast org.bouncycastle.asn1.DERInteger
            astore 2 /* derY */
        start local 2 // org.bouncycastle.asn1.DERInteger derY
         3: .line 70
            goto 6
        end local 2 // org.bouncycastle.asn1.DERInteger derY
         4: .line 71
      StackMap locals: org.bouncycastle.jce.provider.JCEDHPublicKey org.bouncycastle.asn1.x509.SubjectPublicKeyInfo
      StackMap stack: java.io.IOException
            pop
         5: .line 73
            new java.lang.IllegalArgumentException
            dup
            ldc "invalid info structure in DH public key"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        start local 2 // org.bouncycastle.asn1.DERInteger derY
         6: .line 76
      StackMap locals: org.bouncycastle.asn1.DERInteger
      StackMap stack:
            aload 0 /* this */
            aload 2 /* derY */
            invokevirtual org.bouncycastle.asn1.DERInteger.getValue:()Ljava/math/BigInteger;
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.y:Ljava/math/BigInteger;
         7: .line 78
            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;
            invokestatic org.bouncycastle.asn1.ASN1Sequence.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/ASN1Sequence;
            astore 3 /* seq */
        start local 3 // org.bouncycastle.asn1.ASN1Sequence seq
         8: .line 79
            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;
            astore 4 /* id */
        start local 4 // org.bouncycastle.asn1.DERObjectIdentifier id
         9: .line 82
            aload 4 /* id */
            getstatic org.bouncycastle.asn1.pkcs.PKCSObjectIdentifiers.dhKeyAgreement:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.DERObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifne 10
            aload 0 /* this */
            aload 3 /* seq */
            invokevirtual org.bouncycastle.jce.provider.JCEDHPublicKey.isPKCSParam:(Lorg/bouncycastle/asn1/ASN1Sequence;)Z
            ifeq 16
        10: .line 84
      StackMap locals: org.bouncycastle.asn1.ASN1Sequence org.bouncycastle.asn1.DERObjectIdentifier
      StackMap stack:
            new org.bouncycastle.asn1.pkcs.DHParameter
            dup
            aload 3 /* seq */
            invokespecial org.bouncycastle.asn1.pkcs.DHParameter.<init>:(Lorg/bouncycastle/asn1/ASN1Sequence;)V
            astore 5 /* params */
        start local 5 // org.bouncycastle.asn1.pkcs.DHParameter params
        11: .line 86
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.pkcs.DHParameter.getL:()Ljava/math/BigInteger;
            ifnull 14
        12: .line 88
            aload 0 /* this */
            new javax.crypto.spec.DHParameterSpec
            dup
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.pkcs.DHParameter.getP:()Ljava/math/BigInteger;
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.pkcs.DHParameter.getG:()Ljava/math/BigInteger;
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.pkcs.DHParameter.getL:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.intValue:()I
            invokespecial javax.crypto.spec.DHParameterSpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;I)V
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
        13: .line 89
            goto 21
        14: .line 92
      StackMap locals: org.bouncycastle.asn1.pkcs.DHParameter
      StackMap stack:
            aload 0 /* this */
            new javax.crypto.spec.DHParameterSpec
            dup
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.pkcs.DHParameter.getP:()Ljava/math/BigInteger;
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.pkcs.DHParameter.getG:()Ljava/math/BigInteger;
            invokespecial javax.crypto.spec.DHParameterSpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
        end local 5 // org.bouncycastle.asn1.pkcs.DHParameter params
        15: .line 94
            goto 21
        16: .line 95
      StackMap locals:
      StackMap stack:
            aload 4 /* id */
            getstatic org.bouncycastle.asn1.x9.X9ObjectIdentifiers.dhpublicnumber:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            invokevirtual org.bouncycastle.asn1.DERObjectIdentifier.equals:(Ljava/lang/Object;)Z
            ifeq 20
        17: .line 97
            aload 3 /* seq */
            invokestatic org.bouncycastle.asn1.x9.DHDomainParameters.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/x9/DHDomainParameters;
            astore 5 /* params */
        start local 5 // org.bouncycastle.asn1.x9.DHDomainParameters params
        18: .line 99
            aload 0 /* this */
            new javax.crypto.spec.DHParameterSpec
            dup
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.x9.DHDomainParameters.getP:()Lorg/bouncycastle/asn1/DERInteger;
            invokevirtual org.bouncycastle.asn1.DERInteger.getValue:()Ljava/math/BigInteger;
            aload 5 /* params */
            invokevirtual org.bouncycastle.asn1.x9.DHDomainParameters.getG:()Lorg/bouncycastle/asn1/DERInteger;
            invokevirtual org.bouncycastle.asn1.DERInteger.getValue:()Ljava/math/BigInteger;
            invokespecial javax.crypto.spec.DHParameterSpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
        end local 5 // org.bouncycastle.asn1.x9.DHDomainParameters params
        19: .line 100
            goto 21
        20: .line 103
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unknown algorithm type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* id */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 105
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.bouncycastle.asn1.DERObjectIdentifier id
        end local 3 // org.bouncycastle.asn1.ASN1Sequence seq
        end local 2 // org.bouncycastle.asn1.DERInteger derY
        end local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   22     0    this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0   22     1    info  Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
            3    4     2    derY  Lorg/bouncycastle/asn1/DERInteger;
            6   22     2    derY  Lorg/bouncycastle/asn1/DERInteger;
            8   22     3     seq  Lorg/bouncycastle/asn1/ASN1Sequence;
            9   22     4      id  Lorg/bouncycastle/asn1/DERObjectIdentifier;
           11   15     5  params  Lorg/bouncycastle/asn1/pkcs/DHParameter;
           18   19     5  params  Lorg/bouncycastle/asn1/x9/DHDomainParameters;
      Exception table:
        from    to  target  type
           2     3       4  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.JCEDHPublicKey this
         0: .line 109
            ldc "DH"
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;

  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.JCEDHPublicKey this
         0: .line 114
            ldc "X.509"
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=2, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
         0: .line 119
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.info:Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
            ifnull 2
         1: .line 121
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.info:Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getDEREncoded:()[B
            areturn
         2: .line 124
      StackMap locals:
      StackMap stack:
            new org.bouncycastle.asn1.x509.SubjectPublicKeyInfo
            dup
            new org.bouncycastle.asn1.x509.AlgorithmIdentifier
            dup
            getstatic org.bouncycastle.asn1.pkcs.PKCSObjectIdentifiers.dhKeyAgreement:Lorg/bouncycastle/asn1/ASN1ObjectIdentifier;
            new org.bouncycastle.asn1.pkcs.DHParameter
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
            invokevirtual javax.crypto.spec.DHParameterSpec.getP:()Ljava/math/BigInteger;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
            invokevirtual javax.crypto.spec.DHParameterSpec.getG:()Ljava/math/BigInteger;
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
            invokevirtual javax.crypto.spec.DHParameterSpec.getL:()I
            invokespecial org.bouncycastle.asn1.pkcs.DHParameter.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;I)V
            invokevirtual org.bouncycastle.asn1.pkcs.DHParameter.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.DERInteger
            dup
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.y:Ljava/math/BigInteger;
            invokespecial org.bouncycastle.asn1.DERInteger.<init>:(Ljava/math/BigInteger;)V
            invokespecial org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.<init>:(Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;Lorg/bouncycastle/asn1/DEREncodable;)V
            astore 1 /* info */
        start local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
         3: .line 126
            aload 1 /* info */
            invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getDEREncoded:()[B
            areturn
        end local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo info
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            3    4     1  info  Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;

  public javax.crypto.spec.DHParameterSpec getParams();
    descriptor: ()Ljavax/crypto/spec/DHParameterSpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
         0: .line 131
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
            areturn
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;

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

  private boolean isPKCSParam(org.bouncycastle.asn1.ASN1Sequence);
    descriptor: (Lorg/bouncycastle/asn1/ASN1Sequence;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
        start local 1 // org.bouncycastle.asn1.ASN1Sequence seq
         0: .line 141
            aload 1 /* seq */
            invokevirtual org.bouncycastle.asn1.ASN1Sequence.size:()I
            iconst_2
            if_icmpne 2
         1: .line 143
            iconst_1
            ireturn
         2: .line 146
      StackMap locals:
      StackMap stack:
            aload 1 /* seq */
            invokevirtual org.bouncycastle.asn1.ASN1Sequence.size:()I
            iconst_3
            if_icmple 4
         3: .line 148
            iconst_0
            ireturn
         4: .line 151
      StackMap locals:
      StackMap stack:
            aload 1 /* seq */
            iconst_2
            invokevirtual org.bouncycastle.asn1.ASN1Sequence.getObjectAt:(I)Lorg/bouncycastle/asn1/DEREncodable;
            invokestatic org.bouncycastle.asn1.DERInteger.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/DERInteger;
            astore 2 /* l */
        start local 2 // org.bouncycastle.asn1.DERInteger l
         5: .line 152
            aload 1 /* seq */
            iconst_0
            invokevirtual org.bouncycastle.asn1.ASN1Sequence.getObjectAt:(I)Lorg/bouncycastle/asn1/DEREncodable;
            invokestatic org.bouncycastle.asn1.DERInteger.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/DERInteger;
            astore 3 /* p */
        start local 3 // org.bouncycastle.asn1.DERInteger p
         6: .line 154
            aload 2 /* l */
            invokevirtual org.bouncycastle.asn1.DERInteger.getValue:()Ljava/math/BigInteger;
            aload 3 /* p */
            invokevirtual org.bouncycastle.asn1.DERInteger.getValue:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            i2l
            invokestatic java.math.BigInteger.valueOf:(J)Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
            ifle 8
         7: .line 156
            iconst_0
            ireturn
         8: .line 159
      StackMap locals: org.bouncycastle.asn1.DERInteger org.bouncycastle.asn1.DERInteger
      StackMap stack:
            iconst_1
            ireturn
        end local 3 // org.bouncycastle.asn1.DERInteger p
        end local 2 // org.bouncycastle.asn1.DERInteger l
        end local 1 // org.bouncycastle.asn1.ASN1Sequence seq
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0    9     1   seq  Lorg/bouncycastle/asn1/ASN1Sequence;
            5    9     2     l  Lorg/bouncycastle/asn1/DERInteger;
            6    9     3     p  Lorg/bouncycastle/asn1/DERInteger;
    MethodParameters:
      Name  Flags
      seq   

  private void readObject(java.io.ObjectInputStream);
    descriptor: (Ljava/io/ObjectInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
        start local 1 // java.io.ObjectInputStream in
         0: .line 166
            aload 0 /* this */
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            checkcast java.math.BigInteger
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.y:Ljava/math/BigInteger;
         1: .line 167
            aload 0 /* this */
            new javax.crypto.spec.DHParameterSpec
            dup
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            checkcast java.math.BigInteger
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readObject:()Ljava/lang/Object;
            checkcast java.math.BigInteger
            aload 1 /* in */
            invokevirtual java.io.ObjectInputStream.readInt:()I
            invokespecial javax.crypto.spec.DHParameterSpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;I)V
            putfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
         2: .line 168
            return
        end local 1 // java.io.ObjectInputStream in
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0    3     1    in  Ljava/io/ObjectInputStream;
    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.JCEDHPublicKey this
        start local 1 // java.io.ObjectOutputStream out
         0: .line 174
            aload 1 /* out */
            aload 0 /* this */
            invokevirtual org.bouncycastle.jce.provider.JCEDHPublicKey.getY:()Ljava/math/BigInteger;
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         1: .line 175
            aload 1 /* out */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
            invokevirtual javax.crypto.spec.DHParameterSpec.getP:()Ljava/math/BigInteger;
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         2: .line 176
            aload 1 /* out */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
            invokevirtual javax.crypto.spec.DHParameterSpec.getG:()Ljava/math/BigInteger;
            invokevirtual java.io.ObjectOutputStream.writeObject:(Ljava/lang/Object;)V
         3: .line 177
            aload 1 /* out */
            aload 0 /* this */
            getfield org.bouncycastle.jce.provider.JCEDHPublicKey.dhSpec:Ljavax/crypto/spec/DHParameterSpec;
            invokevirtual javax.crypto.spec.DHParameterSpec.getL:()I
            invokevirtual java.io.ObjectOutputStream.writeInt:(I)V
         4: .line 178
            return
        end local 1 // java.io.ObjectOutputStream out
        end local 0 // org.bouncycastle.jce.provider.JCEDHPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/bouncycastle/jce/provider/JCEDHPublicKey;
            0    5     1   out  Ljava/io/ObjectOutputStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      out   
}
SourceFile: "JCEDHPublicKey.java"