Base64Codec.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 constructor <init>()V
    .registers 2

    .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 protected constructor <init>([B)V
    .registers 2

    .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
    .registers 9

    .line 1
    rem-int/lit8 v0, p2, 0x4

    if-nez v0, :cond_52

    add-int/lit8 v0, p2, -0x1

    const/4 v1, 0x0

    move v2, v0

    const/4 v0, 0x0

    :goto_9
    const/4 v3, 0x2

    if-ge v0, v3, :cond_1b

    const/4 v4, -0x1

    if-le v2, v4, :cond_1b

    .line 2
    aget-byte v4, p1, v2

    const/16 v5, 0x3d

    if-eq v4, v5, :cond_16

    goto :goto_1b

    :cond_16
    add-int/lit8 v2, v2, -0x1

    add-int/lit8 v0, v0, 0x1

    goto :goto_9

    :cond_1b
    :goto_1b
    const/4 v2, 0x1

    const/4 v4, 0x3

    if-eqz v0, :cond_2e

    if-eq v0, v2, :cond_2c

    if-ne v0, v3, :cond_24

    goto :goto_2f

    .line 3
    :cond_24
    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_2c
    const/4 v2, 0x2

    goto :goto_2f

    :cond_2e
    const/4 v2, 0x3

    .line 4
    :goto_2f
    div-int/lit8 p2, p2, 0x4

    mul-int/lit8 p2, p2, 0x3

    rsub-int/lit8 v0, v2, 0x3

    sub-int/2addr p2, v0

    new-array p2, p2, [B

    const/4 v3, 0x0

    const/4 v5, 0x0

    .line 5
    :goto_3a
    array-length v0, p2

    rem-int/lit8 v1, v2, 0x3

    sub-int/2addr v0, v1

    if-ge v5, v0, :cond_48

    .line 6
    invoke-virtual {p0, p1, v3, p2, v5}, Lcom/amazonaws/util/Base64Codec;->decode4bytes([BI[BI)V

    add-int/lit8 v3, v3, 0x4

    add-int/lit8 v5, v5, 0x3

    goto :goto_3a

    :cond_48
    if-ge v2, v4, :cond_51

    move-object v0, p0

    move v1, v2

    move-object v2, p1

    move-object v4, p2

    .line 7
    invoke-virtual/range {v0 .. v5}, Lcom/amazonaws/util/Base64Codec;->decode1to3bytes(I[BI[BI)V

    :cond_51
    return-object p2

    .line 8
    :cond_52
    new-instance p1, Ljava/lang/IllegalArgumentException;

    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "Input is expected to be encoded in multiple of 4 bytes but found: "

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object p2

    invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V

    goto :goto_6a

    :goto_69
    throw p1

    :goto_6a
    goto :goto_69
.end method

.method decode1to3bytes(I[BI[BI)V
    .registers 13

    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_25

    .line 4
    invoke-static {v1, p3}, Lcom/amazonaws/util/CodecUtils;->sanityCheckLastPos(II)V

    return-void

    :cond_25
    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_3f

    .line 7
    invoke-static {v3, v5}, Lcom/amazonaws/util/CodecUtils;->sanityCheckLastPos(II)V

    return-void

    :cond_3f
    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 decode4bytes([BI[BI)V
    .registers 9

    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
    .registers 8

    .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_1a

    mul-int/lit8 v0, v0, 0x4

    .line 3
    new-array v0, v0, [B

    const/4 v1, 0x0

    .line 4
    :goto_e
    array-length v3, p1

    if-ge v2, v3, :cond_19

    .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_e

    :cond_19
    return-object v0

    :cond_1a
    const/4 v3, 0x1

    add-int/2addr v0, v3

    mul-int/lit8 v0, v0, 0x4

    .line 6
    new-array v0, v0, [B

    const/4 v4, 0x0

    .line 7
    :goto_21
    array-length v5, p1

    sub-int/2addr v5, v1

    if-ge v2, v5, :cond_2d

    .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_21

    :cond_2d
    if-eq v1, v3, :cond_37

    const/4 v3, 0x2

    if-eq v1, v3, :cond_33

    goto :goto_3a

    .line 9
    :cond_33
    invoke-virtual {p0, p1, v2, v0, v4}, Lcom/amazonaws/util/Base64Codec;->encode2bytes([BI[BI)V

    goto :goto_3a

    .line 10
    :cond_37
    invoke-virtual {p0, p1, v2, v0, v4}, Lcom/amazonaws/util/Base64Codec;->encode1byte([BI[BI)V

    :goto_3a
    return-object v0
.end method

.method encode1byte([BI[BI)V
    .registers 7

    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 encode2bytes([BI[BI)V
    .registers 9

    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 encode3bytes([BI[BI)V
    .registers 10

    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 protected pos(B)I
    .registers 5

    .line 1
    # getter for: Lcom/amazonaws/util/Base64Codec$LazyHolder;->DECODED:[B
    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_a

    return v0

    .line 2
    :cond_a
    new-instance v0, Ljava/lang/IllegalArgumentException;

    new-instance v1, Ljava/lang/StringBuilder;

    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V

    const-string v2, "Invalid base 64 character: \'"

    invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    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