RequestDispatcher.smali

.class public Lcom/h/o/RequestDispatcher;
.super Ljava/lang/Thread;


# instance fields
.field private volatile mQuit:Z

.field private final mRequestQueue:Ljava/util/concurrent/BlockingQueue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/BlockingQueue",
            "<",
            "Lcom/h/o/Request",
            "<*>;>;"
        }
    .end annotation
.end field

.field private final mUnFinishQueue:Ljava/util/concurrent/BlockingQueue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/BlockingQueue",
            "<",
            "Lcom/h/o/Request",
            "<*>;>;"
        }
    .end annotation
.end field


# direct methods
.method public constructor <init>(Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/BlockingQueue;)V
    .registers 4
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/concurrent/BlockingQueue",
            "<",
            "Lcom/h/o/Request",
            "<*>;>;",
            "Ljava/util/concurrent/BlockingQueue",
            "<",
            "Lcom/h/o/Request",
            "<*>;>;)V"
        }
    .end annotation

    invoke-direct {p0}, Ljava/lang/Thread;-><init>()V

    const/4 v0, 0x0

    iput-boolean v0, p0, Lcom/h/o/RequestDispatcher;->mQuit:Z

    iput-object p1, p0, Lcom/h/o/RequestDispatcher;->mUnFinishQueue:Ljava/util/concurrent/BlockingQueue;

    iput-object p2, p0, Lcom/h/o/RequestDispatcher;->mRequestQueue:Ljava/util/concurrent/BlockingQueue;

    return-void
.end method


# virtual methods
.method public quit()V
    .registers 2

    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/h/o/RequestDispatcher;->mQuit:Z

    invoke-virtual {p0}, Lcom/h/o/RequestDispatcher;->interrupt()V

    return-void
.end method

.method public run()V
    .registers 6

    const/16 v0, 0xa

    invoke-static {v0}, Landroid/os/Process;->setThreadPriority(I)V

    :goto_5
    iget-boolean v0, p0, Lcom/h/o/RequestDispatcher;->mQuit:Z

    if-nez v0, :cond_3e

    :try_start_9
    iget-object v0, p0, Lcom/h/o/RequestDispatcher;->mRequestQueue:Ljava/util/concurrent/BlockingQueue;

    invoke-interface {v0}, Ljava/util/concurrent/BlockingQueue;->take()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/h/o/Request;
    :try_end_11
    .catch Ljava/lang/InterruptedException; {:try_start_9 .. :try_end_11} :catch_33

    invoke-virtual {v0}, Lcom/h/o/Request;->isCanceled()Z

    move-result v1

    if-eqz v1, :cond_43

    new-instance v1, Ljava/lang/StringBuilder;

    invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V

    invoke-virtual {v0}, Lcom/h/o/Request;->url()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    const-string/jumbo v1, " is canceled."

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-static {v0}, Lcom/h/r/Logger;->d(Ljava/lang/Object;)V

    goto :goto_5

    :catch_33
    move-exception v0

    iget-boolean v1, p0, Lcom/h/o/RequestDispatcher;->mQuit:Z

    if-eqz v1, :cond_3f

    const-string/jumbo v0, "Queue exit, stop blocking."

    invoke-static {v0}, Lcom/h/r/Logger;->w(Ljava/lang/String;)V

    :cond_3e
    return-void

    :cond_3f
    invoke-static {v0}, Lcom/h/r/Logger;->e(Ljava/lang/Throwable;)V

    goto :goto_5

    :cond_43
    invoke-virtual {v0}, Lcom/h/o/Request;->what()I

    move-result v1

    invoke-virtual {v0}, Lcom/h/o/Request;->responseListener()Lcom/h/o/OnResponseListener;

    move-result-object v2

    invoke-virtual {v0}, Lcom/h/o/Request;->start()V

    invoke-static {v1, v2, v0}, Lcom/h/o/Messenger;->prepare(ILcom/h/o/OnResponseListener;Lcom/h/o/Request;)Lcom/h/o/Messenger;

    move-result-object v3

    invoke-virtual {v3}, Lcom/h/o/Messenger;->start()Lcom/h/o/Messenger;

    move-result-object v3

    invoke-virtual {v3}, Lcom/h/o/Messenger;->post()V

    sget-object v3, Lcom/h/o/SyncRequestExecutor;->INSTANCE:Lcom/h/o/SyncRequestExecutor;

    invoke-virtual {v3, v0}, Lcom/h/o/SyncRequestExecutor;->execute(Lcom/h/o/ProtocolRequest;)Lcom/h/o/Response;

    move-result-object v3

    iget-object v4, p0, Lcom/h/o/RequestDispatcher;->mUnFinishQueue:Ljava/util/concurrent/BlockingQueue;

    invoke-interface {v4, v0}, Ljava/util/concurrent/BlockingQueue;->remove(Ljava/lang/Object;)Z

    invoke-virtual {v0}, Lcom/h/o/Request;->isCanceled()Z

    move-result v4

    if-eqz v4, :cond_95

    new-instance v3, Ljava/lang/StringBuilder;

    invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V

    invoke-virtual {v0}, Lcom/h/o/Request;->url()Ljava/lang/String;

    move-result-object v4

    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v3

    const-string/jumbo v4, " finish, but it\'s canceled."

    invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v3

    invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-static {v3}, Lcom/h/r/Logger;->d(Ljava/lang/Object;)V

    :goto_85
    invoke-virtual {v0}, Lcom/h/o/Request;->finish()V

    invoke-static {v1, v2, v0}, Lcom/h/o/Messenger;->prepare(ILcom/h/o/OnResponseListener;Lcom/h/o/Request;)Lcom/h/o/Messenger;

    move-result-object v0

    invoke-virtual {v0}, Lcom/h/o/Messenger;->finish()Lcom/h/o/Messenger;

    move-result-object v0

    invoke-virtual {v0}, Lcom/h/o/Messenger;->post()V

    goto/16 :goto_5

    :cond_95
    invoke-static {v1, v2, v0}, Lcom/h/o/Messenger;->prepare(ILcom/h/o/OnResponseListener;Lcom/h/o/Request;)Lcom/h/o/Messenger;

    move-result-object v4

    invoke-virtual {v4, v3}, Lcom/h/o/Messenger;->response(Lcom/h/o/Response;)Lcom/h/o/Messenger;

    move-result-object v3

    invoke-virtual {v3}, Lcom/h/o/Messenger;->post()V

    goto :goto_85
.end method