AsyncStringPrinter$Worker.smali

.class Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;
.super Ljava/lang/Object;

# interfaces
.implements Ljava/lang/Runnable;


# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
    value = Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0xa
    name = "Worker"
.end annotation


# instance fields
.field private mAsyncCount:I

.field private final mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;

.field private mLogQueue:Ljava/util/concurrent/BlockingQueue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/BlockingQueue",
            "<",
            "Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;",
            ">;"
        }
    .end annotation
.end field


# direct methods
.method private constructor <init>()V
    .registers 3

    const/4 v1, 0x0

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

    new-instance v0, Ljava/util/concurrent/LinkedBlockingDeque;

    invoke-direct {v0}, Ljava/util/concurrent/LinkedBlockingDeque;-><init>()V

    iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mLogQueue:Ljava/util/concurrent/BlockingQueue;

    new-instance v0, Ljava/util/concurrent/atomic/AtomicBoolean;

    invoke-direct {v0, v1}, Ljava/util/concurrent/atomic/AtomicBoolean;-><init>(Z)V

    iput-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;

    iput v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mAsyncCount:I

    return-void
.end method

.method synthetic constructor <init>(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$1;)V
    .registers 2

    invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;-><init>()V

    return-void
.end method

.method static synthetic access$100(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;)V
    .registers 1

    invoke-direct {p0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->tryStart()V

    return-void
.end method

.method static synthetic access$200(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V
    .registers 3

    invoke-direct {p0, p1, p2}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->enqueue(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V

    return-void
.end method

.method private enqueue(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V
    .registers 5

    :try_start_0
    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mLogQueue:Ljava/util/concurrent/BlockingQueue;

    new-instance v1, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;

    invoke-direct {v1, p1, p2}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;-><init>(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;Ljava/lang/String;)V

    invoke-interface {v0, v1}, Ljava/util/concurrent/BlockingQueue;->put(Ljava/lang/Object;)V
    :try_end_a
    .catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_a} :catch_b

    :goto_a
    return-void

    :catch_b
    move-exception v0

    invoke-virtual {v0}, Ljava/lang/InterruptedException;->printStackTrace()V

    goto :goto_a
.end method

.method private tryStart()V
    .registers 5

    iget-object v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;

    monitor-enter v1

    :try_start_3
    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z

    move-result v0

    if-nez v0, :cond_3a

    new-instance v0, Ljava/lang/Thread;

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

    const/4 v2, 0x1

    invoke-virtual {v0, v2}, Ljava/lang/Thread;->setPriority(I)V

    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string/jumbo v3, "AsyncStringPrinter-"

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

    move-result-object v2

    iget v3, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mAsyncCount:I

    add-int/lit8 v3, v3, 0x1

    iput v3, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mAsyncCount:I

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

    move-result-object v2

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

    move-result-object v2

    invoke-virtual {v0, v2}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    invoke-virtual {v0}, Ljava/lang/Thread;->start()V

    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;

    const/4 v2, 0x1

    invoke-virtual {v0, v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V

    :cond_3a
    monitor-exit v1

    return-void

    :catchall_3c
    move-exception v0

    monitor-exit v1
    :try_end_3e
    .catchall {:try_start_3 .. :try_end_3e} :catchall_3c

    throw v0
.end method


# virtual methods
.method public run()V
    .registers 4

    :goto_0
    :try_start_0
    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mLogQueue:Ljava/util/concurrent/BlockingQueue;

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

    move-result-object v0

    check-cast v0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;

    if-eqz v0, :cond_1a

    # getter for: Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->mPrinter:Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;
    invoke-static {v0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->access$300(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;)Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;

    move-result-object v1

    # getter for: Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->mLog:Ljava/lang/String;
    invoke-static {v0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;->access$400(Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$PrintMsg;)Ljava/lang/String;

    move-result-object v0

    invoke-virtual {v1, v0}, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter;->doPrintln(Ljava/lang/String;)V
    :try_end_15
    .catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_15} :catch_16

    goto :goto_0

    :catch_16
    move-exception v0

    invoke-virtual {v0}, Ljava/lang/InterruptedException;->printStackTrace()V

    :cond_1a
    iget-object v1, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;

    monitor-enter v1

    :try_start_1d
    iget-object v0, p0, Lcom/cmcm/xiaobao/phone/commons/log/printer/AsyncStringPrinter$Worker;->mIsStarted:Ljava/util/concurrent/atomic/AtomicBoolean;

    const/4 v2, 0x0

    invoke-virtual {v0, v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V

    monitor-exit v1

    return-void

    :catchall_25
    move-exception v0

    monitor-exit v1
    :try_end_27
    .catchall {:try_start_1d .. :try_end_27} :catchall_25

    throw v0
.end method