NetworkDispatcher.smali
.class public Lcom/android/volley/NetworkDispatcher;
.super Ljava/lang/Thread;
.source "NetworkDispatcher.java"
# instance fields
.field private final mCache:Lcom/android/volley/Cache;
.field private final mDelivery:Lcom/android/volley/ResponseDelivery;
.field private final mNetwork:Lcom/android/volley/Network;
.field private final mQueue:Ljava/util/concurrent/BlockingQueue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/BlockingQueue<",
"Lcom/android/volley/Request<",
"*>;>;"
}
.end annotation
.end field
.field private volatile mQuit:Z
# direct methods
.method public constructor <init>(Ljava/util/concurrent/BlockingQueue;Lcom/android/volley/Network;Lcom/android/volley/Cache;Lcom/android/volley/ResponseDelivery;)V
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/concurrent/BlockingQueue<",
"Lcom/android/volley/Request<",
"*>;>;",
"Lcom/android/volley/Network;",
"Lcom/android/volley/Cache;",
"Lcom/android/volley/ResponseDelivery;",
")V"
}
.end annotation
.line 61
invoke-direct {p0}, Ljava/lang/Thread;-><init>()V
const/4 v0, 0x0
.line 46
iput-boolean v0, p0, Lcom/android/volley/NetworkDispatcher;->mQuit:Z
.line 62
iput-object p1, p0, Lcom/android/volley/NetworkDispatcher;->mQueue:Ljava/util/concurrent/BlockingQueue;
.line 63
iput-object p2, p0, Lcom/android/volley/NetworkDispatcher;->mNetwork:Lcom/android/volley/Network;
.line 64
iput-object p3, p0, Lcom/android/volley/NetworkDispatcher;->mCache:Lcom/android/volley/Cache;
.line 65
iput-object p4, p0, Lcom/android/volley/NetworkDispatcher;->mDelivery:Lcom/android/volley/ResponseDelivery;
return-void
.end method
.method private addTrafficStatsTag(Lcom/android/volley/Request;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/android/volley/Request<",
"*>;)V"
}
.end annotation
.line 80
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0xe
if-lt v0, v1, :cond_d
.line 81
invoke-virtual {p1}, Lcom/android/volley/Request;->getTrafficStatsTag()I
move-result p1
invoke-static {p1}, Landroid/net/TrafficStats;->setThreadStatsTag(I)V
:cond_d
return-void
.end method
.method private parseAndDeliverNetworkError(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 174
invoke-virtual {p1, p2}, Lcom/android/volley/Request;->parseNetworkError(Lcom/android/volley/VolleyError;)Lcom/android/volley/VolleyError;
move-result-object p2
.line 175
iget-object v0, p0, Lcom/android/volley/NetworkDispatcher;->mDelivery:Lcom/android/volley/ResponseDelivery;
invoke-interface {v0, p1, p2}, Lcom/android/volley/ResponseDelivery;->postError(Lcom/android/volley/Request;Lcom/android/volley/VolleyError;)V
return-void
.end method
.method private processRequest()V
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/lang/InterruptedException;
}
.end annotation
.line 110
iget-object v0, p0, Lcom/android/volley/NetworkDispatcher;->mQueue: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 111
invoke-virtual {p0, v0}, Lcom/android/volley/NetworkDispatcher;->processRequest(Lcom/android/volley/Request;)V
return-void
.end method
# virtual methods
.method processRequest(Lcom/android/volley/Request;)V
.registers 10
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/android/volley/Request<",
"*>;)V"
}
.end annotation
.line 116
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
const/4 v2, 0x3
.line 117
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->sendEvent(I)V
const/4 v2, 0x4
:try_start_9
const-string v3, "network-queue-take"
.line 119
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->addMarker(Ljava/lang/String;)V
.line 123
invoke-virtual {p1}, Lcom/android/volley/Request;->isCanceled()Z
move-result v3
if-eqz v3, :cond_20
const-string v3, "network-discard-cancelled"
.line 124
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->finish(Ljava/lang/String;)V
.line 125
invoke-virtual {p1}, Lcom/android/volley/Request;->notifyListenerResponseNotUsable()V
:try_end_1c
.catch Lcom/android/volley/VolleyError; {:try_start_9 .. :try_end_1c} :catch_9b
.catch Ljava/lang/Exception; {:try_start_9 .. :try_end_1c} :catch_75
.catchall {:try_start_9 .. :try_end_1c} :catchall_73
.line 169
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->sendEvent(I)V
return-void
.line 129
:cond_20
:try_start_20
invoke-direct {p0, p1}, Lcom/android/volley/NetworkDispatcher;->addTrafficStatsTag(Lcom/android/volley/Request;)V
.line 132
iget-object v3, p0, Lcom/android/volley/NetworkDispatcher;->mNetwork:Lcom/android/volley/Network;
invoke-interface {v3, p1}, Lcom/android/volley/Network;->performRequest(Lcom/android/volley/Request;)Lcom/android/volley/NetworkResponse;
move-result-object v3
const-string v4, "network-http-complete"
.line 133
invoke-virtual {p1, v4}, Lcom/android/volley/Request;->addMarker(Ljava/lang/String;)V
.line 137
iget-boolean v4, v3, Lcom/android/volley/NetworkResponse;->notModified:Z
if-eqz v4, :cond_44
invoke-virtual {p1}, Lcom/android/volley/Request;->hasHadResponseDelivered()Z
move-result v4
if-eqz v4, :cond_44
const-string v3, "not-modified"
.line 138
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->finish(Ljava/lang/String;)V
.line 139
invoke-virtual {p1}, Lcom/android/volley/Request;->notifyListenerResponseNotUsable()V
:try_end_40
.catch Lcom/android/volley/VolleyError; {:try_start_20 .. :try_end_40} :catch_9b
.catch Ljava/lang/Exception; {:try_start_20 .. :try_end_40} :catch_75
.catchall {:try_start_20 .. :try_end_40} :catchall_73
.line 169
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->sendEvent(I)V
return-void
.line 144
:cond_44
:try_start_44
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->parseNetworkResponse(Lcom/android/volley/NetworkResponse;)Lcom/android/volley/Response;
move-result-object v3
const-string v4, "network-parse-complete"
.line 145
invoke-virtual {p1, v4}, Lcom/android/volley/Request;->addMarker(Ljava/lang/String;)V
.line 149
invoke-virtual {p1}, Lcom/android/volley/Request;->shouldCache()Z
move-result v4
if-eqz v4, :cond_67
iget-object v4, v3, Lcom/android/volley/Response;->cacheEntry:Lcom/android/volley/Cache$Entry;
if-eqz v4, :cond_67
.line 150
iget-object v4, p0, Lcom/android/volley/NetworkDispatcher;->mCache:Lcom/android/volley/Cache;
invoke-virtual {p1}, Lcom/android/volley/Request;->getCacheKey()Ljava/lang/String;
move-result-object v5
iget-object v6, v3, Lcom/android/volley/Response;->cacheEntry:Lcom/android/volley/Cache$Entry;
invoke-interface {v4, v5, v6}, Lcom/android/volley/Cache;->put(Ljava/lang/String;Lcom/android/volley/Cache$Entry;)V
const-string v4, "network-cache-written"
.line 151
invoke-virtual {p1, v4}, Lcom/android/volley/Request;->addMarker(Ljava/lang/String;)V
.line 155
:cond_67
invoke-virtual {p1}, Lcom/android/volley/Request;->markDelivered()V
.line 156
iget-object v4, p0, Lcom/android/volley/NetworkDispatcher;->mDelivery:Lcom/android/volley/ResponseDelivery;
invoke-interface {v4, p1, v3}, Lcom/android/volley/ResponseDelivery;->postResponse(Lcom/android/volley/Request;Lcom/android/volley/Response;)V
.line 157
invoke-virtual {p1, v3}, Lcom/android/volley/Request;->notifyListenerResponseReceived(Lcom/android/volley/Response;)V
:try_end_72
.catch Lcom/android/volley/VolleyError; {:try_start_44 .. :try_end_72} :catch_9b
.catch Ljava/lang/Exception; {:try_start_44 .. :try_end_72} :catch_75
.catchall {:try_start_44 .. :try_end_72} :catchall_73
goto :goto_aa
:catchall_73
move-exception v0
goto :goto_ae
:catch_75
move-exception v3
:try_start_76
const-string v4, "Unhandled exception %s"
const/4 v5, 0x1
new-array v5, v5, [Ljava/lang/Object;
const/4 v6, 0x0
.line 163
invoke-virtual {v3}, Ljava/lang/Exception;->toString()Ljava/lang/String;
move-result-object v7
aput-object v7, v5, v6
invoke-static {v3, v4, v5}, Lcom/android/volley/VolleyLog;->e(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
.line 164
new-instance v4, Lcom/android/volley/VolleyError;
invoke-direct {v4, v3}, Lcom/android/volley/VolleyError;-><init>(Ljava/lang/Throwable;)V
.line 165
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v5
sub-long/2addr v5, v0
invoke-virtual {v4, v5, v6}, Lcom/android/volley/VolleyError;->setNetworkTimeMs(J)V
.line 166
iget-object v0, p0, Lcom/android/volley/NetworkDispatcher;->mDelivery:Lcom/android/volley/ResponseDelivery;
invoke-interface {v0, p1, v4}, Lcom/android/volley/ResponseDelivery;->postError(Lcom/android/volley/Request;Lcom/android/volley/VolleyError;)V
.line 167
invoke-virtual {p1}, Lcom/android/volley/Request;->notifyListenerResponseNotUsable()V
goto :goto_aa
:catch_9b
move-exception v3
.line 159
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 160
invoke-direct {p0, p1, v3}, Lcom/android/volley/NetworkDispatcher;->parseAndDeliverNetworkError(Lcom/android/volley/Request;Lcom/android/volley/VolleyError;)V
.line 161
invoke-virtual {p1}, Lcom/android/volley/Request;->notifyListenerResponseNotUsable()V
:try_end_aa
.catchall {:try_start_76 .. :try_end_aa} :catchall_73
.line 169
:goto_aa
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->sendEvent(I)V
return-void
:goto_ae
invoke-virtual {p1, v2}, Lcom/android/volley/Request;->sendEvent(I)V
throw v0
.end method
.method public quit()V
.registers 2
const/4 v0, 0x1
.line 73
iput-boolean v0, p0, Lcom/android/volley/NetworkDispatcher;->mQuit:Z
.line 74
invoke-virtual {p0}, Lcom/android/volley/NetworkDispatcher;->interrupt()V
return-void
.end method
.method public run()V
.registers 3
const/16 v0, 0xa
.line 87
invoke-static {v0}, Landroid/os/Process;->setThreadPriority(I)V
.line 90
:goto_5
:try_start_5
invoke-direct {p0}, Lcom/android/volley/NetworkDispatcher;->processRequest()V
:try_end_8
.catch Ljava/lang/InterruptedException; {:try_start_5 .. :try_end_8} :catch_9
goto :goto_5
.line 93
:catch_9
iget-boolean v0, p0, Lcom/android/volley/NetworkDispatcher;->mQuit:Z
if-eqz v0, :cond_15
.line 94
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
new-array v0, v0, [Ljava/lang/Object;
const-string v1, "Ignoring spurious interrupt of NetworkDispatcher thread; use quit() to terminate it"
.line 97
invoke-static {v1, v0}, Lcom/android/volley/VolleyLog;->e(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_5
.end method