class org.bouncycastle.crypto.util.PublicKeyFactory$DSAConverter extends org.bouncycastle.crypto.util.PublicKeyFactory$SubjectPublicKeyInfoConverter
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: org.bouncycastle.crypto.util.PublicKeyFactory$DSAConverter
super_class: org.bouncycastle.crypto.util.PublicKeyFactory$SubjectPublicKeyInfoConverter
{
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 // org.bouncycastle.crypto.util.PublicKeyFactory$DSAConverter this
0: .line 246
aload 0 /* this */
invokespecial org.bouncycastle.crypto.util.PublicKeyFactory$SubjectPublicKeyInfoConverter.<init>:()V
return
end local 0 // org.bouncycastle.crypto.util.PublicKeyFactory$DSAConverter this
LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/bouncycastle/crypto/util/PublicKeyFactory$DSAConverter;
org.bouncycastle.crypto.params.AsymmetricKeyParameter getPublicKeyParameters(org.bouncycastle.asn1.x509.SubjectPublicKeyInfo, java.lang.Object);
descriptor: (Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;Ljava/lang/Object;)Lorg/bouncycastle/crypto/params/AsymmetricKeyParameter;
flags: (0x0000)
Code:
stack=5, locals=7, args_size=3
start local 0 // org.bouncycastle.crypto.util.PublicKeyFactory$DSAConverter this
start local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo keyInfo
start local 2 // java.lang.Object defaultParams
0: .line 252
aload 1 /* keyInfo */
invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.parsePublicKey:()Lorg/bouncycastle/asn1/ASN1Primitive;
checkcast org.bouncycastle.asn1.ASN1Integer
astore 3 /* derY */
start local 3 // org.bouncycastle.asn1.ASN1Integer derY
1: .line 253
aload 1 /* keyInfo */
invokevirtual org.bouncycastle.asn1.x509.SubjectPublicKeyInfo.getAlgorithm:()Lorg/bouncycastle/asn1/x509/AlgorithmIdentifier;
invokevirtual org.bouncycastle.asn1.x509.AlgorithmIdentifier.getParameters:()Lorg/bouncycastle/asn1/ASN1Encodable;
astore 4 /* de */
start local 4 // org.bouncycastle.asn1.ASN1Encodable de
2: .line 255
aconst_null
astore 5 /* parameters */
start local 5 // org.bouncycastle.crypto.params.DSAParameters parameters
3: .line 256
aload 4 /* de */
ifnull 6
4: .line 258
aload 4 /* de */
invokeinterface org.bouncycastle.asn1.ASN1Encodable.toASN1Primitive:()Lorg/bouncycastle/asn1/ASN1Primitive;
invokestatic org.bouncycastle.asn1.x509.DSAParameter.getInstance:(Ljava/lang/Object;)Lorg/bouncycastle/asn1/x509/DSAParameter;
astore 6 /* params */
start local 6 // org.bouncycastle.asn1.x509.DSAParameter params
5: .line 259
new org.bouncycastle.crypto.params.DSAParameters
dup
aload 6 /* params */
invokevirtual org.bouncycastle.asn1.x509.DSAParameter.getP:()Ljava/math/BigInteger;
aload 6 /* params */
invokevirtual org.bouncycastle.asn1.x509.DSAParameter.getQ:()Ljava/math/BigInteger;
aload 6 /* params */
invokevirtual org.bouncycastle.asn1.x509.DSAParameter.getG:()Ljava/math/BigInteger;
invokespecial org.bouncycastle.crypto.params.DSAParameters.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
astore 5 /* parameters */
end local 6 // org.bouncycastle.asn1.x509.DSAParameter params
6: .line 262
StackMap locals: org.bouncycastle.asn1.ASN1Integer org.bouncycastle.asn1.ASN1Encodable org.bouncycastle.crypto.params.DSAParameters
StackMap stack:
new org.bouncycastle.crypto.params.DSAPublicKeyParameters
dup
aload 3 /* derY */
invokevirtual org.bouncycastle.asn1.ASN1Integer.getValue:()Ljava/math/BigInteger;
aload 5 /* parameters */
invokespecial org.bouncycastle.crypto.params.DSAPublicKeyParameters.<init>:(Ljava/math/BigInteger;Lorg/bouncycastle/crypto/params/DSAParameters;)V
areturn
end local 5 // org.bouncycastle.crypto.params.DSAParameters parameters
end local 4 // org.bouncycastle.asn1.ASN1Encodable de
end local 3 // org.bouncycastle.asn1.ASN1Integer derY
end local 2 // java.lang.Object defaultParams
end local 1 // org.bouncycastle.asn1.x509.SubjectPublicKeyInfo keyInfo
end local 0 // org.bouncycastle.crypto.util.PublicKeyFactory$DSAConverter this
LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/bouncycastle/crypto/util/PublicKeyFactory$DSAConverter;
0 7 1 keyInfo Lorg/bouncycastle/asn1/x509/SubjectPublicKeyInfo;
0 7 2 defaultParams Ljava/lang/Object;
1 7 3 derY Lorg/bouncycastle/asn1/ASN1Integer;
2 7 4 de Lorg/bouncycastle/asn1/ASN1Encodable;
3 7 5 parameters Lorg/bouncycastle/crypto/params/DSAParameters;
5 6 6 params Lorg/bouncycastle/asn1/x509/DSAParameter;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
keyInfo
defaultParams
}
SourceFile: "PublicKeyFactory.java"
NestHost: org.bouncycastle.crypto.util.PublicKeyFactory
InnerClasses:
private DSAConverter = org.bouncycastle.crypto.util.PublicKeyFactory$DSAConverter of org.bouncycastle.crypto.util.PublicKeyFactory
private abstract SubjectPublicKeyInfoConverter = org.bouncycastle.crypto.util.PublicKeyFactory$SubjectPublicKeyInfoConverter of org.bouncycastle.crypto.util.PublicKeyFactory