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