RainbowPublicKey.smali
.class public Lorg/spongycastle/pqc/asn1/RainbowPublicKey;
.super Lorg/spongycastle/asn1/ASN1Object;
.source "RainbowPublicKey.java"
# instance fields
.field private coeffQuadratic:[[B
.field private coeffScalar:[B
.field private coeffSingular:[[B
.field private docLength:Lorg/spongycastle/asn1/ASN1Integer;
.field private oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.field private version:Lorg/spongycastle/asn1/ASN1Integer;
# direct methods
.method public constructor <init>(I[[S[[S[S)V
.registers 9
.prologue
.line 74
invoke-direct {p0}, Lorg/spongycastle/asn1/ASN1Object;-><init>()V
.line 75
new-instance v0, Lorg/spongycastle/asn1/ASN1Integer;
const-wide/16 v2, 0x0
invoke-direct {v0, v2, v3}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(J)V
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
.line 76
new-instance v0, Lorg/spongycastle/asn1/ASN1Integer;
int-to-long v2, p1
invoke-direct {v0, v2, v3}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(J)V
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->docLength:Lorg/spongycastle/asn1/ASN1Integer;
.line 77
invoke-static {p2}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[S)[[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffQuadratic:[[B
.line 78
invoke-static {p3}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[S)[[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffSingular:[[B
.line 79
invoke-static {p4}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([S)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffScalar:[B
.line 80
return-void
.end method
.method private constructor <init>(Lorg/spongycastle/asn1/ASN1Sequence;)V
.registers 7
.prologue
const/4 v1, 0x0
.line 42
invoke-direct {p0}, Lorg/spongycastle/asn1/ASN1Object;-><init>()V
.line 44
invoke-virtual {p1, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
instance-of v0, v0, Lorg/spongycastle/asn1/ASN1Integer;
if-eqz v0, :cond_4c
.line 46
invoke-virtual {p1, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/asn1/ASN1Integer;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1Integer;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
.line 53
:goto_16
const/4 v0, 0x1
invoke-virtual {p1, v0}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/asn1/ASN1Integer;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1Integer;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->docLength:Lorg/spongycastle/asn1/ASN1Integer;
.line 55
const/4 v0, 0x2
invoke-virtual {p1, v0}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1Sequence;
move-result-object v2
.line 56
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v0
new-array v0, v0, [[B
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffQuadratic:[[B
move v0, v1
.line 57
:goto_33
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
if-ge v0, v3, :cond_57
.line 59
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffQuadratic:[[B
invoke-virtual {v2, v0}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v4
invoke-static {v4}, Lorg/spongycastle/asn1/ASN1OctetString;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1OctetString;
move-result-object v4
invoke-virtual {v4}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v4
aput-object v4, v3, v0
.line 57
add-int/lit8 v0, v0, 0x1
goto :goto_33
.line 50
:cond_4c
invoke-virtual {p1, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/asn1/ASN1ObjectIdentifier;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
goto :goto_16
.line 62
:cond_57
const/4 v0, 0x3
invoke-virtual {p1, v0}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1Sequence;
.line 63
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v2
new-array v2, v2, [[B
iput-object v2, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffSingular:[[B
move v2, v1
.line 64
:goto_67
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
if-ge v2, v3, :cond_80
.line 66
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffSingular:[[B
invoke-virtual {v0, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v4
invoke-static {v4}, Lorg/spongycastle/asn1/ASN1OctetString;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1OctetString;
move-result-object v4
invoke-virtual {v4}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v4
aput-object v4, v3, v2
.line 64
add-int/lit8 v2, v2, 0x1
goto :goto_67
.line 69
:cond_80
const/4 v0, 0x4
invoke-virtual {p1, v0}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1Sequence;
.line 70
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
invoke-static {v0}, Lorg/spongycastle/asn1/ASN1OctetString;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1OctetString;
move-result-object v0
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffScalar:[B
.line 71
return-void
.end method
.method public static getInstance(Ljava/lang/Object;)Lorg/spongycastle/pqc/asn1/RainbowPublicKey;
.registers 3
.prologue
.line 84
instance-of v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;
if-eqz v0, :cond_7
.line 86
check-cast p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;
.line 93
:goto_6
return-object p0
.line 88
:cond_7
if-eqz p0, :cond_14
.line 90
new-instance v0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;
invoke-static {p0}, Lorg/spongycastle/asn1/ASN1Sequence;->getInstance(Ljava/lang/Object;)Lorg/spongycastle/asn1/ASN1Sequence;
move-result-object v1
invoke-direct {v0, v1}, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;-><init>(Lorg/spongycastle/asn1/ASN1Sequence;)V
move-object p0, v0
goto :goto_6
.line 93
:cond_14
const/4 p0, 0x0
goto :goto_6
.end method
# virtual methods
.method public getCoeffQuadratic()[[S
.registers 2
.prologue
.line 114
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffQuadratic:[[B
invoke-static {v0}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[B)[[S
move-result-object v0
return-object v0
.end method
.method public getCoeffScalar()[S
.registers 2
.prologue
.line 130
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffScalar:[B
invoke-static {v0}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([B)[S
move-result-object v0
return-object v0
.end method
.method public getCoeffSingular()[[S
.registers 2
.prologue
.line 122
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffSingular:[[B
invoke-static {v0}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[B)[[S
move-result-object v0
return-object v0
.end method
.method public getDocLength()I
.registers 2
.prologue
.line 106
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->docLength:Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {v0}, Ljava/math/BigInteger;->intValue()I
move-result v0
return v0
.end method
.method public getVersion()Lorg/spongycastle/asn1/ASN1Integer;
.registers 2
.prologue
.line 98
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
return-object v0
.end method
.method public toASN1Primitive()Lorg/spongycastle/asn1/ASN1Primitive;
.registers 7
.prologue
const/4 v1, 0x0
.line 135
new-instance v2, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 138
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
if-eqz v0, :cond_2e
.line 140
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v2, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 148
:goto_f
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->docLength:Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v2, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 151
new-instance v3, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v3}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v0, v1
.line 152
:goto_1a
iget-object v4, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffQuadratic:[[B
array-length v4, v4
if-ge v0, v4, :cond_34
.line 154
new-instance v4, Lorg/spongycastle/asn1/DEROctetString;
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffQuadratic:[[B
aget-object v5, v5, v0
invoke-direct {v4, v5}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v3, v4}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 152
add-int/lit8 v0, v0, 0x1
goto :goto_1a
.line 144
:cond_2e
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
invoke-virtual {v2, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
goto :goto_f
.line 156
:cond_34
new-instance v0, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v0, v3}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v2, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 159
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 160
:goto_41
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffSingular:[[B
array-length v3, v3
if-ge v1, v3, :cond_55
.line 162
new-instance v3, Lorg/spongycastle/asn1/DEROctetString;
iget-object v4, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffSingular:[[B
aget-object v4, v4, v1
invoke-direct {v3, v4}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v0, v3}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 160
add-int/lit8 v1, v1, 0x1
goto :goto_41
.line 164
:cond_55
new-instance v1, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v1, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v2, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 167
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 168
new-instance v1, Lorg/spongycastle/asn1/DEROctetString;
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPublicKey;->coeffScalar:[B
invoke-direct {v1, v3}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 169
new-instance v1, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v1, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v2, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 172
new-instance v0, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v0, v2}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
return-object v0
.end method