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 private static final INVALID_STATUS_CODE:I = -0x1
.field private static final MAXIMUM_REDIRECTS:I = 0x5
.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 27
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
.param p1, "glideUrl" # Lcom/bumptech/glide/load/model/GlideUrl;
.param p2, "timeout" # I
.line 41
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
.line 42
return-void
.end method
.method constructor <init>(Lcom/bumptech/glide/load/model/GlideUrl;ILcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;)V
.registers 4
.param p1, "glideUrl" # Lcom/bumptech/glide/load/model/GlideUrl;
.param p2, "timeout" # I
.param p3, "connectionFactory" # Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
.line 45
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 46
iput-object p1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->glideUrl:Lcom/bumptech/glide/load/model/GlideUrl;
.line 47
iput p2, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->timeout:I
.line 48
iput-object p3, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->connectionFactory:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
.line 49
return-void
.end method
.method private getStreamForSuccessfulRequest(Ljava/net/HttpURLConnection;)Ljava/io/InputStream;
.registers 6
.param p1, "urlConnection" # Ljava/net/HttpURLConnection;
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 138
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getContentEncoding()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v0
if-eqz v0, :cond_1a
.line 139
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getContentLength()I
move-result v0
.line 140
.local v0, "contentLength":I
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 v1
iput-object v1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
.line 141
.end local v0 # "contentLength":I
goto :goto_41
.line 142
:cond_1a
const/4 v0, 0x3
const-string v1, "HttpUrlFetcher"
invoke-static {v1, v0}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v0
if-eqz v0, :cond_3b
.line 143
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Got non empty content encoding: "
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/net/HttpURLConnection;->getContentEncoding()Ljava/lang/String;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v1, v0}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;)I
.line 145
:cond_3b
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;
.line 147
:goto_41
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
return-object v0
.end method
.method private static isHttpOk(I)Z
.registers 3
.param p0, "statusCode" # I
.line 128
div-int/lit8 v0, p0, 0x64
const/4 v1, 0x2
if-ne v0, v1, :cond_7
const/4 v0, 0x1
goto :goto_8
:cond_7
const/4 v0, 0x0
:goto_8
return v0
.end method
.method private static isHttpRedirect(I)Z
.registers 3
.param p0, "statusCode" # I
.line 133
div-int/lit8 v0, p0, 0x64
const/4 v1, 0x3
if-ne v0, v1, :cond_7
const/4 v0, 0x1
goto :goto_8
:cond_7
const/4 v0, 0x0
:goto_8
return v0
.end method
.method private loadDataWithRedirects(Ljava/net/URL;ILjava/net/URL;Ljava/util/Map;)Ljava/io/InputStream;
.registers 10
.param p1, "url" # Ljava/net/URL;
.param p2, "redirects" # I
.param p3, "lastUrl" # Ljava/net/URL;
.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 = {
Ljava/io/IOException;
}
.end annotation
.line 72
.local p4, "headers":Ljava/util/Map;, "Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;"
const/4 v0, 0x5
if-ge p2, v0, :cond_d2
.line 78
if-eqz p3, :cond_1e
:try_start_5
invoke-virtual {p1}, Ljava/net/URL;->toURI()Ljava/net/URI;
move-result-object v0
invoke-virtual {p3}, Ljava/net/URL;->toURI()Ljava/net/URI;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/net/URI;->equals(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_14
goto :goto_1e
.line 79
:cond_14
new-instance v0, Lcom/bumptech/glide/load/HttpException;
const-string v1, "In re-direct loop"
invoke-direct {v0, v1}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;)V
.end local p1 # "url":Ljava/net/URL;
.end local p2 # "redirects":I
.end local p3 # "lastUrl":Ljava/net/URL;
.end local p4 # "headers":Ljava/util/Map;, "Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;"
throw v0
:try_end_1c
.catch Ljava/net/URISyntaxException; {:try_start_5 .. :try_end_1c} :catch_1c
.line 81
.restart local p1 # "url":Ljava/net/URL;
.restart local p2 # "redirects":I
.restart local p3 # "lastUrl":Ljava/net/URL;
.restart local p4 # "headers":Ljava/util/Map;, "Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;"
:catch_1c
move-exception v0
goto :goto_1f
.line 83
:cond_1e
:goto_1e
nop
.line 86
:goto_1f
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->connectionFactory:Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;
invoke-interface {v0, p1}, Lcom/bumptech/glide/load/data/HttpUrlFetcher$HttpUrlConnectionFactory;->build(Ljava/net/URL;)Ljava/net/HttpURLConnection;
move-result-object v0
iput-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
.line 87
invoke-interface {p4}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_2f
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_4d
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 88
.local v1, "headerEntry":Ljava/util/Map$Entry;, "Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;"
iget-object v2, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/String;
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/lang/String;
invoke-virtual {v2, v3, v4}, Ljava/net/HttpURLConnection;->addRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
.line 89
.end local v1 # "headerEntry":Ljava/util/Map$Entry;, "Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/String;>;"
goto :goto_2f
.line 90
:cond_4d
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
iget v1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->timeout:I
invoke-virtual {v0, v1}, Ljava/net/HttpURLConnection;->setConnectTimeout(I)V
.line 91
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
iget v1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->timeout:I
invoke-virtual {v0, v1}, Ljava/net/HttpURLConnection;->setReadTimeout(I)V
.line 92
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
const/4 v1, 0x0
invoke-virtual {v0, v1}, Ljava/net/HttpURLConnection;->setUseCaches(Z)V
.line 93
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
const/4 v2, 0x1
invoke-virtual {v0, v2}, Ljava/net/HttpURLConnection;->setDoInput(Z)V
.line 97
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-virtual {v0, v1}, Ljava/net/HttpURLConnection;->setInstanceFollowRedirects(Z)V
.line 100
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->connect()V
.line 102
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-virtual {v0}, 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;
.line 103
iget-boolean v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isCancelled:Z
if-eqz v0, :cond_7f
.line 104
const/4 v0, 0x0
return-object v0
.line 106
:cond_7f
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result v0
.line 107
.local v0, "statusCode":I
invoke-static {v0}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isHttpOk(I)Z
move-result v1
if-eqz v1, :cond_92
.line 108
iget-object v1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-direct {p0, v1}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->getStreamForSuccessfulRequest(Ljava/net/HttpURLConnection;)Ljava/io/InputStream;
move-result-object v1
return-object v1
.line 109
:cond_92
invoke-static {v0}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isHttpRedirect(I)Z
move-result v1
if-eqz v1, :cond_bd
.line 110
iget-object v1, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
const-string v2, "Location"
invoke-virtual {v1, v2}, Ljava/net/HttpURLConnection;->getHeaderField(Ljava/lang/String;)Ljava/lang/String;
move-result-object v1
.line 111
.local v1, "redirectUrlString":Ljava/lang/String;
invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z
move-result v2
if-nez v2, :cond_b5
.line 114
new-instance v2, Ljava/net/URL;
invoke-direct {v2, p1, v1}, Ljava/net/URL;-><init>(Ljava/net/URL;Ljava/lang/String;)V
.line 117
.local v2, "redirectUrl":Ljava/net/URL;
invoke-virtual {p0}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->cleanup()V
.line 118
add-int/lit8 v3, p2, 0x1
invoke-direct {p0, v2, v3, p1, p4}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->loadDataWithRedirects(Ljava/net/URL;ILjava/net/URL;Ljava/util/Map;)Ljava/io/InputStream;
move-result-object v3
return-object v3
.line 112
.end local v2 # "redirectUrl":Ljava/net/URL;
:cond_b5
new-instance v2, Lcom/bumptech/glide/load/HttpException;
const-string v3, "Received empty or null redirect url"
invoke-direct {v2, v3}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;)V
throw v2
.line 119
.end local v1 # "redirectUrlString":Ljava/lang/String;
:cond_bd
const/4 v1, -0x1
if-ne v0, v1, :cond_c6
.line 120
new-instance v1, Lcom/bumptech/glide/load/HttpException;
invoke-direct {v1, v0}, Lcom/bumptech/glide/load/HttpException;-><init>(I)V
throw v1
.line 122
:cond_c6
new-instance v1, Lcom/bumptech/glide/load/HttpException;
iget-object v2, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
invoke-virtual {v2}, Ljava/net/HttpURLConnection;->getResponseMessage()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2, v0}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;I)V
throw v1
.line 73
.end local v0 # "statusCode":I
:cond_d2
new-instance v0, Lcom/bumptech/glide/load/HttpException;
const-string v1, "Too many (> 5) redirects!"
invoke-direct {v0, v1}, Lcom/bumptech/glide/load/HttpException;-><init>(Ljava/lang/String;)V
goto :goto_db
:goto_da
throw v0
:goto_db
goto :goto_da
.end method
# virtual methods
.method public cancel()V
.registers 2
.line 169
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->isCancelled:Z
.line 170
return-void
.end method
.method public cleanup()V
.registers 2
.line 152
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->stream:Ljava/io/InputStream;
if-eqz v0, :cond_9
.line 154
: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_8
.line 157
goto :goto_9
.line 155
:catch_8
move-exception v0
.line 159
:cond_9
:goto_9
iget-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
if-eqz v0, :cond_10
.line 160
invoke-virtual {v0}, Ljava/net/HttpURLConnection;->disconnect()V
.line 162
:cond_10
const/4 v0, 0x0
iput-object v0, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->urlConnection:Ljava/net/HttpURLConnection;
.line 163
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 175
const-class v0, Ljava/io/InputStream;
return-object v0
.end method
.method public getDataSource()Lcom/bumptech/glide/load/DataSource;
.registers 2
.line 181
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 12
.param p1, "priority" # Lcom/bumptech/glide/Priority;
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/bumptech/glide/Priority;",
"Lcom/bumptech/glide/load/data/DataFetcher$DataCallback<",
"-",
"Ljava/io/InputStream;",
">;)V"
}
.end annotation
.line 54
.local p2, "callback":Lcom/bumptech/glide/load/data/DataFetcher$DataCallback;, "Lcom/bumptech/glide/load/data/DataFetcher$DataCallback<-Ljava/io/InputStream;>;"
const-string v0, "Finished http url fetcher fetch in "
const-string v1, "HttpUrlFetcher"
invoke-static {}, Lcom/bumptech/glide/util/LogTime;->getLogTime()J
move-result-wide v2
.line 56
.local v2, "startTime":J
const/4 v4, 0x2
:try_start_9
iget-object v5, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->glideUrl:Lcom/bumptech/glide/load/model/GlideUrl;
invoke-virtual {v5}, Lcom/bumptech/glide/load/model/GlideUrl;->toURL()Ljava/net/URL;
move-result-object v5
const/4 v6, 0x0
const/4 v7, 0x0
iget-object v8, p0, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->glideUrl:Lcom/bumptech/glide/load/model/GlideUrl;
invoke-virtual {v8}, Lcom/bumptech/glide/load/model/GlideUrl;->getHeaders()Ljava/util/Map;
move-result-object v8
invoke-direct {p0, v5, v6, v7, v8}, Lcom/bumptech/glide/load/data/HttpUrlFetcher;->loadDataWithRedirects(Ljava/net/URL;ILjava/net/URL;Ljava/util/Map;)Ljava/io/InputStream;
move-result-object v5
.line 57
.local v5, "result":Ljava/io/InputStream;
invoke-interface {p2, v5}, 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 64
.end local v5 # "result":Ljava/io/InputStream;
invoke-static {v1, v4}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v4
if-eqz v4, :cond_58
.line 65
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
goto :goto_47
.line 64
:catchall_2a
move-exception v5
goto :goto_59
.line 58
:catch_2c
move-exception v5
.line 59
.local v5, "e":Ljava/io/IOException;
const/4 v6, 0x3
:try_start_2e
invoke-static {v1, v6}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v6
if-eqz v6, :cond_39
.line 60
const-string v6, "Failed to load data for url"
invoke-static {v1, v6, v5}, Landroid/util/Log;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 62
:cond_39
invoke-interface {p2, v5}, 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 64
.end local v5 # "e":Ljava/io/IOException;
invoke-static {v1, v4}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v4
if-eqz v4, :cond_58
.line 65
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
:goto_47
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {v2, v3}, Lcom/bumptech/glide/util/LogTime;->getElapsedMillis(J)D
move-result-wide v5
invoke-virtual {v4, v5, v6}, Ljava/lang/StringBuilder;->append(D)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v1, v0}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
.line 68
:cond_58
return-void
.line 64
:goto_59
invoke-static {v1, v4}, Landroid/util/Log;->isLoggable(Ljava/lang/String;I)Z
move-result v4
if-eqz v4, :cond_75
.line 65
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {v2, v3}, Lcom/bumptech/glide/util/LogTime;->getElapsedMillis(J)D
move-result-wide v6
invoke-virtual {v4, v6, v7}, Ljava/lang/StringBuilder;->append(D)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v1, v0}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
:cond_75
throw v5
.end method