RainbowPrivateKey.smali
.class public Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;
.super Lorg/spongycastle/asn1/ASN1Object;
.source "RainbowPrivateKey.java"
# instance fields
.field private b1:[B
.field private b2:[B
.field private invA1:[[B
.field private invA2:[[B
.field private layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
.field private oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
.field private version:Lorg/spongycastle/asn1/ASN1Integer;
.field private vi:[B
# direct methods
.method private constructor <init>(Lorg/spongycastle/asn1/ASN1Sequence;)V
.registers 15
.prologue
.line 58
invoke-direct {p0}, Lorg/spongycastle/asn1/ASN1Object;-><init>()V
.line 60
const/4 v0, 0x0
invoke-virtual {p1, v0}, 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_40
.line 62
const/4 v0, 0x0
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/RainbowPrivateKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
.line 70
:goto_17
const/4 v0, 0x1
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 71
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
new-array v1, v1, [[B
iput-object v1, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA1:[[B
.line 72
const/4 v1, 0x0
move v2, v1
:goto_28
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
if-ge v2, v1, :cond_4c
.line 74
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA1:[[B
invoke-virtual {v0, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v1
aput-object v1, v3, v2
.line 72
add-int/lit8 v1, v2, 0x1
move v2, v1
goto :goto_28
.line 66
:cond_40
const/4 v0, 0x0
invoke-virtual {p1, v0}, 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/RainbowPrivateKey;->oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
goto :goto_17
.line 78
:cond_4c
const/4 v0, 0x2
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 79
const/4 v1, 0x0
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->b1:[B
.line 82
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 83
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
new-array v1, v1, [[B
iput-object v1, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA2:[[B
.line 84
const/4 v1, 0x0
move v2, v1
:goto_71
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
if-ge v2, v1, :cond_89
.line 86
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA2:[[B
invoke-virtual {v0, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v1
aput-object v1, v3, v2
.line 84
add-int/lit8 v1, v2, 0x1
move v2, v1
goto :goto_71
.line 90
:cond_89
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 91
const/4 v1, 0x0
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->b2:[B
.line 94
const/4 v0, 0x5
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 95
const/4 v1, 0x0
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->vi:[B
.line 98
const/4 v0, 0x6
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 100
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
new-array v8, v1, [[[[B
.line 101
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
new-array v9, v1, [[[[B
.line 102
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
new-array v10, v1, [[[B
.line 103
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
new-array v11, v1, [[B
.line 105
const/4 v1, 0x0
move v5, v1
:goto_d2
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v1
if-ge v5, v1, :cond_1a8
.line 107
invoke-virtual {v0, v5}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1Sequence;
.line 110
const/4 v2, 0x0
invoke-virtual {v1, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v2
check-cast v2, Lorg/spongycastle/asn1/ASN1Sequence;
.line 111
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
new-array v3, v3, [[[B
aput-object v3, v8, v5
.line 112
const/4 v3, 0x0
move v6, v3
:goto_ef
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
if-ge v6, v3, :cond_125
.line 114
invoke-virtual {v2, v6}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v3
check-cast v3, Lorg/spongycastle/asn1/ASN1Sequence;
.line 115
aget-object v4, v8, v5
invoke-virtual {v3}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v7
new-array v7, v7, [[B
aput-object v7, v4, v6
.line 116
const/4 v4, 0x0
move v7, v4
:goto_107
invoke-virtual {v3}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v4
if-ge v7, v4, :cond_121
.line 118
aget-object v4, v8, v5
aget-object v12, v4, v6
invoke-virtual {v3, v7}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v4
check-cast v4, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v4}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v4
aput-object v4, v12, v7
.line 116
add-int/lit8 v4, v7, 0x1
move v7, v4
goto :goto_107
.line 112
:cond_121
add-int/lit8 v3, v6, 0x1
move v6, v3
goto :goto_ef
.line 123
:cond_125
const/4 v2, 0x1
invoke-virtual {v1, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v2
check-cast v2, Lorg/spongycastle/asn1/ASN1Sequence;
.line 124
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
new-array v3, v3, [[[B
aput-object v3, v9, v5
.line 125
const/4 v3, 0x0
move v7, v3
:goto_136
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
if-ge v7, v3, :cond_16d
.line 127
invoke-virtual {v2, v7}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v3
move-object v4, v3
check-cast v4, Lorg/spongycastle/asn1/ASN1Sequence;
.line 128
aget-object v3, v9, v5
invoke-virtual {v4}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v6
new-array v6, v6, [[B
aput-object v6, v3, v7
.line 129
const/4 v3, 0x0
move v6, v3
:goto_14f
invoke-virtual {v4}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
if-ge v6, v3, :cond_169
.line 131
aget-object v3, v9, v5
aget-object v12, v3, v7
invoke-virtual {v4, v6}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v3
check-cast v3, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v3}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v3
aput-object v3, v12, v6
.line 129
add-int/lit8 v3, v6, 0x1
move v6, v3
goto :goto_14f
.line 125
:cond_169
add-int/lit8 v3, v7, 0x1
move v7, v3
goto :goto_136
.line 136
:cond_16d
const/4 v2, 0x2
invoke-virtual {v1, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v2
check-cast v2, Lorg/spongycastle/asn1/ASN1Sequence;
.line 137
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
new-array v3, v3, [[B
aput-object v3, v10, v5
.line 138
const/4 v3, 0x0
move v4, v3
:goto_17e
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v3
if-ge v4, v3, :cond_196
.line 140
aget-object v6, v10, v5
invoke-virtual {v2, v4}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v3
check-cast v3, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v3}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v3
aput-object v3, v6, v4
.line 138
add-int/lit8 v3, v4, 0x1
move v4, v3
goto :goto_17e
.line 144
:cond_196
const/4 v2, 0x3
invoke-virtual {v1, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1OctetString;
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1OctetString;->getOctets()[B
move-result-object v1
aput-object v1, v11, v5
.line 105
add-int/lit8 v1, v5, 0x1
move v5, v1
goto/16 :goto_d2
.line 147
:cond_1a8
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->vi:[B
array-length v0, v0
add-int/lit8 v12, v0, -0x1
.line 148
new-array v0, v12, [Lorg/spongycastle/pqc/crypto/rainbow/Layer;
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
.line 149
const/4 v0, 0x0
move v7, v0
:goto_1b3
if-ge v7, v12, :cond_1e4
.line 151
new-instance v0, Lorg/spongycastle/pqc/crypto/rainbow/Layer;
iget-object v1, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->vi:[B
aget-byte v1, v1, v7
iget-object v2, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->vi:[B
add-int/lit8 v3, v7, 0x1
aget-byte v2, v2, v3
aget-object v3, v8, v7
invoke-static {v3}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[[B)[[[S
move-result-object v3
aget-object v4, v9, v7
.line 152
invoke-static {v4}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[[B)[[[S
move-result-object v4
aget-object v5, v10, v7
invoke-static {v5}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[B)[[S
move-result-object v5
aget-object v6, v11, v7
invoke-static {v6}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([B)[S
move-result-object v6
invoke-direct/range {v0 .. v6}, Lorg/spongycastle/pqc/crypto/rainbow/Layer;-><init>(BB[[[S[[[S[[S[S)V
.line 153
iget-object v1, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
aput-object v0, v1, v7
.line 149
add-int/lit8 v0, v7, 0x1
move v7, v0
goto :goto_1b3
.line 156
:cond_1e4
return-void
.end method
.method public constructor <init>([[S[S[[S[S[I[Lorg/spongycastle/pqc/crypto/rainbow/Layer;)V
.registers 11
.prologue
.line 160
invoke-direct {p0}, Lorg/spongycastle/asn1/ASN1Object;-><init>()V
.line 161
new-instance v0, Lorg/spongycastle/asn1/ASN1Integer;
const-wide/16 v2, 0x1
invoke-direct {v0, v2, v3}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(J)V
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
.line 162
invoke-static {p1}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[S)[[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA1:[[B
.line 163
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/RainbowPrivateKey;->b1:[B
.line 164
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/RainbowPrivateKey;->invA2:[[B
.line 165
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/RainbowPrivateKey;->b2:[B
.line 166
invoke-static {p5}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertIntArray([I)[B
move-result-object v0
iput-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->vi:[B
.line 167
iput-object p6, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
.line 168
return-void
.end method
.method public static getInstance(Ljava/lang/Object;)Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;
.registers 3
.prologue
.line 172
instance-of v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;
if-eqz v0, :cond_7
.line 174
check-cast p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;
.line 181
:goto_6
return-object p0
.line 176
:cond_7
if-eqz p0, :cond_14
.line 178
new-instance v0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;
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/RainbowPrivateKey;-><init>(Lorg/spongycastle/asn1/ASN1Sequence;)V
move-object p0, v0
goto :goto_6
.line 181
:cond_14
const/4 p0, 0x0
goto :goto_6
.end method
# virtual methods
.method public getB1()[S
.registers 2
.prologue
.line 206
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->b1:[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 getB2()[S
.registers 2
.prologue
.line 216
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->b2:[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 getInvA1()[[S
.registers 2
.prologue
.line 196
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA1:[[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 getInvA2()[[S
.registers 2
.prologue
.line 226
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA2:[[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 getLayers()[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
.registers 2
.prologue
.line 236
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
return-object v0
.end method
.method public getVersion()Lorg/spongycastle/asn1/ASN1Integer;
.registers 2
.prologue
.line 186
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
return-object v0
.end method
.method public getVi()[I
.registers 2
.prologue
.line 246
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->vi:[B
invoke-static {v0}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArraytoInt([B)[I
move-result-object v0
return-object v0
.end method
.method public toASN1Primitive()Lorg/spongycastle/asn1/ASN1Primitive;
.registers 13
.prologue
const/4 v1, 0x0
.line 251
new-instance v4, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v4}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 254
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
if-eqz v0, :cond_29
.line 256
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->version:Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v4, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 264
:goto_f
new-instance v2, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v0, v1
.line 265
:goto_15
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA1:[[B
array-length v3, v3
if-ge v0, v3, :cond_2f
.line 267
new-instance v3, Lorg/spongycastle/asn1/DEROctetString;
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA1:[[B
aget-object v5, v5, v0
invoke-direct {v3, v5}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v2, v3}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 265
add-int/lit8 v0, v0, 0x1
goto :goto_15
.line 260
:cond_29
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->oid:Lorg/spongycastle/asn1/ASN1ObjectIdentifier;
invoke-virtual {v4, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
goto :goto_f
.line 269
:cond_2f
new-instance v0, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v0, v2}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v4, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 272
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 273
new-instance v2, Lorg/spongycastle/asn1/DEROctetString;
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->b1:[B
invoke-direct {v2, v3}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v0, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 274
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v4, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 277
new-instance v2, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v0, v1
.line 278
:goto_54
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA2:[[B
array-length v3, v3
if-ge v0, v3, :cond_68
.line 280
new-instance v3, Lorg/spongycastle/asn1/DEROctetString;
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->invA2:[[B
aget-object v5, v5, v0
invoke-direct {v3, v5}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v2, v3}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 278
add-int/lit8 v0, v0, 0x1
goto :goto_54
.line 282
:cond_68
new-instance v0, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v0, v2}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v4, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 285
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 286
new-instance v2, Lorg/spongycastle/asn1/DEROctetString;
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->b2:[B
invoke-direct {v2, v3}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v0, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 287
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v4, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 290
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 291
new-instance v2, Lorg/spongycastle/asn1/DEROctetString;
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->vi:[B
invoke-direct {v2, v3}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v0, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 292
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v4, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 295
new-instance v5, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v5}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v0, v1
.line 297
:goto_a4
iget-object v2, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
array-length v2, v2
if-ge v0, v2, :cond_17d
.line 299
new-instance v6, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v6}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 302
iget-object v2, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
aget-object v2, v2, v0
invoke-virtual {v2}, Lorg/spongycastle/pqc/crypto/rainbow/Layer;->getCoeffAlpha()[[[S
move-result-object v2
invoke-static {v2}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[[S)[[[B
move-result-object v7
.line 303
new-instance v8, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v8}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v2, v1
.line 304
:goto_c0
array-length v3, v7
if-ge v2, v3, :cond_e8
.line 306
new-instance v9, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v9}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v3, v1
.line 307
:goto_c9
aget-object v10, v7, v2
array-length v10, v10
if-ge v3, v10, :cond_dd
.line 309
new-instance v10, Lorg/spongycastle/asn1/DEROctetString;
aget-object v11, v7, v2
aget-object v11, v11, v3
invoke-direct {v10, v11}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v9, v10}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 307
add-int/lit8 v3, v3, 0x1
goto :goto_c9
.line 311
:cond_dd
new-instance v3, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v3, v9}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v8, v3}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 304
add-int/lit8 v2, v2, 0x1
goto :goto_c0
.line 313
:cond_e8
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v8}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v6, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 316
iget-object v2, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
aget-object v2, v2, v0
invoke-virtual {v2}, Lorg/spongycastle/pqc/crypto/rainbow/Layer;->getCoeffBeta()[[[S
move-result-object v2
invoke-static {v2}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[[S)[[[B
move-result-object v7
.line 317
new-instance v8, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v8}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v3, v1
.line 318
:goto_102
array-length v2, v7
if-ge v3, v2, :cond_12b
.line 320
new-instance v9, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v9}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v2, v1
.line 321
:goto_10b
aget-object v10, v7, v3
array-length v10, v10
if-ge v2, v10, :cond_11f
.line 323
new-instance v10, Lorg/spongycastle/asn1/DEROctetString;
aget-object v11, v7, v3
aget-object v11, v11, v2
invoke-direct {v10, v11}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v9, v10}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 321
add-int/lit8 v2, v2, 0x1
goto :goto_10b
.line 325
:cond_11f
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v9}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v8, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 318
add-int/lit8 v2, v3, 0x1
move v3, v2
goto :goto_102
.line 327
:cond_12b
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v8}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v6, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 330
iget-object v2, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
aget-object v2, v2, v0
invoke-virtual {v2}, Lorg/spongycastle/pqc/crypto/rainbow/Layer;->getCoeffGamma()[[S
move-result-object v2
invoke-static {v2}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([[S)[[B
move-result-object v3
.line 331
new-instance v7, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v7}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
move v2, v1
.line 332
:goto_145
array-length v8, v3
if-ge v2, v8, :cond_155
.line 334
new-instance v8, Lorg/spongycastle/asn1/DEROctetString;
aget-object v9, v3, v2
invoke-direct {v8, v9}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v7, v8}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 332
add-int/lit8 v2, v2, 0x1
goto :goto_145
.line 336
:cond_155
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v7}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v6, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 339
new-instance v2, Lorg/spongycastle/asn1/DEROctetString;
iget-object v3, p0, Lorg/spongycastle/pqc/asn1/RainbowPrivateKey;->layers:[Lorg/spongycastle/pqc/crypto/rainbow/Layer;
aget-object v3, v3, v0
invoke-virtual {v3}, Lorg/spongycastle/pqc/crypto/rainbow/Layer;->getCoeffEta()[S
move-result-object v3
invoke-static {v3}, Lorg/spongycastle/pqc/crypto/rainbow/util/RainbowUtil;->convertArray([S)[B
move-result-object v3
invoke-direct {v2, v3}, Lorg/spongycastle/asn1/DEROctetString;-><init>([B)V
invoke-virtual {v6, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 342
new-instance v2, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v2, v6}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v5, v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 297
add-int/lit8 v0, v0, 0x1
goto/16 :goto_a4
.line 345
:cond_17d
new-instance v0, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v0, v5}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v4, v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 347
new-instance v0, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v0, v4}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
return-object v0
.end method