a.smali
.class public final Lcom/android/volley/toolbox/a;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/android/volley/f;
# static fields
.field public static final c:Z
# instance fields
.field public final a:Lcom/android/volley/toolbox/c;
.field public final b:Lcom/android/volley/toolbox/b;
# direct methods
.method public static constructor <clinit>()V
.registers 1
sget-boolean v0, Lcom/android/volley/r;->a:Z
sput-boolean v0, Lcom/android/volley/toolbox/a;->c:Z
return-void
.end method
.method public constructor <init>(Lcom/android/volley/toolbox/c;)V
.registers 3
.line 1
new-instance v0, Lcom/android/volley/toolbox/b;
invoke-direct {v0}, Lcom/android/volley/toolbox/b;-><init>()V
.line 2
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 3
iput-object p1, p0, Lcom/android/volley/toolbox/a;->a:Lcom/android/volley/toolbox/c;
.line 4
iput-object v0, p0, Lcom/android/volley/toolbox/a;->b:Lcom/android/volley/toolbox/b;
return-void
.end method
.method public static a(Ljava/lang/String;Lcom/android/volley/k;Lcom/android/volley/q;)V
.registers 11
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/lang/String;",
"Lcom/android/volley/k<",
"*>;",
"Lcom/android/volley/q;",
")V"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/android/volley/q;
}
.end annotation
.line 1
iget-object v0, p1, Lcom/android/volley/k;->k:Lcom/android/volley/d;
.line 2
iget v1, v0, Lcom/android/volley/d;->a:I
const/4 v2, 0x1
const/4 v3, 0x0
const/4 v4, 0x2
.line 3
:try_start_7
iget v5, v0, Lcom/android/volley/d;->b:I
add-int/2addr v5, v2
iput v5, v0, Lcom/android/volley/d;->b:I
int-to-float v6, v1
const/high16 v7, 0x3f800000 # 1.0f
mul-float v7, v7, v6
add-float/2addr v7, v6
float-to-int v6, v7
.line 4
iput v6, v0, Lcom/android/volley/d;->a:I
.line 5
iget v0, v0, Lcom/android/volley/d;->c:I
:try_end_17
.catch Lcom/android/volley/q; {:try_start_7 .. :try_end_17} :catch_33
if-gt v5, v0, :cond_1b
const/4 v0, 0x1
goto :goto_1c
:cond_1b
const/4 v0, 0x0
:goto_1c
if-eqz v0, :cond_32
new-array p2, v4, [Ljava/lang/Object;
aput-object p0, p2, v3
.line 6
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p0
aput-object p0, p2, v2
const-string p0, "%s-retry [timeout=%s]"
invoke-static {p0, p2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
invoke-virtual {p1, p0}, Lcom/android/volley/k;->b(Ljava/lang/String;)V
return-void
.line 7
:cond_32
:try_start_32
throw p2
:try_end_33
.catch Lcom/android/volley/q; {:try_start_32 .. :try_end_33} :catch_33
:catch_33
move-exception p2
new-array v0, v4, [Ljava/lang/Object;
aput-object p0, v0, v3
.line 8
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p0
aput-object p0, v0, v2
const-string p0, "%s-timeout-giveup [timeout=%s]"
invoke-static {p0, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
invoke-virtual {p1, p0}, Lcom/android/volley/k;->b(Ljava/lang/String;)V
.line 9
throw p2
.end method
.method public static b([Lorg/apache/http/Header;)Ljava/util/Map;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"([",
"Lorg/apache/http/Header;",
")",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/String;",
">;"
}
.end annotation
.line 1
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
const/4 v1, 0x0
.line 2
:goto_6
array-length v2, p0
if-ge v1, v2, :cond_1b
.line 3
aget-object v2, p0, v1
invoke-interface {v2}, Lorg/apache/http/Header;->getName()Ljava/lang/String;
move-result-object v2
aget-object v3, p0, v1
invoke-interface {v3}, Lorg/apache/http/Header;->getValue()Ljava/lang/String;
move-result-object v3
invoke-virtual {v0, v2, v3}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
add-int/lit8 v1, v1, 0x1
goto :goto_6
:cond_1b
return-object v0
.end method
# virtual methods
.method public final c(Lorg/apache/http/HttpEntity;)[B
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;,
Lcom/android/volley/o;
}
.end annotation
const-string v0, "Error occured when calling consumingContent"
.line 1
new-instance v1, Lcom/android/volley/toolbox/e;
iget-object v2, p0, Lcom/android/volley/toolbox/a;->b:Lcom/android/volley/toolbox/b;
invoke-interface {p1}, Lorg/apache/http/HttpEntity;->getContentLength()J
move-result-wide v3
long-to-int v4, v3
invoke-direct {v1, v2, v4}, Lcom/android/volley/toolbox/e;-><init>(Lcom/android/volley/toolbox/b;I)V
const/4 v2, 0x0
const/4 v3, 0x0
.line 2
:try_start_10
invoke-interface {p1}, Lorg/apache/http/HttpEntity;->getContent()Ljava/io/InputStream;
move-result-object v4
if-eqz v4, :cond_3f
.line 3
iget-object v5, p0, Lcom/android/volley/toolbox/a;->b:Lcom/android/volley/toolbox/b;
const/16 v6, 0x400
invoke-virtual {v5, v6}, Lcom/android/volley/toolbox/b;->a(I)[B
move-result-object v3
.line 4
:goto_1e
invoke-virtual {v4, v3}, Ljava/io/InputStream;->read([B)I
move-result v5
const/4 v6, -0x1
if-eq v5, v6, :cond_29
.line 5
invoke-virtual {v1, v3, v2, v5}, Lcom/android/volley/toolbox/e;->write([BII)V
goto :goto_1e
.line 6
:cond_29
invoke-virtual {v1}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B
move-result-object v4
:try_end_2d
.catchall {:try_start_10 .. :try_end_2d} :catchall_45
.line 7
:try_start_2d
invoke-interface {p1}, Lorg/apache/http/HttpEntity;->consumeContent()V
:try_end_30
.catch Ljava/io/IOException; {:try_start_2d .. :try_end_30} :catch_31
goto :goto_36
:catch_31
new-array p1, v2, [Ljava/lang/Object;
.line 8
invoke-static {v0, p1}, Lcom/android/volley/r;->b(Ljava/lang/String;[Ljava/lang/Object;)V
.line 9
:goto_36
iget-object p1, p0, Lcom/android/volley/toolbox/a;->b:Lcom/android/volley/toolbox/b;
invoke-virtual {p1, v3}, Lcom/android/volley/toolbox/b;->b([B)V
.line 10
invoke-virtual {v1}, Lcom/android/volley/toolbox/e;->close()V
return-object v4
.line 11
:cond_3f
:try_start_3f
new-instance v4, Lcom/android/volley/o;
invoke-direct {v4}, Lcom/android/volley/o;-><init>()V
throw v4
:try_end_45
.catchall {:try_start_3f .. :try_end_45} :catchall_45
:catchall_45
move-exception v4
.line 12
:try_start_46
invoke-interface {p1}, Lorg/apache/http/HttpEntity;->consumeContent()V
:try_end_49
.catch Ljava/io/IOException; {:try_start_46 .. :try_end_49} :catch_4a
goto :goto_4f
:catch_4a
new-array p1, v2, [Ljava/lang/Object;
.line 13
invoke-static {v0, p1}, Lcom/android/volley/r;->b(Ljava/lang/String;[Ljava/lang/Object;)V
.line 14
:goto_4f
iget-object p1, p0, Lcom/android/volley/toolbox/a;->b:Lcom/android/volley/toolbox/b;
invoke-virtual {p1, v3}, Lcom/android/volley/toolbox/b;->b([B)V
.line 15
invoke-virtual {v1}, Lcom/android/volley/toolbox/e;->close()V
throw v4
.end method
.method public final d(JLcom/android/volley/k;[BLorg/apache/http/StatusLine;)V
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"(J",
"Lcom/android/volley/k<",
"*>;[B",
"Lorg/apache/http/StatusLine;",
")V"
}
.end annotation
.line 1
sget-boolean v0, Lcom/android/volley/toolbox/a;->c:Z
if-nez v0, :cond_b
const/16 v0, 0xbb8
int-to-long v0, v0
cmp-long v2, p1, v0
if-lez v2, :cond_40
:cond_b
const/4 v0, 0x5
new-array v0, v0, [Ljava/lang/Object;
const/4 v1, 0x0
aput-object p3, v0, v1
const/4 v1, 0x1
.line 2
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object p1
aput-object p1, v0, v1
const/4 p1, 0x2
if-eqz p4, :cond_21
array-length p2, p4
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
goto :goto_23
:cond_21
const-string p2, "null"
:goto_23
aput-object p2, v0, p1
const/4 p1, 0x3
invoke-interface {p5}, Lorg/apache/http/StatusLine;->getStatusCode()I
move-result p2
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
aput-object p2, v0, p1
const/4 p1, 0x4
.line 3
iget-object p2, p3, Lcom/android/volley/k;->k:Lcom/android/volley/d;
.line 4
iget p2, p2, Lcom/android/volley/d;->b:I
.line 5
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p2
aput-object p2, v0, p1
const-string p1, "HTTP response for request=<%s> [lifetime=%d], [size=%s], [rc=%d], [retryCount=%s]"
.line 6
invoke-static {p1, v0}, Lcom/android/volley/r;->a(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
:cond_40
return-void
.end method
.method public final e(Lcom/android/volley/k;)Lcom/android/volley/i;
.registers 19
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/android/volley/k<",
"*>;)",
"Lcom/android/volley/i;"
}
.end annotation
.annotation system Ldalvik/annotation/Throws;
value = {
Lcom/android/volley/q;
}
.end annotation
move-object/from16 v7, p0
move-object/from16 v8, p1
.line 1
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v9
.line 2
:goto_8
new-instance v1, Ljava/util/HashMap;
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
const/4 v11, 0x1
const/4 v12, 0x0
const/4 v2, 0x0
.line 3
:try_start_10
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
.line 4
iget-object v3, v7, Lcom/android/volley/toolbox/a;->a:Lcom/android/volley/toolbox/c;
check-cast v3, Lcom/android/volley/toolbox/d;
invoke-virtual {v3, v8, v0}, Lcom/android/volley/toolbox/d;->a(Lcom/android/volley/k;Ljava/util/Map;)Lorg/apache/http/HttpResponse;
move-result-object v13
:try_end_1d
.catch Ljava/net/SocketTimeoutException; {:try_start_10 .. :try_end_1d} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_10 .. :try_end_1d} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_10 .. :try_end_1d} :catch_d7
.catch Ljava/io/IOException; {:try_start_10 .. :try_end_1d} :catch_8b
.line 5
:try_start_1d
move-object v0, v13
check-cast v0, Lorg/apache/http/message/BasicHttpResponse;
invoke-virtual {v0}, Lorg/apache/http/message/BasicHttpResponse;->getStatusLine()Lorg/apache/http/StatusLine;
move-result-object v6
.line 6
invoke-interface {v6}, Lorg/apache/http/StatusLine;->getStatusCode()I
move-result v14
.line 7
invoke-interface {v13}, Lorg/apache/http/HttpResponse;->getAllHeaders()[Lorg/apache/http/Header;
move-result-object v3
invoke-static {v3}, Lcom/android/volley/toolbox/a;->b([Lorg/apache/http/Header;)Ljava/util/Map;
move-result-object v15
:try_end_30
.catch Ljava/net/SocketTimeoutException; {:try_start_1d .. :try_end_30} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_1d .. :try_end_30} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_1d .. :try_end_30} :catch_d7
.catch Ljava/io/IOException; {:try_start_1d .. :try_end_30} :catch_87
const/16 v1, 0x130
if-ne v14, v1, :cond_3c
.line 8
:try_start_34
new-instance v0, Lcom/android/volley/i;
invoke-direct {v0, v1, v2, v15, v11}, Lcom/android/volley/i;-><init>(I[BLjava/util/Map;Z)V
:try_end_39
.catch Ljava/net/SocketTimeoutException; {:try_start_34 .. :try_end_39} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_34 .. :try_end_39} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_34 .. :try_end_39} :catch_d7
.catch Ljava/io/IOException; {:try_start_34 .. :try_end_39} :catch_3a
return-object v0
:catch_3a
move-exception v0
goto :goto_80
.line 9
:cond_3c
:try_start_3c
invoke-virtual {v0}, Lorg/apache/http/message/BasicHttpResponse;->getEntity()Lorg/apache/http/HttpEntity;
move-result-object v1
:try_end_40
.catch Ljava/net/SocketTimeoutException; {:try_start_3c .. :try_end_40} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_3c .. :try_end_40} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_3c .. :try_end_40} :catch_d7
.catch Ljava/io/IOException; {:try_start_3c .. :try_end_40} :catch_84
if-eqz v1, :cond_4b
.line 10
:try_start_42
invoke-virtual {v0}, Lorg/apache/http/message/BasicHttpResponse;->getEntity()Lorg/apache/http/HttpEntity;
move-result-object v0
invoke-virtual {v7, v0}, Lcom/android/volley/toolbox/a;->c(Lorg/apache/http/HttpEntity;)[B
move-result-object v0
:try_end_4a
.catch Ljava/net/SocketTimeoutException; {:try_start_42 .. :try_end_4a} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_42 .. :try_end_4a} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_42 .. :try_end_4a} :catch_d7
.catch Ljava/io/IOException; {:try_start_42 .. :try_end_4a} :catch_3a
goto :goto_4d
:cond_4b
:try_start_4b
new-array v0, v12, [B
:try_end_4d
.catch Ljava/net/SocketTimeoutException; {:try_start_4b .. :try_end_4d} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_4b .. :try_end_4d} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_4b .. :try_end_4d} :catch_d7
.catch Ljava/io/IOException; {:try_start_4b .. :try_end_4d} :catch_84
:goto_4d
move-object v4, v0
.line 11
:try_start_4e
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
:try_end_52
.catch Ljava/net/SocketTimeoutException; {:try_start_4e .. :try_end_52} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_4e .. :try_end_52} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_4e .. :try_end_52} :catch_d7
.catch Ljava/io/IOException; {:try_start_4e .. :try_end_52} :catch_7d
sub-long v2, v0, v9
move-object/from16 v1, p0
move-object/from16 v16, v4
move-object/from16 v4, p1
move-object/from16 v5, v16
.line 12
:try_start_5c
invoke-virtual/range {v1 .. v6}, Lcom/android/volley/toolbox/a;->d(JLcom/android/volley/k;[BLorg/apache/http/StatusLine;)V
const/16 v0, 0xc8
if-lt v14, v0, :cond_6f
const/16 v0, 0x12b
if-gt v14, v0, :cond_6f
.line 13
new-instance v0, Lcom/android/volley/i;
:try_end_69
.catch Ljava/net/SocketTimeoutException; {:try_start_5c .. :try_end_69} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_5c .. :try_end_69} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_5c .. :try_end_69} :catch_d7
.catch Ljava/io/IOException; {:try_start_5c .. :try_end_69} :catch_79
move-object/from16 v1, v16
:try_start_6b
invoke-direct {v0, v14, v1, v15, v12}, Lcom/android/volley/i;-><init>(I[BLjava/util/Map;Z)V
return-object v0
:cond_6f
move-object/from16 v1, v16
.line 14
new-instance v0, Ljava/io/IOException;
invoke-direct {v0}, Ljava/io/IOException;-><init>()V
throw v0
:try_end_77
.catch Ljava/net/SocketTimeoutException; {:try_start_6b .. :try_end_77} :catch_f9
.catch Lorg/apache/http/conn/ConnectTimeoutException; {:try_start_6b .. :try_end_77} :catch_ed
.catch Ljava/net/MalformedURLException; {:try_start_6b .. :try_end_77} :catch_d7
.catch Ljava/io/IOException; {:try_start_6b .. :try_end_77} :catch_77
:catch_77
move-exception v0
goto :goto_7f
:catch_79
move-exception v0
move-object/from16 v1, v16
goto :goto_7f
:catch_7d
move-exception v0
move-object v1, v4
:goto_7f
move-object v2, v1
:goto_80
move-object v3, v2
move-object v2, v13
move-object v1, v15
goto :goto_8d
:catch_84
move-exception v0
move-object v1, v15
goto :goto_88
:catch_87
move-exception v0
:goto_88
move-object v3, v2
move-object v2, v13
goto :goto_8d
:catch_8b
move-exception v0
move-object v3, v2
:goto_8d
if-eqz v2, :cond_d1
.line 15
invoke-interface {v2}, Lorg/apache/http/HttpResponse;->getStatusLine()Lorg/apache/http/StatusLine;
move-result-object v0
invoke-interface {v0}, Lorg/apache/http/StatusLine;->getStatusCode()I
move-result v0
const/4 v2, 0x2
new-array v2, v2, [Ljava/lang/Object;
.line 16
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v4
aput-object v4, v2, v12
.line 17
iget-object v4, v8, Lcom/android/volley/k;->c:Ljava/lang/String;
aput-object v4, v2, v11
const-string v4, "Unexpected response code %d for %s"
.line 18
invoke-static {v4, v2}, Lcom/android/volley/r;->a(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
if-eqz v3, :cond_cb
.line 19
new-instance v2, Lcom/android/volley/i;
invoke-direct {v2, v0, v3, v1, v12}, Lcom/android/volley/i;-><init>(I[BLjava/util/Map;Z)V
const/16 v1, 0x191
if-eq v0, v1, :cond_bf
const/16 v1, 0x193
if-ne v0, v1, :cond_b9
goto :goto_bf
.line 20
:cond_b9
new-instance v0, Lcom/android/volley/o;
invoke-direct {v0, v2}, Lcom/android/volley/o;-><init>(Lcom/android/volley/i;)V
throw v0
.line 21
:cond_bf
:goto_bf
new-instance v0, Lcom/android/volley/a;
invoke-direct {v0, v2}, Lcom/android/volley/a;-><init>(Lcom/android/volley/i;)V
const-string v1, "auth"
invoke-static {v1, v8, v0}, Lcom/android/volley/toolbox/a;->a(Ljava/lang/String;Lcom/android/volley/k;Lcom/android/volley/q;)V
goto/16 :goto_8
.line 22
:cond_cb
new-instance v0, Lcom/android/volley/h;
invoke-direct {v0}, Lcom/android/volley/h;-><init>()V
throw v0
.line 23
:cond_d1
new-instance v1, Lcom/android/volley/j;
invoke-direct {v1, v0}, Lcom/android/volley/j;-><init>(Ljava/lang/Throwable;)V
throw v1
:catch_d7
move-exception v0
.line 24
new-instance v1, Ljava/lang/RuntimeException;
const-string v2, "Bad URL "
.line 25
invoke-static {v2}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
.line 26
iget-object v3, v8, Lcom/android/volley/k;->c:Ljava/lang/String;
.line 27
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2, v0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
throw v1
.line 28
:catch_ed
new-instance v0, Lcom/android/volley/p;
invoke-direct {v0}, Lcom/android/volley/p;-><init>()V
const-string v1, "connection"
invoke-static {v1, v8, v0}, Lcom/android/volley/toolbox/a;->a(Ljava/lang/String;Lcom/android/volley/k;Lcom/android/volley/q;)V
goto/16 :goto_8
.line 29
:catch_f9
new-instance v0, Lcom/android/volley/p;
invoke-direct {v0}, Lcom/android/volley/p;-><init>()V
const-string v1, "socket"
invoke-static {v1, v8, v0}, Lcom/android/volley/toolbox/a;->a(Ljava/lang/String;Lcom/android/volley/k;Lcom/android/volley/q;)V
goto/16 :goto_8
.end method