tmap/smali/com/amazonaws/util/Base64Codec.smali
2022-06-10 21:38:30 +09:00

720 lines
12 KiB
Smali

.class Lcom/amazonaws/util/Base64Codec;
.super Ljava/lang/Object;
.source "Base64Codec.java"
# interfaces
.implements Lcom/amazonaws/util/Codec;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/amazonaws/util/Base64Codec$LazyHolder;
}
.end annotation
# static fields
.field private static final BITS_3:I = 0x3
.field private static final BITS_4:I = 0x4
.field private static final BITS_6:I = 0x6
.field private static final MASK_2BITS:I = 0x3
.field private static final MASK_4BITS:I = 0xf
.field private static final MASK_6BITS:I = 0x3f
.field private static final OFFSET_0_VALUE:I = 0x34
.field private static final OFFSET_OF_0:I = -0x4
.field private static final OFFSET_OF_PLUS:I = -0x13
.field private static final OFFSET_OF_SLASH:I = -0x10
.field private static final OFFSET_OF_a:I = 0x47
.field private static final OFFSET_PLUS_VALUE:I = 0x3e
.field private static final OFFSET_SLASH_VALUE:I = 0x3f
.field private static final OFFSET_a_VALUE:I = 0x1a
.field private static final PAD:B = 0x3dt
# instance fields
.field private final alpahbets:[B
# direct methods
.method public constructor <init>()V
.locals 1
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const-string v0, "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
.line 2
invoke-static {v0}, Lcom/amazonaws/util/CodecUtils;->toBytesDirect(Ljava/lang/String;)[B
move-result-object v0
iput-object v0, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B
return-void
.end method
.method public constructor <init>([B)V
.locals 0
.line 3
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 4
iput-object p1, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B
return-void
.end method
# virtual methods
.method public decode([BI)[B
.locals 8
.line 1
rem-int/lit8 v0, p2, 0x4
if-nez v0, :cond_7
add-int/lit8 v0, p2, -0x1
const/4 v1, 0x0
move v2, v1
:goto_0
const/4 v3, 0x2
if-ge v2, v3, :cond_1
const/4 v4, -0x1
if-le v0, v4, :cond_1
.line 2
aget-byte v4, p1, v0
const/16 v5, 0x3d
if-eq v4, v5, :cond_0
goto :goto_1
:cond_0
add-int/lit8 v0, v0, -0x1
add-int/lit8 v2, v2, 0x1
goto :goto_0
:cond_1
:goto_1
const/4 v0, 0x1
const/4 v4, 0x3
if-eqz v2, :cond_3
if-eq v2, v0, :cond_4
if-ne v2, v3, :cond_2
move v3, v0
goto :goto_2
.line 3
:cond_2
new-instance p1, Ljava/lang/Error;
const-string p2, "Impossible"
invoke-direct {p1, p2}, Ljava/lang/Error;-><init>(Ljava/lang/String;)V
throw p1
:cond_3
move v3, v4
.line 4
:cond_4
:goto_2
div-int/lit8 p2, p2, 0x4
mul-int/2addr p2, v4
rsub-int/lit8 v0, v3, 0x3
sub-int/2addr p2, v0
new-array v6, p2, [B
move v5, v1
move v7, v5
.line 5
:goto_3
rem-int/lit8 v0, v3, 0x3
sub-int v0, p2, v0
if-ge v7, v0, :cond_5
.line 6
invoke-virtual {p0, p1, v5, v6, v7}, Lcom/amazonaws/util/Base64Codec;->decode4bytes([BI[BI)V
add-int/lit8 v5, v5, 0x4
add-int/lit8 v7, v7, 0x3
goto :goto_3
:cond_5
if-ge v3, v4, :cond_6
move-object v0, p0
move v1, v3
move-object v2, p1
move v3, v5
move-object v4, v6
move v5, v7
.line 7
invoke-virtual/range {v0 .. v5}, Lcom/amazonaws/util/Base64Codec;->decode1to3bytes(I[BI[BI)V
:cond_6
return-object v6
.line 8
:cond_7
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string v0, "Input is expected to be encoded in multiple of 4 bytes but found: "
invoke-static {v0, p2}, Landroid/support/v4/media/b;->a(Ljava/lang/String;I)Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public decode1to3bytes(I[BI[BI)V
.locals 7
add-int/lit8 v0, p5, 0x1
add-int/lit8 v1, p3, 0x1
.line 1
aget-byte p3, p2, p3
.line 2
invoke-virtual {p0, p3}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result p3
const/4 v2, 0x2
shl-int/2addr p3, v2
add-int/lit8 v3, v1, 0x1
aget-byte v1, p2, v1
.line 3
invoke-virtual {p0, v1}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result v1
ushr-int/lit8 v4, v1, 0x4
const/4 v5, 0x3
and-int/2addr v4, v5
or-int/2addr p3, v4
int-to-byte p3, p3
aput-byte p3, p4, p5
const/16 p3, 0xf
const/4 p5, 0x1
if-ne p1, p5, :cond_0
.line 4
invoke-static {v1, p3}, Lcom/amazonaws/util/CodecUtils;->sanityCheckLastPos(II)V
return-void
:cond_0
add-int/lit8 p5, v0, 0x1
and-int/2addr v1, p3
shl-int/lit8 v1, v1, 0x4
add-int/lit8 v4, v3, 0x1
.line 5
aget-byte v3, p2, v3
.line 6
invoke-virtual {p0, v3}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result v3
ushr-int/lit8 v6, v3, 0x2
and-int/2addr p3, v6
or-int/2addr p3, v1
int-to-byte p3, p3
aput-byte p3, p4, v0
if-ne p1, v2, :cond_1
.line 7
invoke-static {v3, v5}, Lcom/amazonaws/util/CodecUtils;->sanityCheckLastPos(II)V
return-void
:cond_1
and-int/lit8 p1, v3, 0x3
shl-int/lit8 p1, p1, 0x6
.line 8
aget-byte p2, p2, v4
.line 9
invoke-virtual {p0, p2}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result p2
or-int/2addr p1, p2
int-to-byte p1, p1
aput-byte p1, p4, p5
return-void
.end method
.method public decode4bytes([BI[BI)V
.locals 4
add-int/lit8 v0, p4, 0x1
add-int/lit8 v1, p2, 0x1
.line 1
aget-byte p2, p1, p2
.line 2
invoke-virtual {p0, p2}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result p2
shl-int/lit8 p2, p2, 0x2
add-int/lit8 v2, v1, 0x1
aget-byte v1, p1, v1
.line 3
invoke-virtual {p0, v1}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result v1
ushr-int/lit8 v3, v1, 0x4
and-int/lit8 v3, v3, 0x3
or-int/2addr p2, v3
int-to-byte p2, p2
aput-byte p2, p3, p4
add-int/lit8 p2, v0, 0x1
and-int/lit8 p4, v1, 0xf
shl-int/lit8 p4, p4, 0x4
add-int/lit8 v1, v2, 0x1
.line 4
aget-byte v2, p1, v2
.line 5
invoke-virtual {p0, v2}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result v2
ushr-int/lit8 v3, v2, 0x2
and-int/lit8 v3, v3, 0xf
or-int/2addr p4, v3
int-to-byte p4, p4
aput-byte p4, p3, v0
and-int/lit8 p4, v2, 0x3
shl-int/lit8 p4, p4, 0x6
.line 6
aget-byte p1, p1, v1
.line 7
invoke-virtual {p0, p1}, Lcom/amazonaws/util/Base64Codec;->pos(B)I
move-result p1
or-int/2addr p1, p4
int-to-byte p1, p1
aput-byte p1, p3, p2
return-void
.end method
.method public encode([B)[B
.locals 6
.line 1
array-length v0, p1
div-int/lit8 v0, v0, 0x3
.line 2
array-length v1, p1
rem-int/lit8 v1, v1, 0x3
const/4 v2, 0x0
if-nez v1, :cond_1
mul-int/lit8 v0, v0, 0x4
.line 3
new-array v0, v0, [B
move v1, v2
.line 4
:goto_0
array-length v3, p1
if-ge v2, v3, :cond_0
.line 5
invoke-virtual {p0, p1, v2, v0, v1}, Lcom/amazonaws/util/Base64Codec;->encode3bytes([BI[BI)V
add-int/lit8 v2, v2, 0x3
add-int/lit8 v1, v1, 0x4
goto :goto_0
:cond_0
return-object v0
:cond_1
const/4 v3, 0x1
add-int/2addr v0, v3
mul-int/lit8 v0, v0, 0x4
.line 6
new-array v0, v0, [B
move v4, v2
.line 7
:goto_1
array-length v5, p1
sub-int/2addr v5, v1
if-ge v2, v5, :cond_2
.line 8
invoke-virtual {p0, p1, v2, v0, v4}, Lcom/amazonaws/util/Base64Codec;->encode3bytes([BI[BI)V
add-int/lit8 v2, v2, 0x3
add-int/lit8 v4, v4, 0x4
goto :goto_1
:cond_2
if-eq v1, v3, :cond_4
const/4 v3, 0x2
if-eq v1, v3, :cond_3
goto :goto_2
.line 9
:cond_3
invoke-virtual {p0, p1, v2, v0, v4}, Lcom/amazonaws/util/Base64Codec;->encode2bytes([BI[BI)V
goto :goto_2
.line 10
:cond_4
invoke-virtual {p0, p1, v2, v0, v4}, Lcom/amazonaws/util/Base64Codec;->encode1byte([BI[BI)V
:goto_2
return-object v0
.end method
.method public encode1byte([BI[BI)V
.locals 2
add-int/lit8 v0, p4, 0x1
.line 1
iget-object v1, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B
aget-byte p1, p1, p2
ushr-int/lit8 p2, p1, 0x2
and-int/lit8 p2, p2, 0x3f
aget-byte p2, v1, p2
aput-byte p2, p3, p4
add-int/lit8 p2, v0, 0x1
and-int/lit8 p1, p1, 0x3
shl-int/lit8 p1, p1, 0x4
.line 2
aget-byte p1, v1, p1
aput-byte p1, p3, v0
add-int/lit8 p1, p2, 0x1
const/16 p4, 0x3d
.line 3
aput-byte p4, p3, p2
.line 4
aput-byte p4, p3, p1
return-void
.end method
.method public encode2bytes([BI[BI)V
.locals 4
add-int/lit8 v0, p4, 0x1
.line 1
iget-object v1, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B
add-int/lit8 v2, p2, 0x1
aget-byte p2, p1, p2
ushr-int/lit8 v3, p2, 0x2
and-int/lit8 v3, v3, 0x3f
aget-byte v3, v1, v3
aput-byte v3, p3, p4
add-int/lit8 p4, v0, 0x1
and-int/lit8 p2, p2, 0x3
shl-int/lit8 p2, p2, 0x4
.line 2
aget-byte p1, p1, v2
ushr-int/lit8 v2, p1, 0x4
and-int/lit8 v2, v2, 0xf
or-int/2addr p2, v2
aget-byte p2, v1, p2
aput-byte p2, p3, v0
add-int/lit8 p2, p4, 0x1
and-int/lit8 p1, p1, 0xf
shl-int/lit8 p1, p1, 0x2
.line 3
aget-byte p1, v1, p1
aput-byte p1, p3, p4
const/16 p1, 0x3d
.line 4
aput-byte p1, p3, p2
return-void
.end method
.method public encode3bytes([BI[BI)V
.locals 5
add-int/lit8 v0, p4, 0x1
.line 1
iget-object v1, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B
add-int/lit8 v2, p2, 0x1
aget-byte p2, p1, p2
ushr-int/lit8 v3, p2, 0x2
and-int/lit8 v3, v3, 0x3f
aget-byte v3, v1, v3
aput-byte v3, p3, p4
add-int/lit8 p4, v0, 0x1
and-int/lit8 p2, p2, 0x3
shl-int/lit8 p2, p2, 0x4
add-int/lit8 v3, v2, 0x1
.line 2
aget-byte v2, p1, v2
ushr-int/lit8 v4, v2, 0x4
and-int/lit8 v4, v4, 0xf
or-int/2addr p2, v4
aget-byte p2, v1, p2
aput-byte p2, p3, v0
add-int/lit8 p2, p4, 0x1
and-int/lit8 v0, v2, 0xf
shl-int/lit8 v0, v0, 0x2
.line 3
aget-byte p1, p1, v3
ushr-int/lit8 v2, p1, 0x6
and-int/lit8 v2, v2, 0x3
or-int/2addr v0, v2
aget-byte v0, v1, v0
aput-byte v0, p3, p4
and-int/lit8 p1, p1, 0x3f
.line 4
aget-byte p1, v1, p1
aput-byte p1, p3, p2
return-void
.end method
.method public pos(B)I
.locals 2
.line 1
invoke-static {}, Lcom/amazonaws/util/Base64Codec$LazyHolder;->access$000()[B
move-result-object v0
aget-byte v0, v0, p1
const/4 v1, -0x1
if-le v0, v1, :cond_0
return v0
.line 2
:cond_0
new-instance v0, Ljava/lang/IllegalArgumentException;
const-string v1, "Invalid base 64 character: \'"
invoke-static {v1}, Landroid/support/v4/media/d;->a(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
int-to-char p1, p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
const-string p1, "\'"
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {v0, p1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method