d.smali

.class public Lcom/cleanmaster/scanengin/d;
.super Lcom/cleanmaster/hpsharelib/scanengin/TaskBus;
.source "JunkTaskBus.java"


# direct methods
.method public constructor <init>()V
    .registers 1

    .prologue
    .line 20
    invoke-direct {p0}, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus;-><init>()V

    return-void
.end method


# virtual methods
.method protected getThreadName()Ljava/lang/String;
    .registers 2

    .prologue
    .line 25
    const-string v0, "junk-taskbus-thread"

    return-object v0
.end method

.method protected scanTaskList(Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$IScanTaskListParams;)V
    .registers 17

    .prologue
    .line 31
    if-nez p1, :cond_3

    .line 130
    :cond_2
    return-void

    .line 35
    :cond_3
    invoke-interface/range {p1 .. p1}, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$IScanTaskListParams;->getTaskQueue()Ljava/util/Queue;

    move-result-object v2

    .line 36
    if-eqz v2, :cond_2

    invoke-interface {v2}, Ljava/util/Queue;->isEmpty()Z

    move-result v0

    if-nez v0, :cond_2

    .line 40
    new-instance v3, Ljava/util/ArrayList;

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

    .line 43
    :try_start_14
    invoke-interface {v2}, Ljava/util/Queue;->size()I

    move-result v4

    .line 44
    new-instance v5, Ljava/util/concurrent/CountDownLatch;

    invoke-direct {v5, v4}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V

    .line 45
    const/4 v1, 0x0

    .line 47
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/Thread;->getId()J

    move-result-wide v6

    .line 48
    invoke-interface {v2}, Ljava/util/Queue;->poll()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;

    move-object v14, v0

    move v0, v1

    move-object v1, v14

    :goto_2f
    if-eqz v1, :cond_53

    .line 49
    iget-object v8, v1, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;->mTask:Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;

    if-nez v8, :cond_40

    move v1, v0

    .line 48
    :goto_36
    invoke-interface {v2}, Ljava/util/Queue;->poll()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;

    move-object v14, v0

    move v0, v1

    move-object v1, v14

    goto :goto_2f

    .line 53
    :cond_40
    iget-object v8, p0, Lcom/cleanmaster/scanengin/d;->mTaskCtrl:Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;

    invoke-virtual {v8}, Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;->checkStop()Z

    move-result v8

    if-eqz v8, :cond_5b

    .line 54
    invoke-virtual {p0}, Lcom/cleanmaster/scanengin/d;->getTaskBusCallback()Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$ITaskBusCallback;

    move-result-object v2

    .line 55
    if-eqz v2, :cond_53

    .line 56
    iget-object v1, v1, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;->mTask:Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;

    invoke-interface {v2, v1}, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$ITaskBusCallback;->notifySkipScan(Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;)V

    .line 116
    :cond_53
    :goto_53
    if-ge v0, v4, :cond_f6

    .line 117
    invoke-virtual {v5}, Ljava/util/concurrent/CountDownLatch;->countDown()V

    .line 116
    add-int/lit8 v0, v0, 0x1

    goto :goto_53

    .line 61
    :cond_5b
    iget v8, v1, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;->mTaskTime:I

    if-gtz v8, :cond_c7

    .line 62
    iget-object v8, v1, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;->mTask:Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;

    invoke-interface {v8}, Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;->getTaskDesc()Ljava/lang/String;

    move-result-object v8

    .line 63
    const-string v9, "JTB"

    new-instance v10, Ljava/lang/StringBuilder;

    const-string v11, "("

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

    invoke-virtual {v10, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    move-result-object v10

    const-string v11, ")start: "

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

    move-result-object v10

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

    move-result-object v10

    const-string v11, " Time : "

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

    move-result-object v10

    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v12

    invoke-virtual {v10, v12, v13}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    move-result-object v10

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

    move-result-object v10

    invoke-static {v9, v10}, Lcom/cleanmaster/hpsharelib/utils/OpLog;->x(Ljava/lang/String;Ljava/lang/String;)V

    .line 64
    iget-object v1, v1, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;->mTask:Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;

    iget-object v9, p0, Lcom/cleanmaster/scanengin/d;->mTaskCtrl:Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;

    invoke-interface {v1, v9}, Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;->scan(Lcom/cleanmaster/bitloader/task/IScanTaskController;)Z

    .line 65
    const-string v1, "JTB"

    new-instance v9, Ljava/lang/StringBuilder;

    const-string v10, "("

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

    invoke-virtual {v9, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    move-result-object v9

    const-string v10, ")end: "

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

    move-result-object v9

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

    move-result-object v8

    const-string v9, " Time : "

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

    move-result-object v8

    invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J

    move-result-wide v10

    invoke-virtual {v8, v10, v11}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    move-result-object v8

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

    move-result-object v8

    invoke-static {v1, v8}, Lcom/cleanmaster/hpsharelib/utils/OpLog;->x(Ljava/lang/String;Ljava/lang/String;)V

    move v1, v0

    .line 66
    goto/16 :goto_36

    .line 67
    :cond_c7
    new-instance v8, Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;

    invoke-direct {v8}, Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;-><init>()V

    .line 68
    iget-object v9, v1, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;->mTask:Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;

    .line 69
    new-instance v10, Lcom/cleanmaster/scanengin/e;

    invoke-direct {v10, p0, v9, v8, v5}, Lcom/cleanmaster/scanengin/e;-><init>(Lcom/cleanmaster/scanengin/d;Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;Ljava/util/concurrent/CountDownLatch;)V

    .line 81
    iget-object v9, p0, Lcom/cleanmaster/scanengin/d;->mTaskCtrl:Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;

    new-instance v11, Lcom/cleanmaster/scanengin/f;

    invoke-direct {v11, p0, v8}, Lcom/cleanmaster/scanengin/f;-><init>(Lcom/cleanmaster/scanengin/d;Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;)V

    invoke-virtual {v9, v11}, Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;->addObserver(Lcom/cleanmaster/bitloader/task/IScanTaskControllerObserver;)I

    move-result v8

    .line 108
    invoke-static {v8}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v8

    invoke-interface {v3, v8}, Ljava/util/List;->add(Ljava/lang/Object;)Z

    .line 109
    iget-object v1, v1, Lcom/cleanmaster/hpsharelib/scanengin/TaskBus$TaskInfo;->mTask:Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;

    invoke-interface {v1}, Lcom/cm/plugincluster/softmgr/interfaces/junk/IScanTask;->getTaskDesc()Ljava/lang/String;

    move-result-object v1

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

    .line 110
    invoke-virtual {v10}, Ljava/lang/Thread;->start()V
    :try_end_f1
    .catchall {:try_start_14 .. :try_end_f1} :catchall_118

    .line 112
    add-int/lit8 v0, v0, 0x1

    move v1, v0

    goto/16 :goto_36

    .line 120
    :cond_f6
    :try_start_f6
    invoke-virtual {v5}, Ljava/util/concurrent/CountDownLatch;->await()V
    :try_end_f9
    .catch Ljava/lang/Exception; {:try_start_f6 .. :try_end_f9} :catch_113
    .catchall {:try_start_f6 .. :try_end_f9} :catchall_118

    .line 126
    :goto_f9
    invoke-interface {v3}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v1

    :goto_fd
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_2

    invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/lang/Integer;

    .line 127
    iget-object v2, p0, Lcom/cleanmaster/scanengin/d;->mTaskCtrl:Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;

    invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I

    move-result v0

    invoke-virtual {v2, v0}, Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;->removeObserver(I)V

    goto :goto_fd

    .line 121
    :catch_113
    move-exception v0

    .line 123
    :try_start_114
    invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
    :try_end_117
    .catchall {:try_start_114 .. :try_end_117} :catchall_118

    goto :goto_f9

    .line 126
    :catchall_118
    move-exception v0

    move-object v1, v0

    invoke-interface {v3}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v2

    :goto_11e
    invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_134

    invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/lang/Integer;

    .line 127
    iget-object v3, p0, Lcom/cleanmaster/scanengin/d;->mTaskCtrl:Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;

    invoke-virtual {v0}, Ljava/lang/Integer;->intValue()I

    move-result v0

    invoke-virtual {v3, v0}, Lcom/cleanmaster/bitloader/task/TaskCtrlImpl;->removeObserver(I)V

    goto :goto_11e

    .line 128
    :cond_134
    throw v1
.end method