apkfuckery/com.discord/smali_classes2/f/n/a/k/b.smali
2020-07-08 16:44:49 +00:00

953 lines
20 KiB
Smali

.class public Lf/n/a/k/b;
.super Ljava/lang/Object;
.source "ImageHeaderParser.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lf/n/a/k/b$b;,
Lf/n/a/k/b$a;
}
.end annotation
# static fields
.field public static final b:[B
.field public static final c:[I
# instance fields
.field public final a:Lf/n/a/k/b$a;
# direct methods
.method public static constructor <clinit>()V
.locals 2
const-string v0, "UTF-8"
invoke-static {v0}, Ljava/nio/charset/Charset;->forName(Ljava/lang/String;)Ljava/nio/charset/Charset;
move-result-object v0
const-string v1, "Exif\u0000\u0000"
invoke-virtual {v1, v0}, Ljava/lang/String;->getBytes(Ljava/nio/charset/Charset;)[B
move-result-object v0
sput-object v0, Lf/n/a/k/b;->b:[B
const/16 v0, 0xd
new-array v0, v0, [I
fill-array-data v0, :array_0
sput-object v0, Lf/n/a/k/b;->c:[I
return-void
:array_0
.array-data 4
0x0
0x1
0x1
0x2
0x4
0x8
0x1
0x1
0x2
0x4
0x8
0x4
0x8
.end array-data
.end method
.method public constructor <init>(Ljava/io/InputStream;)V
.locals 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
new-instance v0, Lf/n/a/k/b$b;
invoke-direct {v0, p1}, Lf/n/a/k/b$b;-><init>(Ljava/io/InputStream;)V
iput-object v0, p0, Lf/n/a/k/b;->a:Lf/n/a/k/b$a;
return-void
.end method
.method public static a(Landroid/media/ExifInterface;IILjava/lang/String;)V
.locals 23
const-string v1, "FNumber"
const-string v2, "DateTime"
const-string v3, "DateTimeDigitized"
const-string v4, "ExposureTime"
const-string v5, "Flash"
const-string v6, "FocalLength"
const-string v7, "GPSAltitude"
const-string v8, "GPSAltitudeRef"
const-string v9, "GPSDateStamp"
const-string v10, "GPSLatitude"
const-string v11, "GPSLatitudeRef"
const-string v12, "GPSLongitude"
const-string v13, "GPSLongitudeRef"
const-string v14, "GPSProcessingMethod"
const-string v15, "GPSTimeStamp"
const-string v16, "ISOSpeedRatings"
const-string v17, "Make"
const-string v18, "Model"
const-string v19, "SubSecTime"
const-string v20, "SubSecTimeDigitized"
const-string v21, "SubSecTimeOriginal"
const-string v22, "WhiteBalance"
filled-new-array/range {v1 .. v22}, [Ljava/lang/String;
move-result-object v0
:try_start_0
new-instance v1, Landroid/media/ExifInterface;
move-object/from16 v2, p3
invoke-direct {v1, v2}, Landroid/media/ExifInterface;-><init>(Ljava/lang/String;)V
const/4 v2, 0x0
:goto_0
const/16 v3, 0x16
if-ge v2, v3, :cond_1
aget-object v3, v0, v2
move-object/from16 v4, p0
invoke-virtual {v4, v3}, Landroid/media/ExifInterface;->getAttribute(Ljava/lang/String;)Ljava/lang/String;
move-result-object v5
invoke-static {v5}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v6
if-nez v6, :cond_0
invoke-virtual {v1, v3, v5}, Landroid/media/ExifInterface;->setAttribute(Ljava/lang/String;Ljava/lang/String;)V
:cond_0
add-int/lit8 v2, v2, 0x1
goto :goto_0
:cond_1
const-string v0, "ImageWidth"
invoke-static/range {p1 .. p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v0, v2}, Landroid/media/ExifInterface;->setAttribute(Ljava/lang/String;Ljava/lang/String;)V
const-string v0, "ImageLength"
invoke-static/range {p2 .. p2}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v0, v2}, Landroid/media/ExifInterface;->setAttribute(Ljava/lang/String;Ljava/lang/String;)V
const-string v0, "Orientation"
const-string v2, "0"
invoke-virtual {v1, v0, v2}, Landroid/media/ExifInterface;->setAttribute(Ljava/lang/String;Ljava/lang/String;)V
invoke-virtual {v1}, Landroid/media/ExifInterface;->saveAttributes()V
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_1
:catch_0
move-exception v0
invoke-virtual {v0}, Ljava/io/IOException;->getMessage()Ljava/lang/String;
move-result-object v0
const-string v1, "ImageHeaderParser"
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:goto_1
return-void
.end method
# virtual methods
.method public b()I
.locals 18
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
move-object/from16 v0, p0
iget-object v1, v0, Lf/n/a/k/b;->a:Lf/n/a/k/b$a;
check-cast v1, Lf/n/a/k/b$b;
invoke-virtual {v1}, Lf/n/a/k/b$b;->a()I
move-result v1
const v2, 0xffd8
and-int v3, v1, v2
const/16 v4, 0x4949
const/16 v5, 0x4d4d
if-eq v3, v2, :cond_1
if-eq v1, v5, :cond_1
if-ne v1, v4, :cond_0
goto :goto_0
:cond_0
const/4 v2, 0x0
goto :goto_1
:cond_1
:goto_0
const/4 v2, 0x1
:goto_1
const/4 v3, 0x3
const/4 v4, -0x1
const-string v6, "ImageHeaderParser"
if-nez v2, :cond_3
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v2
if-eqz v2, :cond_2
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Parser doesn\'t handle magic number: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v6, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_2
return v4
:cond_3
iget-object v1, v0, Lf/n/a/k/b;->a:Lf/n/a/k/b$a;
check-cast v1, Lf/n/a/k/b$b;
iget-object v1, v1, Lf/n/a/k/b$b;->a:Ljava/io/InputStream;
invoke-virtual {v1}, Ljava/io/InputStream;->read()I
move-result v1
const/16 v2, 0xff
and-int/2addr v1, v2
int-to-short v1, v1
const/4 v7, 0x0
if-eq v1, v2, :cond_4
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v2
if-eqz v2, :cond_b
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v8, "Unknown segmentId="
invoke-virtual {v2, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v6, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto/16 :goto_6
:cond_4
iget-object v1, v0, Lf/n/a/k/b;->a:Lf/n/a/k/b$a;
check-cast v1, Lf/n/a/k/b$b;
iget-object v1, v1, Lf/n/a/k/b$b;->a:Ljava/io/InputStream;
invoke-virtual {v1}, Ljava/io/InputStream;->read()I
move-result v1
and-int/2addr v1, v2
int-to-short v1, v1
const/16 v2, 0xda
if-ne v1, v2, :cond_5
goto/16 :goto_6
:cond_5
const/16 v2, 0xd9
if-ne v1, v2, :cond_6
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v1
if-eqz v1, :cond_b
const-string v1, "Found MARKER_EOI in exif segment"
invoke-static {v6, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_6
:cond_6
iget-object v2, v0, Lf/n/a/k/b;->a:Lf/n/a/k/b$a;
check-cast v2, Lf/n/a/k/b$b;
invoke-virtual {v2}, Lf/n/a/k/b$b;->a()I
move-result v2
add-int/lit8 v2, v2, -0x2
const/16 v8, 0xe1
if-eq v1, v8, :cond_d
iget-object v8, v0, Lf/n/a/k/b;->a:Lf/n/a/k/b$a;
int-to-long v9, v2
check-cast v8, Lf/n/a/k/b$b;
if-eqz v8, :cond_c
const-wide/16 v11, 0x0
cmp-long v13, v9, v11
if-gez v13, :cond_7
goto :goto_5
:cond_7
move-wide v13, v9
:goto_2
cmp-long v15, v13, v11
if-lez v15, :cond_a
iget-object v15, v8, Lf/n/a/k/b$b;->a:Ljava/io/InputStream;
invoke-virtual {v15, v13, v14}, Ljava/io/InputStream;->skip(J)J
move-result-wide v15
cmp-long v17, v15, v11
if-lez v17, :cond_8
goto :goto_3
:cond_8
iget-object v15, v8, Lf/n/a/k/b$b;->a:Ljava/io/InputStream;
invoke-virtual {v15}, Ljava/io/InputStream;->read()I
move-result v15
if-ne v15, v4, :cond_9
goto :goto_4
:cond_9
const-wide/16 v15, 0x1
:goto_3
sub-long/2addr v13, v15
goto :goto_2
:cond_a
:goto_4
sub-long v11, v9, v13
:goto_5
cmp-long v8, v11, v9
if-eqz v8, :cond_3
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v8
if-eqz v8, :cond_b
const-string v8, "Unable to skip enough data, type: "
const-string v9, ", wanted to skip: "
const-string v10, ", but actually skipped: "
invoke-static {v8, v1, v9, v2, v10}, Lf/e/b/a/a;->G(Ljava/lang/String;ILjava/lang/String;ILjava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, v11, v12}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v6, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_b
:goto_6
const/4 v2, -0x1
goto :goto_7
:cond_c
throw v7
:cond_d
:goto_7
if-ne v2, v4, :cond_f
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v1
if-eqz v1, :cond_e
const-string v1, "Failed to parse exif segment length, or exif segment not found"
invoke-static {v6, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_e
return v4
:cond_f
new-array v1, v2, [B
iget-object v8, v0, Lf/n/a/k/b;->a:Lf/n/a/k/b$a;
check-cast v8, Lf/n/a/k/b$b;
if-eqz v8, :cond_25
move v7, v2
:goto_8
if-lez v7, :cond_10
iget-object v9, v8, Lf/n/a/k/b$b;->a:Ljava/io/InputStream;
sub-int v10, v2, v7
invoke-virtual {v9, v1, v10, v7}, Ljava/io/InputStream;->read([BII)I
move-result v9
if-eq v9, v4, :cond_10
sub-int/2addr v7, v9
goto :goto_8
:cond_10
sub-int v7, v2, v7
if-eq v7, v2, :cond_11
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v1
if-eqz v1, :cond_24
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Unable to read exif segment data, length: "
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, ", actually read: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v6, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto/16 :goto_12
:cond_11
sget-object v7, Lf/n/a/k/b;->b:[B
array-length v7, v7
if-le v2, v7, :cond_12
const/4 v7, 0x1
goto :goto_9
:cond_12
const/4 v7, 0x0
:goto_9
if-eqz v7, :cond_14
const/4 v8, 0x0
:goto_a
sget-object v9, Lf/n/a/k/b;->b:[B
array-length v10, v9
if-ge v8, v10, :cond_14
aget-byte v10, v1, v8
aget-byte v9, v9, v8
if-eq v10, v9, :cond_13
const/4 v7, 0x0
goto :goto_b
:cond_13
add-int/lit8 v8, v8, 0x1
goto :goto_a
:cond_14
:goto_b
if-eqz v7, :cond_23
invoke-static {v1}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;
move-result-object v1
sget-object v7, Ljava/nio/ByteOrder;->BIG_ENDIAN:Ljava/nio/ByteOrder;
invoke-virtual {v1, v7}, Ljava/nio/ByteBuffer;->order(Ljava/nio/ByteOrder;)Ljava/nio/ByteBuffer;
move-result-object v1
invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->limit(I)Ljava/nio/Buffer;
move-result-object v1
check-cast v1, Ljava/nio/ByteBuffer;
const/4 v2, 0x6
invoke-virtual {v1, v2}, Ljava/nio/ByteBuffer;->getShort(I)S
move-result v7
if-ne v7, v5, :cond_15
sget-object v5, Ljava/nio/ByteOrder;->BIG_ENDIAN:Ljava/nio/ByteOrder;
goto :goto_c
:cond_15
const/16 v5, 0x4949
if-ne v7, v5, :cond_16
sget-object v5, Ljava/nio/ByteOrder;->LITTLE_ENDIAN:Ljava/nio/ByteOrder;
goto :goto_c
:cond_16
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v5
if-eqz v5, :cond_17
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v8, "Unknown endianness = "
invoke-virtual {v5, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {v6, v5}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_17
sget-object v5, Ljava/nio/ByteOrder;->BIG_ENDIAN:Ljava/nio/ByteOrder;
:goto_c
invoke-virtual {v1, v5}, Ljava/nio/ByteBuffer;->order(Ljava/nio/ByteOrder;)Ljava/nio/ByteBuffer;
const/16 v5, 0xa
invoke-virtual {v1, v5}, Ljava/nio/ByteBuffer;->getInt(I)I
move-result v5
add-int/2addr v5, v2
invoke-virtual {v1, v5}, Ljava/nio/ByteBuffer;->getShort(I)S
move-result v2
const/4 v7, 0x0
:goto_d
if-ge v7, v2, :cond_24
add-int/lit8 v8, v5, 0x2
mul-int/lit8 v9, v7, 0xc
add-int/2addr v9, v8
invoke-virtual {v1, v9}, Ljava/nio/ByteBuffer;->getShort(I)S
move-result v8
const/16 v10, 0x112
if-eq v8, v10, :cond_18
goto/16 :goto_11
:cond_18
add-int/lit8 v10, v9, 0x2
invoke-virtual {v1, v10}, Ljava/nio/ByteBuffer;->getShort(I)S
move-result v10
const/4 v11, 0x1
if-lt v10, v11, :cond_21
const/16 v11, 0xc
if-le v10, v11, :cond_19
goto/16 :goto_10
:cond_19
add-int/lit8 v11, v9, 0x4
invoke-virtual {v1, v11}, Ljava/nio/ByteBuffer;->getInt(I)I
move-result v11
if-gez v11, :cond_1a
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v8
if-eqz v8, :cond_22
const-string v8, "Negative tiff component count"
invoke-static {v6, v8}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto/16 :goto_11
:cond_1a
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v12
const-string v13, " tagType="
if-eqz v12, :cond_1b
const-string v12, "Got tagIndex="
const-string v14, " formatCode="
invoke-static {v12, v7, v13, v8, v14}, Lf/e/b/a/a;->G(Ljava/lang/String;ILjava/lang/String;ILjava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v12
invoke-virtual {v12, v10}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v14, " componentCount="
invoke-virtual {v12, v14}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v12, v11}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v12
invoke-static {v6, v12}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_1b
sget-object v12, Lf/n/a/k/b;->c:[I
aget v12, v12, v10
add-int/2addr v11, v12
const/4 v12, 0x4
if-le v11, v12, :cond_1c
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v8
if-eqz v8, :cond_22
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "Got byte count > 4, not orientation, continuing, formatCode="
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v10}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-static {v6, v8}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto/16 :goto_11
:cond_1c
add-int/lit8 v9, v9, 0x8
if-ltz v9, :cond_20
invoke-virtual {v1}, Ljava/nio/ByteBuffer;->remaining()I
move-result v10
if-le v9, v10, :cond_1d
goto :goto_f
:cond_1d
if-ltz v11, :cond_1f
add-int/2addr v11, v9
invoke-virtual {v1}, Ljava/nio/ByteBuffer;->remaining()I
move-result v10
if-le v11, v10, :cond_1e
goto :goto_e
:cond_1e
invoke-virtual {v1, v9}, Ljava/nio/ByteBuffer;->getShort(I)S
move-result v4
goto :goto_12
:cond_1f
:goto_e
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v9
if-eqz v9, :cond_22
new-instance v9, Ljava/lang/StringBuilder;
invoke-direct {v9}, Ljava/lang/StringBuilder;-><init>()V
const-string v10, "Illegal number of bytes for TI tag data tagType="
invoke-virtual {v9, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v9, v8}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-static {v6, v8}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_11
:cond_20
:goto_f
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v10
if-eqz v10, :cond_22
new-instance v10, Ljava/lang/StringBuilder;
invoke-direct {v10}, Ljava/lang/StringBuilder;-><init>()V
const-string v11, "Illegal tagValueOffset="
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v10, v9}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v10, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v10, v8}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-static {v6, v8}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_11
:cond_21
:goto_10
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v8
if-eqz v8, :cond_22
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
const-string v9, "Got invalid format code = "
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v10}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v8
invoke-static {v6, v8}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_22
:goto_11
add-int/lit8 v7, v7, 0x1
goto/16 :goto_d
:cond_23
invoke-static {v6, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v1
if-eqz v1, :cond_24
const-string v1, "Missing jpeg exif preamble"
invoke-static {v6, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
:cond_24
:goto_12
return v4
:cond_25
throw v7
.end method