i.smali
.class public Lcom/android/volley/i;
.super Ljava/lang/Thread;
.source "NetworkDispatcher.java"
# instance fields
.field private final a:Ljava/util/concurrent/BlockingQueue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/BlockingQueue<",
"Lcom/android/volley/Request<",
"*>;>;"
}
.end annotation
.end field
.field private final b:Lcom/android/volley/h;
.field private final c:Lcom/android/volley/a;
.field private final d:Lcom/android/volley/n;
.field private volatile e:Z
# direct methods
.method public constructor <init>(Ljava/util/concurrent/BlockingQueue;Lcom/android/volley/h;Lcom/android/volley/a;Lcom/android/volley/n;)V
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/concurrent/BlockingQueue<",
"Lcom/android/volley/Request<",
"*>;>;",
"Lcom/android/volley/h;",
"Lcom/android/volley/a;",
"Lcom/android/volley/n;",
")V"
}
.end annotation
.line 1
invoke-direct {p0}, Ljava/lang/Thread;-><init>()V
const/4 v0, 0x0
.line 2
iput-boolean v0, p0, Lcom/android/volley/i;->e:Z
.line 3
iput-object p1, p0, Lcom/android/volley/i;->a:Ljava/util/concurrent/BlockingQueue;
.line 4
iput-object p2, p0, Lcom/android/volley/i;->b:Lcom/android/volley/h;
.line 5
iput-object p3, p0, Lcom/android/volley/i;->c:Lcom/android/volley/a;
.line 6
iput-object p4, p0, Lcom/android/volley/i;->d:Lcom/android/volley/n;
return-void
.end method
.method private a(Lcom/android/volley/Request;Lcom/android/volley/VolleyError;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/android/volley/Request<",
"*>;",
"Lcom/android/volley/VolleyError;",
")V"
}
.end annotation
.line 30
invoke-virtual {p1, p2}, Lcom/android/volley/Request;->b(Lcom/android/volley/VolleyError;)Lcom/android/volley/VolleyError;
.line 31
iget-object v0, p0, Lcom/android/volley/i;->d:Lcom/android/volley/n;
invoke-interface {v0, p1, p2}, Lcom/android/volley/n;->a(Lcom/android/volley/Request;Lcom/android/volley/VolleyError;)V
return-void
.end method
.method private b()V
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/InterruptedException;
}
.end annotation
.line 3
iget-object v0, p0, Lcom/android/volley/i;->a:Ljava/util/concurrent/BlockingQueue;
invoke-interface {v0}, Ljava/util/concurrent/BlockingQueue;->take()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/android/volley/Request;
.line 4
invoke-virtual {p0, v0}, Lcom/android/volley/i;->a(Lcom/android/volley/Request;)V
return-void
.end method
.method private b(Lcom/android/volley/Request;)V
.registers 4
.annotation build Landroid/annotation/TargetApi;
value = 0xe
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/android/volley/Request<",
"*>;)V"
}
.end annotation
.line 1
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0xe
if-lt v0, v1, :cond_d
.line 2
invoke-virtual {p1}, Lcom/android/volley/Request;->s()I
move-result p1
invoke-static {p1}, Landroid/net/TrafficStats;->setThreadStatsTag(I)V
:cond_d
return-void
.end method
# virtual methods
.method public a()V
.registers 2
const/4 v0, 0x1
.line 1
iput-boolean v0, p0, Lcom/android/volley/i;->e:Z
.line 2
invoke-virtual {p0}, Ljava/lang/Thread;->interrupt()V
return-void
.end method
.method a(Lcom/android/volley/Request;)V
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/android/volley/Request<",
"*>;)V"
}
.end annotation
.line 3
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
:try_start_4
const-string v2, "network-queue-take"
.line 4
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->a(Ljava/lang/String;)V
.line 5
invoke-virtual {p1}, Lcom/android/volley/Request;->v()Z
move-result v2
if-eqz v2, :cond_18
const-string v2, "network-discard-cancelled"
.line 6
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->b(Ljava/lang/String;)V
.line 7
invoke-virtual {p1}, Lcom/android/volley/Request;->x()V
return-void
.line 8
:cond_18
invoke-direct {p0, p1}, Lcom/android/volley/i;->b(Lcom/android/volley/Request;)V
.line 9
iget-object v2, p0, Lcom/android/volley/i;->b:Lcom/android/volley/h;
invoke-interface {v2, p1}, Lcom/android/volley/h;->a(Lcom/android/volley/Request;)Lcom/android/volley/j;
move-result-object v2
const-string v3, "network-http-complete"
.line 10
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->a(Ljava/lang/String;)V
.line 11
iget-boolean v3, v2, Lcom/android/volley/j;->e:Z
if-eqz v3, :cond_39
invoke-virtual {p1}, Lcom/android/volley/Request;->u()Z
move-result v3
if-eqz v3, :cond_39
const-string v2, "not-modified"
.line 12
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->b(Ljava/lang/String;)V
.line 13
invoke-virtual {p1}, Lcom/android/volley/Request;->x()V
return-void
.line 14
:cond_39
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->a(Lcom/android/volley/j;)Lcom/android/volley/m;
move-result-object v2
const-string v3, "network-parse-complete"
.line 15
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->a(Ljava/lang/String;)V
.line 16
invoke-virtual {p1}, Lcom/android/volley/Request;->y()Z
move-result v3
if-eqz v3, :cond_5c
iget-object v3, v2, Lcom/android/volley/m;->b:Lcom/android/volley/a$a;
if-eqz v3, :cond_5c
.line 17
iget-object v3, p0, Lcom/android/volley/i;->c:Lcom/android/volley/a;
invoke-virtual {p1}, Lcom/android/volley/Request;->d()Ljava/lang/String;
move-result-object v4
iget-object v5, v2, Lcom/android/volley/m;->b:Lcom/android/volley/a$a;
invoke-interface {v3, v4, v5}, Lcom/android/volley/a;->a(Ljava/lang/String;Lcom/android/volley/a$a;)V
const-string v3, "network-cache-written"
.line 18
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->a(Ljava/lang/String;)V
.line 19
:cond_5c
invoke-virtual {p1}, Lcom/android/volley/Request;->w()V
.line 20
iget-object v3, p0, Lcom/android/volley/i;->d:Lcom/android/volley/n;
invoke-interface {v3, p1, v2}, Lcom/android/volley/n;->a(Lcom/android/volley/Request;Lcom/android/volley/m;)V
.line 21
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->a(Lcom/android/volley/m;)V
:try_end_67
.catch Lcom/android/volley/VolleyError; {:try_start_4 .. :try_end_67} :catch_8e
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_67} :catch_68
goto :goto_9d
:catch_68
move-exception v2
const/4 v3, 0x1
.line 22
new-array v3, v3, [Ljava/lang/Object;
const/4 v4, 0x0
invoke-virtual {v2}, Ljava/lang/Exception;->toString()Ljava/lang/String;
move-result-object v5
aput-object v5, v3, v4
const-string v4, "Unhandled exception %s"
invoke-static {v2, v4, v3}, Lcom/android/volley/p;->a(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
.line 23
new-instance v3, Lcom/android/volley/VolleyError;
invoke-direct {v3, v2}, Lcom/android/volley/VolleyError;-><init>(Ljava/lang/Throwable;)V
.line 24
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
sub-long/2addr v4, v0
invoke-virtual {v3, v4, v5}, Lcom/android/volley/VolleyError;->setNetworkTimeMs(J)V
.line 25
iget-object v0, p0, Lcom/android/volley/i;->d:Lcom/android/volley/n;
invoke-interface {v0, p1, v3}, Lcom/android/volley/n;->a(Lcom/android/volley/Request;Lcom/android/volley/VolleyError;)V
.line 26
invoke-virtual {p1}, Lcom/android/volley/Request;->x()V
goto :goto_9d
:catch_8e
move-exception v2
.line 27
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v3
sub-long/2addr v3, v0
invoke-virtual {v2, v3, v4}, Lcom/android/volley/VolleyError;->setNetworkTimeMs(J)V
.line 28
invoke-direct {p0, p1, v2}, Lcom/android/volley/i;->a(Lcom/android/volley/Request;Lcom/android/volley/VolleyError;)V
.line 29
invoke-virtual {p1}, Lcom/android/volley/Request;->x()V
:goto_9d
return-void
.end method
.method public run()V
.registers 3
const/16 v0, 0xa
.line 1
invoke-static {v0}, Landroid/os/Process;->setThreadPriority(I)V
.line 2
:goto_5
:try_start_5
invoke-direct {p0}, Lcom/android/volley/i;->b()V
:try_end_8
.catch Ljava/lang/InterruptedException; {:try_start_5 .. :try_end_8} :catch_9
goto :goto_5
.line 3
:catch_9
iget-boolean v0, p0, Lcom/android/volley/i;->e:Z
if-eqz v0, :cond_15
.line 4
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
return-void
:cond_15
const/4 v0, 0x0
.line 5
new-array v0, v0, [Ljava/lang/Object;
const-string v1, "Ignoring spurious interrupt of NetworkDispatcher thread; use quit() to terminate it"
invoke-static {v1, v0}, Lcom/android/volley/p;->b(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_5
.end method