.class Lcom/amazonaws/util/Base64Codec; .super Ljava/lang/Object; .source "SourceFile" # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/amazonaws/util/Base64Codec$LazyHolder; } .end annotation # instance fields .field public final alpahbets:[B # direct methods .method public constructor ()V .locals 1 .line 74 invoke-direct {p0}, Ljava/lang/Object;->()V const-string v0, "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" .line 76 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 # virtual methods .method public decode([BI)[B .locals 7 .line 206 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 215 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, 0x3 if-eqz v2, :cond_3 const/4 v4, 0x1 if-eq v2, v4, :cond_4 if-ne v2, v3, :cond_2 move v3, v4 goto :goto_2 .line 233 :cond_2 new-instance p1, Ljava/lang/Error; const-string p2, "Impossible" invoke-direct {p1, p2}, Ljava/lang/Error;->(Ljava/lang/String;)V throw p1 :cond_3 move v3, v0 .line 235 :cond_4 :goto_2 div-int/lit8 p2, p2, 0x4 mul-int/2addr p2, v0 rsub-int/lit8 v2, v3, 0x3 sub-int/2addr p2, v2 new-array v6, p2, [B move v4, v1 move v5, v4 .line 239 :goto_3 rem-int/lit8 v1, v3, 0x3 sub-int v1, p2, v1 if-ge v5, v1, :cond_5 .line 240 invoke-virtual {p0, p1, v4, v6, v5}, Lcom/amazonaws/util/Base64Codec;->decode4bytes([BI[BI)V add-int/lit8 v4, v4, 0x4 add-int/lit8 v5, v5, 0x3 goto :goto_3 :cond_5 if-ge v3, v0, :cond_6 move-object v0, p0 move v1, v3 move-object v2, p1 move v3, v4 move-object v4, v6 .line 244 invoke-virtual/range {v0 .. v5}, Lcom/amazonaws/util/Base64Codec;->decode1to3bytes(I[BI[BI)V :cond_6 return-object v6 .line 207 :cond_7 new-instance p1, Ljava/lang/IllegalArgumentException; new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()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;->(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 176 aget-byte v2, p2, p3 .line 178 invoke-virtual {p0, v2}, Lcom/amazonaws/util/Base64Codec;->pos(B)I move-result v2 const/4 v3, 0x2 shl-int/2addr v2, v3 add-int/lit8 v4, p3, 0x2 aget-byte v1, p2, v1 .line 179 invoke-virtual {p0, v1}, Lcom/amazonaws/util/Base64Codec;->pos(B)I move-result v1 ushr-int/lit8 v5, v1, 0x4 const/4 v6, 0x3 and-int/2addr v5, v6 or-int/2addr v2, v5 int-to-byte v2, v2 aput-byte v2, p4, p5 const/16 v2, 0xf const/4 v5, 0x1 if-ne p1, v5, :cond_0 .line 182 invoke-static {v1, v2}, Lcom/amazonaws/util/CodecUtils;->sanityCheckLastPos(II)V return-void :cond_0 add-int/2addr p5, v3 and-int/2addr v1, v2 shl-int/lit8 v1, v1, 0x4 add-int/2addr p3, v6 .line 186 aget-byte v4, p2, v4 .line 189 invoke-virtual {p0, v4}, Lcom/amazonaws/util/Base64Codec;->pos(B)I move-result v4 ushr-int/lit8 v5, v4, 0x2 and-int/2addr v2, v5 or-int/2addr v1, v2 int-to-byte v1, v1 aput-byte v1, p4, v0 if-ne p1, v3, :cond_1 .line 192 invoke-static {v4, v6}, Lcom/amazonaws/util/CodecUtils;->sanityCheckLastPos(II)V return-void :cond_1 and-int/lit8 p1, v4, 0x3 shl-int/lit8 p1, p1, 0x6 .line 196 aget-byte p2, p2, p3 .line 199 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 5 add-int/lit8 v0, p4, 0x1 add-int/lit8 v1, p2, 0x1 .line 151 aget-byte v2, p1, p2 .line 153 invoke-virtual {p0, v2}, Lcom/amazonaws/util/Base64Codec;->pos(B)I move-result v2 shl-int/lit8 v2, v2, 0x2 add-int/lit8 v3, p2, 0x2 aget-byte v1, p1, v1 .line 154 invoke-virtual {p0, v1}, Lcom/amazonaws/util/Base64Codec;->pos(B)I move-result v1 ushr-int/lit8 v4, v1, 0x4 and-int/lit8 v4, v4, 0x3 or-int/2addr v2, v4 int-to-byte v2, v2 aput-byte v2, p3, p4 add-int/lit8 p4, p4, 0x2 and-int/lit8 v1, v1, 0xf shl-int/lit8 v1, v1, 0x4 add-int/lit8 p2, p2, 0x3 .line 156 aget-byte v2, p1, v3 .line 159 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 v1, v3 int-to-byte v1, v1 aput-byte v1, p3, v0 and-int/lit8 v0, v2, 0x3 shl-int/lit8 v0, v0, 0x6 .line 161 aget-byte p1, p1, p2 .line 164 invoke-virtual {p0, p1}, Lcom/amazonaws/util/Base64Codec;->pos(B)I move-result p1 or-int/2addr p1, v0 int-to-byte p1, p1 aput-byte p1, p3, p4 return-void .end method .method public encode([B)[B .locals 6 .line 85 array-length v0, p1 div-int/lit8 v0, v0, 0x3 .line 86 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 89 new-array v0, v0, [B move v1, v2 .line 91 :goto_0 array-length v3, p1 if-ge v2, v3, :cond_0 .line 92 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 96 new-array v0, v0, [B move v4, v2 .line 99 :goto_1 array-length v5, p1 sub-int/2addr v5, v1 if-ge v2, v5, :cond_2 .line 100 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 107 :cond_3 invoke-virtual {p0, p1, v2, v0, v4}, Lcom/amazonaws/util/Base64Codec;->encode2bytes([BI[BI)V goto :goto_2 .line 104 :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 iget-object v1, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B .line 141 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, p4, 0x2 and-int/lit8 p1, p1, 0x3 shl-int/lit8 p1, p1, 0x4 .line 142 aget-byte p1, v1, p1 aput-byte p1, p3, v0 add-int/lit8 p4, p4, 0x3 const/16 p1, 0x3d .line 143 aput-byte p1, p3, p2 .line 144 aput-byte p1, p3, p4 return-void .end method .method public encode2bytes([BI[BI)V .locals 4 add-int/lit8 v0, p4, 0x1 iget-object v1, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B add-int/lit8 v2, p2, 0x1 .line 130 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 v3, p4, 0x2 and-int/lit8 p2, p2, 0x3 shl-int/lit8 p2, p2, 0x4 .line 131 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 p4, p4, 0x3 and-int/lit8 p1, p1, 0xf shl-int/lit8 p1, p1, 0x2 .line 133 aget-byte p1, v1, p1 aput-byte p1, p3, v3 const/16 p1, 0x3d .line 134 aput-byte p1, p3, p4 return-void .end method .method public encode3bytes([BI[BI)V .locals 6 add-int/lit8 v0, p4, 0x1 iget-object v1, p0, Lcom/amazonaws/util/Base64Codec;->alpahbets:[B add-int/lit8 v2, p2, 0x1 .line 118 aget-byte v3, p1, p2 ushr-int/lit8 v4, v3, 0x2 and-int/lit8 v4, v4, 0x3f aget-byte v4, v1, v4 aput-byte v4, p3, p4 add-int/lit8 v4, p4, 0x2 and-int/lit8 v3, v3, 0x3 shl-int/lit8 v3, v3, 0x4 add-int/lit8 p2, p2, 0x2 .line 119 aget-byte v2, p1, v2 ushr-int/lit8 v5, v2, 0x4 and-int/lit8 v5, v5, 0xf or-int/2addr v3, v5 aget-byte v3, v1, v3 aput-byte v3, p3, v0 add-int/lit8 p4, p4, 0x3 and-int/lit8 v0, v2, 0xf shl-int/lit8 v0, v0, 0x2 .line 121 aget-byte p1, p1, p2 ushr-int/lit8 p2, p1, 0x6 and-int/lit8 p2, p2, 0x3 or-int/2addr p2, v0 aget-byte p2, v1, p2 aput-byte p2, p3, v4 and-int/lit8 p1, p1, 0x3f .line 123 aget-byte p1, v1, p1 aput-byte p1, p3, p4 return-void .end method .method public pos(B)I .locals 3 .line 250 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 254 :cond_0 new-instance v0, Ljava/lang/IllegalArgumentException; new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()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;->(Ljava/lang/String;)V throw v0 .end method