TimeCalculator.smali 
.class public Lcom/taobao/weex/utils/tools/TimeCalculator;
.super Ljava/lang/Object;
.source "TimeCalculator.java"
# static fields
.field public static final PLATFORM_ANDROID:Ljava/lang/String; = "Android"
.field public static final TIMELINE_TAG:Ljava/lang/String; = "timeline"
# instance fields
.field private logRecorder:Ljava/util/concurrent/CopyOnWriteArrayList;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/CopyOnWriteArrayList<",
            "Lcom/taobao/weex/utils/tools/LogDetail;",
            ">;"
        }
    .end annotation
.end field
.field private test:Ljava/lang/String;
# direct methods
.method public constructor <init>(Lcom/taobao/weex/WXSDKInstance;)V
    .registers 2
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "instance"
        }
    .end annotation
    .line 36
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V
    const-string/jumbo p1, "{\"time\":{\"execTime\":0,\"constructor\":0,\"destructor\":0,\"taskStart\":0,\"taskEnd\":0,\"waitTime\":0},\"Info\":{\"taskInfo\":{\"relateTaskId\":0,\"args\":\"stringReplace\"},\"taskName\":\"stringReplace\",\"instanceId\":\"1\",\"platform\":\"stringReplace\",\"taskId\":0}}"
    .line 66
    iput-object p1, p0, Lcom/taobao/weex/utils/tools/TimeCalculator;->test:Ljava/lang/String;
    .line 37
    new-instance p1, Ljava/util/concurrent/CopyOnWriteArrayList;
    invoke-direct {p1}, Ljava/util/concurrent/CopyOnWriteArrayList;-><init>()V
    iput-object p1, p0, Lcom/taobao/weex/utils/tools/TimeCalculator;->logRecorder:Ljava/util/concurrent/CopyOnWriteArrayList;
    return-void
.end method
# virtual methods
.method public addLog(Lcom/taobao/weex/utils/tools/LogDetail;)V
    .registers 3
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "logDetail"
        }
    .end annotation
    .line 41
    invoke-static {}, Lcom/taobao/weex/WXEnvironment;->isPerf()Z
    move-result v0
    if-nez v0, :cond_7
    return-void
    .line 44
    :cond_7
    iget-object v0, p0, Lcom/taobao/weex/utils/tools/TimeCalculator;->logRecorder:Ljava/util/concurrent/CopyOnWriteArrayList;
    invoke-virtual {v0, p1}, Ljava/util/concurrent/CopyOnWriteArrayList;->add(Ljava/lang/Object;)Z
    return-void
.end method
.method public createLogDetail(Ljava/lang/String;)Lcom/taobao/weex/utils/tools/LogDetail;
    .registers 3
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "name"
        }
    .end annotation
    .line 48
    new-instance v0, Lcom/taobao/weex/utils/tools/LogDetail;
    invoke-direct {v0}, Lcom/taobao/weex/utils/tools/LogDetail;-><init>()V
    .line 49
    invoke-virtual {v0, p1}, Lcom/taobao/weex/utils/tools/LogDetail;->name(Ljava/lang/String;)V
    .line 50
    invoke-virtual {p0, v0}, Lcom/taobao/weex/utils/tools/TimeCalculator;->addLog(Lcom/taobao/weex/utils/tools/LogDetail;)V
    return-object v0
.end method
.method public println()V
    .registers 4
    .line 55
    invoke-static {}, Lcom/taobao/weex/WXEnvironment;->isPerf()Z
    move-result v0
    if-nez v0, :cond_7
    return-void
    .line 59
    :cond_7
    iget-object v0, p0, Lcom/taobao/weex/utils/tools/TimeCalculator;->logRecorder:Ljava/util/concurrent/CopyOnWriteArrayList;
    invoke-virtual {v0}, Ljava/util/concurrent/CopyOnWriteArrayList;->iterator()Ljava/util/Iterator;
    move-result-object v0
    :goto_d
    invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
    move-result v1
    if-eqz v1, :cond_23
    invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
    move-result-object v1
    check-cast v1, Lcom/taobao/weex/utils/tools/LogDetail;
    .line 60
    invoke-static {v1}, Lcom/alibaba/fastjson/JSON;->toJSONString(Ljava/lang/Object;)Ljava/lang/String;
    move-result-object v1
    const-string v2, "timeline"
    invoke-static {v2, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
    goto :goto_d
    :cond_23
    return-void
.end method