NTRUSignerPrng.smali
.class public Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;
.super Ljava/lang/Object;
.source "NTRUSignerPrng.java"
# instance fields
.field private counter:I
.field private hashAlg:Lorg/spongycastle/crypto/Digest;
.field private seed:[B
# direct methods
.method constructor <init>([BLorg/spongycastle/crypto/Digest;)V
.registers 4
.prologue
.line 23
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 24
const/4 v0, 0x0
iput v0, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->counter:I
.line 25
iput-object p1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->seed:[B
.line 26
iput-object p2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->hashAlg:Lorg/spongycastle/crypto/Digest;
.line 27
return-void
.end method
# virtual methods
.method nextBytes(I)[B
.registers 8
.prologue
const/4 v5, 0x0
.line 37
invoke-static {p1}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v0
.line 39
:goto_5
invoke-virtual {v0}, Ljava/nio/ByteBuffer;->hasRemaining()Z
move-result v1
if-eqz v1, :cond_4e
.line 41
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->seed:[B
array-length v1, v1
add-int/lit8 v1, v1, 0x4
invoke-static {v1}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v1
.line 42
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->seed:[B
invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
.line 43
iget v2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->counter:I
invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->putInt(I)Ljava/nio/ByteBuffer;
.line 44
invoke-virtual {v1}, Ljava/nio/ByteBuffer;->array()[B
move-result-object v1
.line 45
iget-object v2, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->hashAlg:Lorg/spongycastle/crypto/Digest;
invoke-interface {v2}, Lorg/spongycastle/crypto/Digest;->getDigestSize()I
move-result v2
new-array v2, v2, [B
.line 47
iget-object v3, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->hashAlg:Lorg/spongycastle/crypto/Digest;
array-length v4, v1
invoke-interface {v3, v1, v5, v4}, Lorg/spongycastle/crypto/Digest;->update([BII)V
.line 49
iget-object v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->hashAlg:Lorg/spongycastle/crypto/Digest;
invoke-interface {v1, v2, v5}, Lorg/spongycastle/crypto/Digest;->doFinal([BI)I
.line 51
invoke-virtual {v0}, Ljava/nio/ByteBuffer;->remaining()I
move-result v1
array-length v3, v2
if-ge v1, v3, :cond_4a
.line 53
invoke-virtual {v0}, Ljava/nio/ByteBuffer;->remaining()I
move-result v1
invoke-virtual {v0, v2, v5, v1}, Ljava/nio/ByteBuffer;->put([BII)Ljava/nio/ByteBuffer;
.line 59
:goto_43
iget v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->counter:I
add-int/lit8 v1, v1, 0x1
iput v1, p0, Lorg/spongycastle/pqc/crypto/ntru/NTRUSignerPrng;->counter:I
goto :goto_5
.line 57
:cond_4a
invoke-virtual {v0, v2}, Ljava/nio/ByteBuffer;->put([B)Ljava/nio/ByteBuffer;
goto :goto_43
.line 62
:cond_4e
invoke-virtual {v0}, Ljava/nio/ByteBuffer;->array()[B
move-result-object v0
return-object v0
.end method