ParSet.smali
.class public Lorg/spongycastle/pqc/asn1/ParSet;
.super Lorg/spongycastle/asn1/ASN1Object;
.source "ParSet.java"
# static fields
.field private static final ZERO:Ljava/math/BigInteger;
# instance fields
.field private h:[I
.field private k:[I
.field private t:I
.field private w:[I
# direct methods
.method static constructor <clinit>()V
.registers 2
.prologue
.line 26
const-wide/16 v0, 0x0
invoke-static {v0, v1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v0
sput-object v0, Lorg/spongycastle/pqc/asn1/ParSet;->ZERO:Ljava/math/BigInteger;
return-void
.end method
.method public constructor <init>(I[I[I[I)V
.registers 5
.prologue
.line 77
invoke-direct {p0}, Lorg/spongycastle/asn1/ASN1Object;-><init>()V
.line 78
iput p1, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
.line 79
iput-object p2, p0, Lorg/spongycastle/pqc/asn1/ParSet;->h:[I
.line 80
iput-object p3, p0, Lorg/spongycastle/pqc/asn1/ParSet;->w:[I
.line 81
iput-object p4, p0, Lorg/spongycastle/pqc/asn1/ParSet;->k:[I
.line 82
return-void
.end method
.method private constructor <init>(Lorg/spongycastle/asn1/ASN1Sequence;)V
.registers 8
.prologue
const/4 v3, 0x0
.line 44
invoke-direct {p0}, Lorg/spongycastle/asn1/ASN1Object;-><init>()V
.line 45
invoke-virtual {p1}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v0
const/4 v1, 0x4
if-eq v0, v1, :cond_24
.line 47
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "sie of seqOfParams = "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 49
:cond_24
invoke-virtual {p1, v3}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v0
check-cast v0, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v0
.line 51
invoke-static {v0}, Lorg/spongycastle/pqc/asn1/ParSet;->checkBigIntegerInIntRangeAndPositive(Ljava/math/BigInteger;)I
move-result v0
iput v0, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
.line 53
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 54
const/4 v1, 0x2
invoke-virtual {p1, v1}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v1
check-cast v1, Lorg/spongycastle/asn1/ASN1Sequence;
.line 55
const/4 v2, 0x3
invoke-virtual {p1, v2}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v2
check-cast v2, Lorg/spongycastle/asn1/ASN1Sequence;
.line 57
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v4
iget v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
if-ne v4, v5, :cond_61
.line 58
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v4
iget v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
if-ne v4, v5, :cond_61
.line 59
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v4
iget v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
if-eq v4, v5, :cond_69
.line 61
:cond_61
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "invalid size of sequences"
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 64
:cond_69
invoke-virtual {v0}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v4
new-array v4, v4, [I
iput-object v4, p0, Lorg/spongycastle/pqc/asn1/ParSet;->h:[I
.line 65
invoke-virtual {v1}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v4
new-array v4, v4, [I
iput-object v4, p0, Lorg/spongycastle/pqc/asn1/ParSet;->w:[I
.line 66
invoke-virtual {v2}, Lorg/spongycastle/asn1/ASN1Sequence;->size()I
move-result v4
new-array v4, v4, [I
iput-object v4, p0, Lorg/spongycastle/pqc/asn1/ParSet;->k:[I
move v4, v3
.line 68
:goto_82
iget v3, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
if-ge v4, v3, :cond_c0
.line 70
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->h:[I
invoke-virtual {v0, v4}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v3
check-cast v3, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v3}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v3
invoke-static {v3}, Lorg/spongycastle/pqc/asn1/ParSet;->checkBigIntegerInIntRangeAndPositive(Ljava/math/BigInteger;)I
move-result v3
aput v3, v5, v4
.line 71
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->w:[I
invoke-virtual {v1, v4}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v3
check-cast v3, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v3}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v3
invoke-static {v3}, Lorg/spongycastle/pqc/asn1/ParSet;->checkBigIntegerInIntRangeAndPositive(Ljava/math/BigInteger;)I
move-result v3
aput v3, v5, v4
.line 72
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->k:[I
invoke-virtual {v2, v4}, Lorg/spongycastle/asn1/ASN1Sequence;->getObjectAt(I)Lorg/spongycastle/asn1/ASN1Encodable;
move-result-object v3
check-cast v3, Lorg/spongycastle/asn1/ASN1Integer;
invoke-virtual {v3}, Lorg/spongycastle/asn1/ASN1Integer;->getValue()Ljava/math/BigInteger;
move-result-object v3
invoke-static {v3}, Lorg/spongycastle/pqc/asn1/ParSet;->checkBigIntegerInIntRangeAndPositive(Ljava/math/BigInteger;)I
move-result v3
aput v3, v5, v4
.line 68
add-int/lit8 v3, v4, 0x1
move v4, v3
goto :goto_82
.line 74
:cond_c0
return-void
.end method
.method private static checkBigIntegerInIntRangeAndPositive(Ljava/math/BigInteger;)I
.registers 4
.prologue
.line 35
const-wide/32 v0, 0x7fffffff
invoke-static {v0, v1}, Ljava/math/BigInteger;->valueOf(J)Ljava/math/BigInteger;
move-result-object v0
invoke-virtual {p0, v0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gtz v0, :cond_15
sget-object v0, Lorg/spongycastle/pqc/asn1/ParSet;->ZERO:Ljava/math/BigInteger;
.line 36
invoke-virtual {p0, v0}, Ljava/math/BigInteger;->compareTo(Ljava/math/BigInteger;)I
move-result v0
if-gtz v0, :cond_2e
.line 38
:cond_15
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "BigInteger not in Range: "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p0}, Ljava/math/BigInteger;->toString()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.line 40
:cond_2e
invoke-virtual {p0}, Ljava/math/BigInteger;->intValue()I
move-result v0
return v0
.end method
.method public static getInstance(Ljava/lang/Object;)Lorg/spongycastle/pqc/asn1/ParSet;
.registers 3
.prologue
.line 86
instance-of v0, p0, Lorg/spongycastle/pqc/asn1/ParSet;
if-eqz v0, :cond_7
.line 88
check-cast p0, Lorg/spongycastle/pqc/asn1/ParSet;
.line 95
:goto_6
return-object p0
.line 90
:cond_7
if-eqz p0, :cond_14
.line 92
new-instance v0, Lorg/spongycastle/pqc/asn1/ParSet;
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/ParSet;-><init>(Lorg/spongycastle/asn1/ASN1Sequence;)V
move-object p0, v0
goto :goto_6
.line 95
:cond_14
const/4 p0, 0x0
goto :goto_6
.end method
# virtual methods
.method public getH()[I
.registers 2
.prologue
.line 105
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/ParSet;->h:[I
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([I)[I
move-result-object v0
return-object v0
.end method
.method public getK()[I
.registers 2
.prologue
.line 115
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/ParSet;->k:[I
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([I)[I
move-result-object v0
return-object v0
.end method
.method public getT()I
.registers 2
.prologue
.line 100
iget v0, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
return v0
.end method
.method public getW()[I
.registers 2
.prologue
.line 110
iget-object v0, p0, Lorg/spongycastle/pqc/asn1/ParSet;->w:[I
invoke-static {v0}, Lorg/spongycastle/util/Arrays;->clone([I)[I
move-result-object v0
return-object v0
.end method
.method public toASN1Primitive()Lorg/spongycastle/asn1/ASN1Primitive;
.registers 9
.prologue
.line 120
new-instance v1, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 121
new-instance v2, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v2}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 122
new-instance v3, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v3}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 124
const/4 v0, 0x0
:goto_10
iget-object v4, p0, Lorg/spongycastle/pqc/asn1/ParSet;->h:[I
array-length v4, v4
if-ge v0, v4, :cond_3f
.line 126
new-instance v4, Lorg/spongycastle/asn1/ASN1Integer;
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->h:[I
aget v5, v5, v0
int-to-long v6, v5
invoke-direct {v4, v6, v7}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(J)V
invoke-virtual {v1, v4}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 127
new-instance v4, Lorg/spongycastle/asn1/ASN1Integer;
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->w:[I
aget v5, v5, v0
int-to-long v6, v5
invoke-direct {v4, v6, v7}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(J)V
invoke-virtual {v2, v4}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 128
new-instance v4, Lorg/spongycastle/asn1/ASN1Integer;
iget-object v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->k:[I
aget v5, v5, v0
int-to-long v6, v5
invoke-direct {v4, v6, v7}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(J)V
invoke-virtual {v3, v4}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 124
add-int/lit8 v0, v0, 0x1
goto :goto_10
.line 131
:cond_3f
new-instance v0, Lorg/spongycastle/asn1/ASN1EncodableVector;
invoke-direct {v0}, Lorg/spongycastle/asn1/ASN1EncodableVector;-><init>()V
.line 133
new-instance v4, Lorg/spongycastle/asn1/ASN1Integer;
iget v5, p0, Lorg/spongycastle/pqc/asn1/ParSet;->t:I
int-to-long v6, v5
invoke-direct {v4, v6, v7}, Lorg/spongycastle/asn1/ASN1Integer;-><init>(J)V
invoke-virtual {v0, v4}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 134
new-instance v4, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v4, v1}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v0, v4}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 135
new-instance v1, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v1, v2}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 136
new-instance v1, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v1, v3}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
invoke-virtual {v0, v1}, Lorg/spongycastle/asn1/ASN1EncodableVector;->add(Lorg/spongycastle/asn1/ASN1Encodable;)V
.line 138
new-instance v1, Lorg/spongycastle/asn1/DERSequence;
invoke-direct {v1, v0}, Lorg/spongycastle/asn1/DERSequence;-><init>(Lorg/spongycastle/asn1/ASN1EncodableVector;)V
return-object v1
.end method