HttpUrlFetcher.smali
.class public Lcom/bumptech/glide/load/data/HttpUrlFetcher;
.super Ljava/lang/Object;
.source "HttpUrlFetcher.java"
# interfaces
.implements Lcom/bumptech/glide/load/data/DataFetcher;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/bumptech/glide/load/data/HttpUrlFetcher$DefaultHttpUrlConnectionFactory;,
Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
}
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/Object;",
"Lcom/bumptech/glide/load/data/DataFetcher<",
"Ljava/io/InputStream;",
">;"
}
.end annotation
# static fields
.field static final DEFAULT_CONNECTION_FACTORY:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
.field static final INVALID_STATUS_CODE:I = -0x1
.field private static final MAXIMUM_REDIRECTS:I = 0x5
.field static final REDIRECT_HEADER_FIELD:Ljava/lang/String; = "Location"
.field private static final TAG:Ljava/lang/String; = "HttpUrlFetcher"
# instance fields
.field private final connectionFactory:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
.field private final glideUrl:Lcom/bumptech/glide/load/model/GlideUrl;
.field private volatile isCancelled:Z
.field private stream:Ljava/io/InputStream;
.field private final timeout:I
.field private urlConnection:Ljava/net/HttpURLConnection;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 29
new-instance v0, Lcom/bumptech/glide/load/data/HttpUrlFetcher$DefaultHttpUrlConnectionFactory;
invoke-direct {v0}, Lcom/bumptech/glide/load/data/HttpUrlFetcher$DefaultHttpUrlConnectionFactory;-><init>()V
sput-object v0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->DEFAULT_CONNECTION_FACTORY:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
return-void
.end method
.method public constructor <init>(Lcom/bumptech/glide/load/model/GlideUrl;I)V
.registers 4
.line 43
sget-object v0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->DEFAULT_CONNECTION_FACTORY:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
invoke-direct {p0, p1, p2, v0}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;-><init>(Lcom/bumptech/glide/load/model/GlideUrl;ILcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;)V
return-void
.end method
.method constructor <init>(Lcom/bumptech/glide/load/model/GlideUrl;ILcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;)V
.registers 4
.line 47
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 48
iput-object p1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->glideUrl:Lcom/bumptech/glide/load/model/GlideUrl;
.line 49
iput p2, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->timeout:I
.line 50
iput-object p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->connectionFactory:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
return-void
.end method
.method private buildAndConfigureConnection(Ljava/net/URL;Ljava/util/Map;)Ljava/net/HttpURLConnection;
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/net/URL;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)",
"Ljava/net/HttpURLConnection;"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/bumptech/glide/load/HttpException;
}
.end annotation
const/4 v0, 0x0
.line 149
:try_start_1
iget-object v1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->connectionFactory:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
invoke-interface {v1, p1}, Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;->build(Ljava/net/URL;)Ljava/net/HttpURLConnection;
move-result-object p1
:try_end_7
.catch Ljava/io/IOException; {:try_start_1 .. :try_end_7} :catch_40
.line 153
invoke-interface {p2}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object p2
invoke-interface {p2}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object p2
:goto_f
invoke-interface {p2}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_2b
invoke-interface {p2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 154
invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/String;
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/String;
invoke-virtual {p1, v2, v1}, Ljava/net/HttpURLConnection;->addRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_f
.line 156
:cond_2b
iget p2, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->timeout:I
invoke-virtual {p1, p2}, Ljava/net/HttpURLConnection;->setConnectTimeout(I)V
.line 157
iget p2, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->timeout:I
invoke-virtual {p1, p2}, Ljava/net/HttpURLConnection;->setReadTimeout(I)V
.line 158
invoke-virtual {p1, v0}, Ljava/net/HttpURLConnection;->setUseCaches(Z)V
const/4 p2, 0x1
.line 159
invoke-virtual {p1, p2}, Ljava/net/HttpURLConnection;->setDoInput(Z)V
.line 162
invoke-virtual {p1, v0}, Ljava/net/HttpURLConnection;->setInstanceFollowRedirects(Z)V
return-object p1
:catch_40
move-exception p1
.line 151
new-instance p2, Lcom/bumptech/glide/load/HttpException;
const-string v1, "URL.openConnection threw"
invoke-direct {p2, v1, v0, p1}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;ILjava/lang/Throwable;)V
throw p2
.end method
.method private static getHttpStatusCodeOrInvalid(Ljava/net/HttpURLConnection;)I
.registers 3
.line 136
:try_start_0
invoke-virtual {p0}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result p0
:try_end_4
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_4} :catch_5
return p0
:catch_5
move-exception p0
const/4 v0, 0x3
const-string v1, "HttpUrlFetcher"
.line 138
invoke-static {v1, v0}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v0
if-eqz v0, :cond_14
const-string v0, "Failed to get a response code"
.line 139
invoke-static {v1, v0, p0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:cond_14
const/4 p0, -0x1
return p0
.end method
.method private getStreamForSuccessfulRequest(Ljava/net/HttpURLConnection;)Ljava/io/InputStream;
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/bumptech/glide/load/HttpException;
}
.end annotation
const-string v0, "HttpUrlFetcher"
.line 179
:try_start_2
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getContentEncoding()Ljava/lang/String;
move-result-object v1
invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v1
if-eqz v1, :cond_1c
.line 180
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getContentLength()I
move-result v0
.line 181
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v1
int-to-long v2, v0
invoke-static {v1, v2, v3}, Lcom/bumptech/glide/util/ContentLengthInputStream;->obtain(Ljava/io/InputStream;J)Ljava/io/InputStream;
move-result-object v0
iput-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
goto :goto_43
:cond_1c
const/4 v1, 0x3
.line 183
invoke-static {v0, v1}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v1
if-eqz v1, :cond_3d
.line 184
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Got non empty content encoding: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getContentEncoding()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 186
:cond_3d
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v0
iput-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
:try_end_43
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_43} :catch_46
.line 192
:goto_43
iget-object p1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
return-object p1
:catch_46
move-exception v0
.line 189
new-instance v1, Lcom/bumptech/glide/load/HttpException;
.line 190
invoke-static {p1}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->getHttpStatusCodeOrInvalid(Ljava/net/HttpURLConnection;)I
move-result p1
const-string v2, "Failed to obtain InputStream"
invoke-direct {v1, v2, p1, v0}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;ILjava/lang/Throwable;)V
throw v1
.end method
.method private static isHttpOk(I)Z
.registers 2
.line 168
div-int/lit8 p0, p0, 0x64
const/4 v0, 0x2
if-ne p0, v0, :cond_7
const/4 p0, 0x1
goto :goto_8
:cond_7
const/4 p0, 0x0
:goto_8
return p0
.end method
.method private static isHttpRedirect(I)Z
.registers 2
.line 173
div-int/lit8 p0, p0, 0x64
const/4 v0, 0x3
if-ne p0, v0, :cond_7
const/4 p0, 0x1
goto :goto_8
:cond_7
const/4 p0, 0x0
:goto_8
return p0
.end method
.method private loadDataWithRedirects(Ljava/net/URL;ILjava/net/URL;Ljava/util/Map;)Ljava/io/InputStream;
.registers 7
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/net/URL;",
"I",
"Ljava/net/URL;",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;)",
"Ljava/io/InputStream;"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/bumptech/glide/load/HttpException;
}
.end annotation
const/4 v0, -0x1
const/4 v1, 0x5
if-ge p2, v1, :cond_b8
if-eqz p3, :cond_1d
.line 81
:try_start_6
invoke-virtual {p1}, Ljava/net/URL;->toURI()Ljava/net/URI;
move-result-object v1
invoke-virtual {p3}, Ljava/net/URL;->toURI()Ljava/net/URI;
move-result-object p3
invoke-virtual {v1, p3}, Ljava/net/URI;->equals(Ljava/lang/Object;)Z
move-result p3
if-nez p3, :cond_15
goto :goto_1d
.line 82
:cond_15
new-instance p3, Lcom/bumptech/glide/load/HttpException;
const-string v1, "In re-direct loop"
invoke-direct {p3, v1, v0}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;I)V
throw p3
:try_end_1d
.catch Ljava/net/URISyntaxException; {:try_start_6 .. :try_end_1d} :catch_1d
.line 89
:catch_1d
:cond_1d
:goto_1d
invoke-direct {p0, p1, p4}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->buildAndConfigureConnection(Ljava/net/URL;Ljava/util/Map;)Ljava/net/HttpURLConnection;
move-result-object p3
iput-object p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
.line 93
:try_start_23
invoke-virtual {p3}, Ljava/net/HttpURLConnection;->connect()V
.line 95
iget-object p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-virtual {p3}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object p3
iput-object p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
:try_end_2e
.catch Ljava/io/IOException; {:try_start_23 .. :try_end_2e} :catch_a9
.line 101
iget-boolean p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isCancelled:Z
if-eqz p3, :cond_34
const/4 p1, 0x0
return-object p1
.line 105
:cond_34
iget-object p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-static {p3}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->getHttpStatusCodeOrInvalid(Ljava/net/HttpURLConnection;)I
move-result p3
.line 106
invoke-static {p3}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isHttpOk(I)Z
move-result v1
if-eqz v1, :cond_47
.line 107
iget-object p1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-direct {p0, p1}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->getStreamForSuccessfulRequest(Ljava/net/HttpURLConnection;)Ljava/io/InputStream;
move-result-object p1
return-object p1
.line 108
:cond_47
invoke-static {p3}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isHttpRedirect(I)Z
move-result v1
if-eqz v1, :cond_8c
.line 109
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
const-string v1, "Location"
invoke-virtual {v0, v1}, Ljava/net/HttpURLConnection;->getHeaderField(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
.line 110
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v1
if-nez v1, :cond_84
.line 115
:try_start_5b
new-instance v1, Ljava/net/URL;
invoke-direct {v1, p1, v0}, Ljava/net/URL;-><init>(Ljava/net/URL;Ljava/lang/String;)V
:try_end_60
.catch Ljava/net/MalformedURLException; {:try_start_5b .. :try_end_60} :catch_6a
.line 121
invoke-virtual {p0}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->cleanup()V
add-int/lit8 p2, p2, 0x1
.line 122
invoke-direct {p0, v1, p2, p1, p4}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->loadDataWithRedirects(Ljava/net/URL;ILjava/net/URL;Ljava/util/Map;)Ljava/io/InputStream;
move-result-object p1
return-object p1
:catch_6a
move-exception p1
.line 117
new-instance p2, Lcom/bumptech/glide/load/HttpException;
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Bad redirect url: "
invoke-virtual {p4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p4
invoke-virtual {p4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p4
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
invoke-direct {p2, p4, p3, p1}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;ILjava/lang/Throwable;)V
throw p2
.line 111
:cond_84
new-instance p1, Lcom/bumptech/glide/load/HttpException;
const-string p2, "Received empty or null redirect url"
invoke-direct {p1, p2, p3}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;I)V
throw p1
:cond_8c
if-ne p3, v0, :cond_94
.line 124
new-instance p1, Lcom/bumptech/glide/load/HttpException;
invoke-direct {p1, p3}, Lcom/bumptech/glide/load/HttpException;-><init>(I)V
throw p1
.line 127
:cond_94
:try_start_94
new-instance p1, Lcom/bumptech/glide/load/HttpException;
iget-object p2, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-virtual {p2}, Ljava/net/HttpURLConnection;->getResponseMessage()Ljava/lang/String;
move-result-object p2
invoke-direct {p1, p2, p3}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;I)V
throw p1
:try_end_a0
.catch Ljava/io/IOException; {:try_start_94 .. :try_end_a0} :catch_a0
:catch_a0
move-exception p1
.line 129
new-instance p2, Lcom/bumptech/glide/load/HttpException;
const-string p4, "Failed to get a response message"
invoke-direct {p2, p4, p3, p1}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;ILjava/lang/Throwable;)V
throw p2
:catch_a9
move-exception p1
.line 97
new-instance p2, Lcom/bumptech/glide/load/HttpException;
iget-object p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
.line 98
invoke-static {p3}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->getHttpStatusCodeOrInvalid(Ljava/net/HttpURLConnection;)I
move-result p3
const-string p4, "Failed to connect or obtain data"
invoke-direct {p2, p4, p3, p1}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;ILjava/lang/Throwable;)V
throw p2
.line 75
:cond_b8
new-instance p1, Lcom/bumptech/glide/load/HttpException;
const-string p2, "Too many (> 5) redirects!"
invoke-direct {p1, p2, v0}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;I)V
throw p1
.end method
# virtual methods
.method public cancel()V
.registers 2
const/4 v0, 0x1
.line 214
iput-boolean v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isCancelled:Z
return-void
.end method
.method public cleanup()V
.registers 2
.line 197
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
if-eqz v0, :cond_7
.line 199
:try_start_4
invoke-virtual {v0}, Ljava/io/InputStream;->close()V
:try_end_7
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_7} :catch_7
.line 204
:catch_7
:cond_7
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
if-eqz v0, :cond_e
.line 205
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_e
const/4 v0, 0x0
.line 207
iput-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
return-void
.end method
.method public getDataClass()Ljava/lang/Class;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/lang/Class<",
"Ljava/io/InputStream;",
">;"
}
.end annotation
.line 220
const-class v0, Ljava/io/InputStream;
return-object v0
.end method
.method public getDataSource()Lcom/bumptech/glide/load/DataSource;
.registers 2
.line 226
sget-object v0, Lcom/bumptech/glide/load/DataSource;->REMOTE:Lcom/bumptech/glide/load/DataSource;
return-object v0
.end method
.method public loadData(Lcom/bumptech/glide/Priority;Lcom/bumptech/glide/load/data/DataFetcher$DataCallback;)V
.registers 11
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/bumptech/glide/Priority;",
"Lcom/bumptech/glide/load/data/DataFetcher$DataCallback<",
"-",
"Ljava/io/InputStream;",
">;)V"
}
.end annotation
const-string p1, "Finished http url fetcher fetch in "
const-string v0, "HttpUrlFetcher"
.line 56
invoke-static {}, Lcom/bumptech/glide/util/LogTime;->getLogTime()J
move-result-wide v1
const/4 v3, 0x2
.line 58
:try_start_9
iget-object v4, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->glideUrl:Lcom/bumptech/glide/load/model/GlideUrl;
invoke-virtual {v4}, Lcom/bumptech/glide/load/model/GlideUrl;->toURL()Ljava/net/URL;
move-result-object v4
const/4 v5, 0x0
const/4 v6, 0x0
iget-object v7, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->glideUrl:Lcom/bumptech/glide/load/model/GlideUrl;
invoke-virtual {v7}, Lcom/bumptech/glide/load/model/GlideUrl;->getHeaders()Ljava/util/Map;
move-result-object v7
invoke-direct {p0, v4, v5, v6, v7}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->loadDataWithRedirects(Ljava/net/URL;ILjava/net/URL;Ljava/util/Map;)Ljava/io/InputStream;
move-result-object v4
.line 59
invoke-interface {p2, v4}, Lcom/bumptech/glide/load/data/DataFetcher$DataCallback;->onDataReady(Ljava/lang/Object;)V
:try_end_1e
.catch Ljava/io/IOException; {:try_start_9 .. :try_end_1e} :catch_2c
.catchall {:try_start_9 .. :try_end_1e} :catchall_2a
.line 66
invoke-static {v0, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result p2
if-eqz p2, :cond_5a
.line 67
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
goto :goto_47
:catchall_2a
move-exception p2
goto :goto_5b
:catch_2c
move-exception v4
const/4 v5, 0x3
.line 61
:try_start_2e
invoke-static {v0, v5}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v5
if-eqz v5, :cond_39
const-string v5, "Failed to load data for url"
.line 62
invoke-static {v0, v5, v4}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 64
:cond_39
invoke-interface {p2, v4}, Lcom/bumptech/glide/load/data/DataFetcher$DataCallback;->onLoadFailed(Ljava/lang/Exception;)V
:try_end_3c
.catchall {:try_start_2e .. :try_end_3c} :catchall_2a
.line 66
invoke-static {v0, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result p2
if-eqz p2, :cond_5a
.line 67
new-instance p2, Ljava/lang/StringBuilder;
invoke-direct {p2}, Ljava/lang/StringBuilder;-><init>()V
:goto_47
invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p1
invoke-static {v1, v2}, Lcom/bumptech/glide/util/LogTime;->getElapsedMillis(J)D
move-result-wide v1
invoke-virtual {p1, v1, v2}, Ljava/lang/StringBuilder;->append(D)Ljava/lang/StringBuilder;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
:cond_5a
return-void
.line 66
:goto_5b
invoke-static {v0, v3}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v3
if-eqz v3, :cond_79
.line 67
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object p1
invoke-static {v1, v2}, Lcom/bumptech/glide/util/LogTime;->getElapsedMillis(J)D
move-result-wide v1
invoke-virtual {p1, v1, v2}, Ljava/lang/StringBuilder;->append(D)Ljava/lang/StringBuilder;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-static {v0, p1}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
:cond_79
throw p2
.end method