a.smali

.class public Lcom/cleanmaster/service/scantree/task/a;
.super Ljava/lang/Object;
.source "ReportTask.java"

# interfaces
.implements Lcom/cleanmaster/service/scantree/SDTreeFileScanner$Callback;
.implements Ljava/lang/Runnable;


# instance fields
.field private volatile a:J

.field private volatile b:Z

.field private c:Lcom/cleanmaster/service/scantree/h;


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

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

    .line 24
    const-wide/16 v0, 0x0

    iput-wide v0, p0, Lcom/cleanmaster/service/scantree/task/a;->a:J

    .line 25
    const/4 v0, 0x0

    iput-boolean v0, p0, Lcom/cleanmaster/service/scantree/task/a;->b:Z

    return-void
.end method

.method private static a(Lcom/cleanmaster/service/scantree/h;J)Ljava/util/Queue;
    .registers 14
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Lcom/cleanmaster/service/scantree/h;",
            "J)",
            "Ljava/util/Queue",
            "<",
            "Lcom/cleanmaster/service/scantree/h;",
            ">;"
        }
    .end annotation

    .prologue
    .line 53
    if-nez p0, :cond_4

    const/4 v0, 0x0

    .line 82
    :goto_3
    return-object v0

    .line 54
    :cond_4
    new-instance v3, Ljava/util/concurrent/LinkedBlockingQueue;

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

    .line 55
    new-instance v4, Ljava/util/concurrent/LinkedBlockingQueue;

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

    .line 56
    invoke-interface {v4, p0}, Ljava/util/Queue;->offer(Ljava/lang/Object;)Z

    .line 57
    const/4 v0, 0x0

    move v1, v0

    .line 59
    :cond_13
    :goto_13
    invoke-interface {v4}, Ljava/util/Queue;->isEmpty()Z

    move-result v0

    if-eqz v0, :cond_1b

    move-object v0, v3

    .line 82
    goto :goto_3

    .line 60
    :cond_1b
    invoke-interface {v4}, Ljava/util/Queue;->poll()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/cleanmaster/service/scantree/h;

    .line 62
    invoke-virtual {v0}, Lcom/cleanmaster/service/scantree/h;->d()Ljava/util/List;

    move-result-object v2

    .line 63
    if-eqz v2, :cond_13

    .line 67
    invoke-interface {v2}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v5

    move v2, v1

    :cond_2c
    :goto_2c
    invoke-interface {v5}, Ljava/util/Iterator;->hasNext()Z

    move-result v1

    if-eqz v1, :cond_88

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

    move-result-object v1

    check-cast v1, Lcom/cleanmaster/service/scantree/h;

    .line 68
    invoke-virtual {v1}, Lcom/cleanmaster/service/scantree/h;->a()Ljava/lang/String;

    move-result-object v6

    invoke-static {v6}, Lcom/cleanmaster/service/scantree/cloudconfig/ScanTreeConfig;->b(Ljava/lang/String;)Z

    move-result v6

    if-eqz v6, :cond_84

    .line 69
    invoke-virtual {v1}, Lcom/cleanmaster/service/scantree/h;->b()J

    move-result-wide v6

    cmp-long v6, v6, p1

    if-gtz v6, :cond_2c

    .line 70
    add-int/lit8 v2, v2, 0x1

    .line 71
    invoke-interface {v3, v1}, Ljava/util/Queue;->offer(Ljava/lang/Object;)Z

    .line 72
    const-string v1, "TreeScanTaskReport"

    new-instance v6, Ljava/lang/StringBuilder;

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

    const-string v7, "("

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

    move-result-object v6

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

    move-result-object v6

    const-string v7, ")"

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

    move-result-object v6

    invoke-virtual {v0}, Lcom/cleanmaster/service/scantree/h;->e()Ljava/lang/String;

    move-result-object v7

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

    move-result-object v6

    const-string v7, " "

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

    move-result-object v6

    invoke-virtual {v0}, Lcom/cleanmaster/service/scantree/h;->b()J

    move-result-wide v8

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

    move-result-object v6

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

    move-result-object v6

    invoke-static {v1, v6}, Lcom/cleanmaster/service/scantree/b;->c(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_2c

    .line 77
    :cond_84
    invoke-interface {v4, v1}, Ljava/util/Queue;->offer(Ljava/lang/Object;)Z

    goto :goto_2c

    :cond_88
    move v1, v2

    .line 80
    goto :goto_13
.end method


# virtual methods
.method public onError(ILjava/lang/String;)V
    .registers 6

    .prologue
    .line 37
    const-string v0, "TreeScanTaskReport"

    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string/jumbo v2, "\u626b\u63cf\u51fa\u9519\uff1acode:"

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

    move-result-object v1

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

    move-result-object v1

    const-string v2, ", msg:"

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

    move-result-object v1

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

    move-result-object v1

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

    move-result-object v1

    invoke-static {v0, v1}, Lcom/cleanmaster/service/scantree/b;->a(Ljava/lang/String;Ljava/lang/String;)V

    .line 38
    return-void
.end method

.method public onFinishScan(Lcom/cleanmaster/service/scantree/h;)V
    .registers 7

    .prologue
    .line 42
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v0

    iget-wide v2, p0, Lcom/cleanmaster/service/scantree/task/a;->a:J

    sub-long/2addr v0, v2

    long-to-float v0, v0

    const/high16 v1, 0x447a0000    # 1000.0f

    div-float/2addr v0, v1

    float-to-double v0, v0

    .line 43
    const-string v2, "TreeScanTaskReport"

    new-instance v3, Ljava/lang/StringBuilder;

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

    const-string/jumbo v4, "\u626b\u63cf\u5b8c\u6210,\u603b\u5171\u8017\u65f6\uff1a"

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

    move-result-object v3

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

    move-result-object v0

    const-string/jumbo v1, "\u79d2"

    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 {v2, v0}, Lcom/cleanmaster/service/scantree/b;->c(Ljava/lang/String;Ljava/lang/String;)V

    .line 44
    if-nez p1, :cond_2f

    .line 49
    :goto_2e
    return-void

    .line 45
    :cond_2f
    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/cleanmaster/service/scantree/task/a;->b:Z

    .line 46
    iput-object p1, p0, Lcom/cleanmaster/service/scantree/task/a;->c:Lcom/cleanmaster/service/scantree/h;

    .line 47
    sget-object v0, Lcom/cleanmaster/service/scantree/d;->a:Ljava/util/concurrent/ThreadPoolExecutor;

    invoke-virtual {v0, p0}, Ljava/util/concurrent/ThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V

    goto :goto_2e
.end method

.method public onStartScan()V
    .registers 3

    .prologue
    .line 30
    const-string v0, "TreeScanTaskReport"

    const-string/jumbo v1, "\u5f00\u59cb\u626b\u63cf"

    invoke-static {v0, v1}, Lcom/cleanmaster/service/scantree/b;->b(Ljava/lang/String;Ljava/lang/String;)V

    .line 31
    const/4 v0, 0x0

    iput-boolean v0, p0, Lcom/cleanmaster/service/scantree/task/a;->b:Z

    .line 32
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v0

    iput-wide v0, p0, Lcom/cleanmaster/service/scantree/task/a;->a:J

    .line 33
    return-void
.end method

.method public run()V
    .registers 6

    .prologue
    .line 87
    iget-boolean v0, p0, Lcom/cleanmaster/service/scantree/task/a;->b:Z

    if-eqz v0, :cond_8

    iget-object v0, p0, Lcom/cleanmaster/service/scantree/task/a;->c:Lcom/cleanmaster/service/scantree/h;

    if-nez v0, :cond_9

    .line 122
    :cond_8
    :goto_8
    return-void

    .line 89
    :cond_9
    iget-object v0, p0, Lcom/cleanmaster/service/scantree/task/a;->c:Lcom/cleanmaster/service/scantree/h;

    const-wide/32 v2, 0x500000

    invoke-static {v0, v2, v3}, Lcom/cleanmaster/service/scantree/task/a;->a(Lcom/cleanmaster/service/scantree/h;J)Ljava/util/Queue;

    move-result-object v2

    .line 90
    if-eqz v2, :cond_1a

    invoke-interface {v2}, Ljava/util/Queue;->size()I

    move-result v0

    if-nez v0, :cond_23

    .line 91
    :cond_1a
    const-string v0, "TreeScanTaskReport"

    const-string/jumbo v1, "\u672a\u53d1\u73b0\u547d\u4e2d\u9ed1\u8bcd\u7684\u8def\u5f84\uff0c\u4e0d\u8fdb\u884c\u4e0a\u4f20"

    invoke-static {v0, v1}, Lcom/cleanmaster/service/scantree/b;->d(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_8

    .line 95
    :cond_23
    invoke-static {}, Landroid/os/Environment;->getExternalStorageDirectory()Ljava/io/File;

    move-result-object v1

    .line 96
    const-string v0, ""

    .line 97
    if-eqz v1, :cond_77

    .line 98
    invoke-virtual {v1}, Ljava/io/File;->getAbsolutePath()Ljava/lang/String;

    move-result-object v0

    move-object v1, v0

    .line 101
    :goto_30
    new-instance v3, Ljava/util/ArrayList;

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

    .line 103
    :cond_35
    :goto_35
    invoke-interface {v2}, Ljava/util/Queue;->isEmpty()Z

    move-result v0

    if-eqz v0, :cond_50

    .line 115
    new-instance v0, Lcom/cleanmaster/service/scantree/cloudconfig/a;

    invoke-direct {v0}, Lcom/cleanmaster/service/scantree/cloudconfig/a;-><init>()V

    .line 116
    const/4 v1, 0x1

    invoke-virtual {v0, v3, v1}, Lcom/cleanmaster/service/scantree/cloudconfig/a;->a(Ljava/util/List;I)Z

    move-result v0

    .line 117
    if-nez v0, :cond_6e

    .line 118
    const-string v0, "TreeScanTaskReport"

    const-string/jumbo v1, "\u8def\u5f84\u4e0a\u4f20\u5931\u8d25"

    invoke-static {v0, v1}, Lcom/cleanmaster/service/scantree/b;->d(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_8

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

    move-result-object v0

    check-cast v0, Lcom/cleanmaster/service/scantree/h;

    .line 105
    if-eqz v0, :cond_35

    .line 106
    invoke-virtual {v0}, Lcom/cleanmaster/service/scantree/h;->e()Ljava/lang/String;

    move-result-object v0

    .line 108
    invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v4

    if-nez v4, :cond_35

    .line 111
    invoke-virtual {v1}, Ljava/lang/String;->length()I

    move-result v4

    invoke-virtual {v0, v4}, Ljava/lang/String;->substring(I)Ljava/lang/String;

    move-result-object v0

    .line 112
    invoke-interface {v3, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z

    goto :goto_35

    .line 120
    :cond_6e
    const-string v0, "TreeScanTaskReport"

    const-string/jumbo v1, "\u8def\u5f84\u4e0a\u4f20\u6210\u529f"

    invoke-static {v0, v1}, Lcom/cleanmaster/service/scantree/b;->c(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_8

    :cond_77
    move-object v1, v0

    goto :goto_30
.end method