NetworkDispatcher.smali
.class public Lcom/tradplus/ads/volley/NetworkDispatcher;
.super Ljava/lang/Thread;
# instance fields
.field private final a:Ljava/util/concurrent/BlockingQueue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/BlockingQueue<",
"Lcom/tradplus/ads/volley/Request<",
"*>;>;"
}
.end annotation
.end field
.field private final b:Lcom/tradplus/ads/volley/Network;
.field private final c:Lcom/tradplus/ads/volley/Cache;
.field private final d:Lcom/tradplus/ads/volley/ResponseDelivery;
.field private volatile e:Z
# direct methods
.method public constructor <init>(Ljava/util/concurrent/BlockingQueue;Lcom/tradplus/ads/volley/Network;Lcom/tradplus/ads/volley/Cache;Lcom/tradplus/ads/volley/ResponseDelivery;)V
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/concurrent/BlockingQueue<",
"Lcom/tradplus/ads/volley/Request<",
"*>;>;",
"Lcom/tradplus/ads/volley/Network;",
"Lcom/tradplus/ads/volley/Cache;",
"Lcom/tradplus/ads/volley/ResponseDelivery;",
")V"
}
.end annotation
invoke-direct {p0}, Ljava/lang/Thread;-><init>()V
const/4 v0, 0x0
iput-boolean v0, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->e:Z
iput-object p1, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->a:Ljava/util/concurrent/BlockingQueue;
iput-object p2, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->b:Lcom/tradplus/ads/volley/Network;
iput-object p3, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->c:Lcom/tradplus/ads/volley/Cache;
iput-object p4, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->d:Lcom/tradplus/ads/volley/ResponseDelivery;
return-void
.end method
.method private a(Lcom/tradplus/ads/volley/Request;)V
.registers 4
.annotation build Landroid/annotation/TargetApi;
value = 0xe
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/tradplus/ads/volley/Request<",
"*>;)V"
}
.end annotation
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0xe
if-lt v0, v1, :cond_d
invoke-virtual {p1}, Lcom/tradplus/ads/volley/Request;->getTrafficStatsTag()I
move-result p1
invoke-static {p1}, Landroid/net/TrafficStats;->setThreadStatsTag(I)V
:cond_d
return-void
.end method
.method private a(Lcom/tradplus/ads/volley/Request;Lcom/tradplus/ads/volley/VolleyError;)V
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/tradplus/ads/volley/Request<",
"*>;",
"Lcom/tradplus/ads/volley/VolleyError;",
")V"
}
.end annotation
invoke-virtual {p1, p2}, Lcom/tradplus/ads/volley/Request;->a(Lcom/tradplus/ads/volley/VolleyError;)Lcom/tradplus/ads/volley/VolleyError;
move-result-object p2
iget-object v0, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->d:Lcom/tradplus/ads/volley/ResponseDelivery;
invoke-interface {v0, p1, p2}, Lcom/tradplus/ads/volley/ResponseDelivery;->postError(Lcom/tradplus/ads/volley/Request;Lcom/tradplus/ads/volley/VolleyError;)V
return-void
.end method
# virtual methods
.method public quit()V
.registers 2
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->e:Z
invoke-virtual {p0}, Ljava/lang/Thread;->interrupt()V
return-void
.end method
.method public run()V
.registers 8
const/16 v0, 0xa
invoke-static {v0}, Landroid/os/Process;->setThreadPriority(I)V
:cond_5
:goto_5
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v0
:try_start_9
iget-object v2, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->a:Ljava/util/concurrent/BlockingQueue;
invoke-interface {v2}, Ljava/util/concurrent/BlockingQueue;->take()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/tradplus/ads/volley/Request;
:try_end_11
.catch Ljava/lang/InterruptedException; {:try_start_9 .. :try_end_11} :catch_9b
:try_start_11
const-string v3, "network-queue-take"
invoke-virtual {v2, v3}, Lcom/tradplus/ads/volley/Request;->addMarker(Ljava/lang/String;)V
invoke-virtual {v2}, Lcom/tradplus/ads/volley/Request;->isCanceled()Z
move-result v3
if-eqz v3, :cond_22
const-string v3, "network-discard-cancelled"
:goto_1e
invoke-virtual {v2, v3}, Lcom/tradplus/ads/volley/Request;->a(Ljava/lang/String;)V
goto :goto_5
:cond_22
invoke-direct {p0, v2}, Lcom/tradplus/ads/volley/NetworkDispatcher;->a(Lcom/tradplus/ads/volley/Request;)V
iget-object v3, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->b:Lcom/tradplus/ads/volley/Network;
invoke-interface {v3, v2}, Lcom/tradplus/ads/volley/Network;->performRequest(Lcom/tradplus/ads/volley/Request;)Lcom/tradplus/ads/volley/NetworkResponse;
move-result-object v3
const-string v4, "network-http-complete"
invoke-virtual {v2, v4}, Lcom/tradplus/ads/volley/Request;->addMarker(Ljava/lang/String;)V
iget-boolean v4, v3, Lcom/tradplus/ads/volley/NetworkResponse;->notModified:Z
if-eqz v4, :cond_3d
invoke-virtual {v2}, Lcom/tradplus/ads/volley/Request;->hasHadResponseDelivered()Z
move-result v4
if-eqz v4, :cond_3d
const-string v3, "not-modified"
goto :goto_1e
:cond_3d
invoke-virtual {v2, v3}, Lcom/tradplus/ads/volley/Request;->a(Lcom/tradplus/ads/volley/NetworkResponse;)Lcom/tradplus/ads/volley/Response;
move-result-object v3
const-string v4, "network-parse-complete"
invoke-virtual {v2, v4}, Lcom/tradplus/ads/volley/Request;->addMarker(Ljava/lang/String;)V
invoke-virtual {v2}, Lcom/tradplus/ads/volley/Request;->shouldCache()Z
move-result v4
if-eqz v4, :cond_60
iget-object v4, v3, Lcom/tradplus/ads/volley/Response;->cacheEntry:Lcom/tradplus/ads/volley/Cache$Entry;
if-eqz v4, :cond_60
iget-object v4, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->c:Lcom/tradplus/ads/volley/Cache;
invoke-virtual {v2}, Lcom/tradplus/ads/volley/Request;->getCacheKey()Ljava/lang/String;
move-result-object v5
iget-object v6, v3, Lcom/tradplus/ads/volley/Response;->cacheEntry:Lcom/tradplus/ads/volley/Cache$Entry;
invoke-interface {v4, v5, v6}, Lcom/tradplus/ads/volley/Cache;->put(Ljava/lang/String;Lcom/tradplus/ads/volley/Cache$Entry;)V
const-string v4, "network-cache-written"
invoke-virtual {v2, v4}, Lcom/tradplus/ads/volley/Request;->addMarker(Ljava/lang/String;)V
:cond_60
invoke-virtual {v2}, Lcom/tradplus/ads/volley/Request;->markDelivered()V
iget-object v4, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->d:Lcom/tradplus/ads/volley/ResponseDelivery;
invoke-interface {v4, v2, v3}, Lcom/tradplus/ads/volley/ResponseDelivery;->postResponse(Lcom/tradplus/ads/volley/Request;Lcom/tradplus/ads/volley/Response;)V
:try_end_68
.catch Lcom/tradplus/ads/volley/VolleyError; {:try_start_11 .. :try_end_68} :catch_8d
.catch Ljava/lang/Exception; {:try_start_11 .. :try_end_68} :catch_69
goto :goto_5
:catch_69
move-exception v3
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
invoke-virtual {v3}, Ljava/lang/Exception;->toString()Ljava/lang/String;
move-result-object v6
aput-object v6, v4, v5
const-string v5, "Unhandled exception %s"
invoke-static {v3, v5, v4}, Lcom/tradplus/ads/volley/VolleyLog;->e(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
new-instance v4, Lcom/tradplus/ads/volley/VolleyError;
invoke-direct {v4, v3}, Lcom/tradplus/ads/volley/VolleyError;-><init>(Ljava/lang/Throwable;)V
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v5
sub-long/2addr v5, v0
invoke-virtual {v4, v5, v6}, Lcom/tradplus/ads/volley/VolleyError;->a(J)V
iget-object v0, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->d:Lcom/tradplus/ads/volley/ResponseDelivery;
invoke-interface {v0, v2, v4}, Lcom/tradplus/ads/volley/ResponseDelivery;->postError(Lcom/tradplus/ads/volley/Request;Lcom/tradplus/ads/volley/VolleyError;)V
goto/16 :goto_5
:catch_8d
move-exception v3
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
sub-long/2addr v4, v0
invoke-virtual {v3, v4, v5}, Lcom/tradplus/ads/volley/VolleyError;->a(J)V
invoke-direct {p0, v2, v3}, Lcom/tradplus/ads/volley/NetworkDispatcher;->a(Lcom/tradplus/ads/volley/Request;Lcom/tradplus/ads/volley/VolleyError;)V
goto/16 :goto_5
:catch_9b
nop
iget-boolean v0, p0, Lcom/tradplus/ads/volley/NetworkDispatcher;->e:Z
if-eqz v0, :cond_5
return-void
.end method