WXTimerModule.smali

.class public Lcom/taobao/weex/ui/module/WXTimerModule;
.super Lcom/taobao/weex/common/WXModule;
.source "WXTimerModule.java"

# interfaces
.implements Lcom/taobao/weex/common/Destroyable;
.implements Landroid/os/Handler$Callback;


# static fields
.field private static final TAG:Ljava/lang/String; = "timer"


# instance fields
.field private antiIntAutoBoxing:Landroid/util/SparseArray;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Landroid/util/SparseArray<",
            "Ljava/lang/Integer;",
            ">;"
        }
    .end annotation
.end field

.field private handler:Landroid/os/Handler;


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

    .line 64
    invoke-direct {p0}, Lcom/taobao/weex/common/WXModule;-><init>()V

    .line 65
    new-instance v0, Landroid/os/Handler;

    invoke-static {}, Lcom/taobao/weex/bridge/WXBridgeManager;->getInstance()Lcom/taobao/weex/bridge/WXBridgeManager;

    move-result-object v1

    invoke-virtual {v1}, Lcom/taobao/weex/bridge/WXBridgeManager;->getJSLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-direct {v0, v1, p0}, Landroid/os/Handler;-><init>(Landroid/os/Looper;Landroid/os/Handler$Callback;)V

    iput-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    .line 66
    new-instance v0, Landroid/util/SparseArray;

    invoke-direct {v0}, Landroid/util/SparseArray;-><init>()V

    iput-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->antiIntAutoBoxing:Landroid/util/SparseArray;

    return-void
.end method

.method private checkIfTimerInBack(I)V
    .registers 5
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "instanceId"
        }
    .end annotation

    .line 156
    invoke-static {}, Lcom/taobao/weex/WXSDKManager;->getInstance()Lcom/taobao/weex/WXSDKManager;

    move-result-object v0

    invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object p1

    invoke-virtual {v0, p1}, Lcom/taobao/weex/WXSDKManager;->getSDKInstance(Ljava/lang/String;)Lcom/taobao/weex/WXSDKInstance;

    move-result-object p1

    if-nez p1, :cond_f

    return-void

    .line 160
    :cond_f
    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->isViewDisAppear()Z

    move-result v0

    if-eqz v0, :cond_21

    .line 161
    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->getApmForInstance()Lcom/taobao/weex/performance/WXInstanceApm;

    move-result-object p1

    const-wide/high16 v0, 0x3ff0000000000000L    # 1.0

    const-string/jumbo v2, "wxTimerInBackCount"

    invoke-virtual {p1, v2, v0, v1}, Lcom/taobao/weex/performance/WXInstanceApm;->updateDiffStats(Ljava/lang/String;D)V

    :cond_21
    return-void
.end method

.method private createTimerArgs(IIZ)[Lcom/taobao/weex/bridge/WXJSObject;
    .registers 8
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0,
            0x0,
            0x0
        }
        names = {
            "instanceId",
            "funcId",
            "keepAlive"
        }
    .end annotation

    .line 171
    new-instance v0, Ljava/util/ArrayList;

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

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

    move-result-object p2

    invoke-virtual {v0, p2}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 173
    new-instance p2, Ljava/util/HashMap;

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

    invoke-virtual {v0, p2}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 174
    invoke-static {p3}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;

    move-result-object p2

    invoke-virtual {v0, p2}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 175
    new-instance p2, Lcom/taobao/weex/bridge/WXHashMap;

    invoke-direct {p2}, Lcom/taobao/weex/bridge/WXHashMap;-><init>()V

    const-string p3, "method"

    const-string v1, "callback"

    .line 176
    invoke-virtual {p2, p3, v1}, Lcom/taobao/weex/bridge/WXHashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const-string p3, "args"

    .line 177
    invoke-virtual {p2, p3, v0}, Lcom/taobao/weex/bridge/WXHashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    const/4 p3, 0x1

    new-array v0, p3, [Ljava/lang/Object;

    const/4 v1, 0x0

    aput-object p2, v0, v1

    const/4 p2, 0x2

    new-array v2, p2, [Lcom/taobao/weex/bridge/WXJSObject;

    .line 179
    new-instance v3, Lcom/taobao/weex/bridge/WXJSObject;

    .line 180
    invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object p1

    invoke-direct {v3, p2, p1}, Lcom/taobao/weex/bridge/WXJSObject;-><init>(ILjava/lang/Object;)V

    aput-object v3, v2, v1

    new-instance p1, Lcom/taobao/weex/bridge/WXJSObject;

    .line 182
    invoke-static {v0}, Lcom/taobao/weex/utils/WXJsonUtils;->fromObjectToJSONString(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object p2

    const/4 v0, 0x3

    invoke-direct {p1, v0, p2}, Lcom/taobao/weex/bridge/WXJSObject;-><init>(ILjava/lang/Object;)V

    aput-object p1, v2, p3

    return-object v2
.end method

.method private postMessage(IIII)V
    .registers 7
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0,
            0x0,
            0x0,
            0x0
        }
        names = {
            "what",
            "funcId",
            "interval",
            "instanceId"
        }
    .end annotation

    if-ltz p3, :cond_29

    if-gtz p2, :cond_5

    goto :goto_29

    .line 207
    :cond_5
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->antiIntAutoBoxing:Landroid/util/SparseArray;

    invoke-virtual {v0, p2}, Landroid/util/SparseArray;->get(I)Ljava/lang/Object;

    move-result-object v0

    if-nez v0, :cond_16

    .line 208
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->antiIntAutoBoxing:Landroid/util/SparseArray;

    invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v1

    invoke-virtual {v0, p2, v1}, Landroid/util/SparseArray;->put(ILjava/lang/Object;)V

    .line 210
    :cond_16
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    iget-object v1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->antiIntAutoBoxing:Landroid/util/SparseArray;

    .line 211
    invoke-virtual {v1, p2}, Landroid/util/SparseArray;->get(I)Ljava/lang/Object;

    move-result-object p2

    invoke-virtual {v0, p1, p4, p3, p2}, Landroid/os/Handler;->obtainMessage(IIILjava/lang/Object;)Landroid/os/Message;

    move-result-object p1

    .line 212
    iget-object p2, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    int-to-long p3, p3

    invoke-virtual {p2, p1, p3, p4}, Landroid/os/Handler;->sendMessageDelayed(Landroid/os/Message;J)Z

    goto :goto_30

    :cond_29
    :goto_29
    const-string p1, "timer"

    const-string p2, "interval < 0 or funcId <=0"

    .line 205
    invoke-static {p1, p2}, Lcom/taobao/weex/utils/WXLogUtils;->e(Ljava/lang/String;Ljava/lang/String;)V

    :goto_30
    return-void
.end method

.method private postOrHoldMessage(IIII)V
    .registers 6
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x10,
            0x10,
            0x10,
            0x10
        }
        names = {
            "what",
            "funcId",
            "interval",
            "instanceId"
        }
    .end annotation

    .line 186
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {v0}, Lcom/taobao/weex/WXSDKInstance;->isPreRenderMode()Z

    move-result v0

    if-eqz v0, :cond_c

    .line 187
    invoke-direct {p0, p1, p2, p3, p4}, Lcom/taobao/weex/ui/module/WXTimerModule;->postMessage(IIII)V

    goto :goto_f

    .line 189
    :cond_c
    invoke-direct {p0, p1, p2, p3, p4}, Lcom/taobao/weex/ui/module/WXTimerModule;->postMessage(IIII)V

    :goto_f
    return-void
.end method

.method private removeOrHoldMessage(II)V
    .registers 6
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x10,
            0x10
        }
        names = {
            "what",
            "funcId"
        }
    .end annotation

    .line 194
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {v0}, Lcom/taobao/weex/WXSDKInstance;->isPreRenderMode()Z

    move-result v0

    if-eqz v0, :cond_18

    .line 195
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    iget-object v1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->antiIntAutoBoxing:Landroid/util/SparseArray;

    invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v2

    invoke-virtual {v1, p2, v2}, Landroid/util/SparseArray;->get(ILjava/lang/Object;)Ljava/lang/Object;

    move-result-object p2

    invoke-virtual {v0, p1, p2}, Landroid/os/Handler;->removeMessages(ILjava/lang/Object;)V

    goto :goto_27

    .line 197
    :cond_18
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    iget-object v1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->antiIntAutoBoxing:Landroid/util/SparseArray;

    invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v2

    invoke-virtual {v1, p2, v2}, Landroid/util/SparseArray;->get(ILjava/lang/Object;)Ljava/lang/Object;

    move-result-object p2

    invoke-virtual {v0, p1, p2}, Landroid/os/Handler;->removeMessages(ILjava/lang/Object;)V

    :goto_27
    return-void
.end method


# virtual methods
.method public clearInterval(I)V
    .registers 3
    .annotation runtime Lcom/taobao/weex/annotation/JSMethod;
        uiThread = false
    .end annotation

    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "funcId"
        }
    .end annotation

    if-gtz p1, :cond_3

    return-void

    :cond_3
    const/16 v0, 0xc

    .line 105
    invoke-direct {p0, v0, p1}, Lcom/taobao/weex/ui/module/WXTimerModule;->removeOrHoldMessage(II)V

    return-void
.end method

.method public clearTimeout(I)V
    .registers 3
    .annotation runtime Lcom/taobao/weex/annotation/JSMethod;
        uiThread = false
    .end annotation

    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "funcId"
        }
    .end annotation

    if-gtz p1, :cond_3

    return-void

    :cond_3
    const/16 v0, 0xb

    .line 97
    invoke-direct {p0, v0, p1}, Lcom/taobao/weex/ui/module/WXTimerModule;->removeOrHoldMessage(II)V

    return-void
.end method

.method public destroy()V
    .registers 3

    .line 110
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    if-eqz v0, :cond_1c

    .line 111
    invoke-static {}, Lcom/taobao/weex/WXEnvironment;->isApkDebugable()Z

    move-result v0

    if-eqz v0, :cond_11

    const-string v0, "timer"

    const-string v1, "Timer Module removeAllMessages: "

    .line 112
    invoke-static {v0, v1}, Lcom/taobao/weex/utils/WXLogUtils;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 114
    :cond_11
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    const/4 v1, 0x0

    invoke-virtual {v0, v1}, Landroid/os/Handler;->removeCallbacksAndMessages(Ljava/lang/Object;)V

    .line 115
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->antiIntAutoBoxing:Landroid/util/SparseArray;

    invoke-virtual {v0}, Landroid/util/SparseArray;->clear()V

    :cond_1c
    return-void
.end method

.method public handleMessage(Landroid/os/Message;)Z
    .registers 12
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "msg"
        }
    .end annotation

    const/4 v0, 0x0

    const/4 v1, 0x1

    if-eqz p1, :cond_90

    .line 124
    iget v2, p1, Landroid/os/Message;->what:I

    .line 125
    invoke-static {}, Lcom/taobao/weex/WXEnvironment;->isApkDebugable()Z

    move-result v3

    if-eqz v3, :cond_24

    .line 126
    new-instance v3, Ljava/lang/StringBuilder;

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

    const-string v4, "Timer Module handleMessage : "

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

    iget v4, p1, Landroid/os/Message;->what:I

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

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

    move-result-object v3

    const-string v4, "timer"

    invoke-static {v4, v3}, Lcom/taobao/weex/utils/WXLogUtils;->d(Ljava/lang/String;Ljava/lang/String;)V

    :cond_24
    const/16 v3, 0xb

    if-eq v2, v3, :cond_66

    const/16 v3, 0xc

    if-eq v2, v3, :cond_2d

    goto :goto_90

    .line 139
    :cond_2d
    iget-object v2, p1, Landroid/os/Message;->obj:Ljava/lang/Object;

    if-nez v2, :cond_32

    goto :goto_90

    .line 142
    :cond_32
    iget v0, p1, Landroid/os/Message;->arg1:I

    invoke-direct {p0, v0}, Lcom/taobao/weex/ui/module/WXTimerModule;->checkIfTimerInBack(I)V

    .line 143
    iget-object v0, p1, Landroid/os/Message;->obj:Ljava/lang/Object;

    check-cast v0, Ljava/lang/Integer;

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

    move-result v0

    iget v2, p1, Landroid/os/Message;->arg2:I

    iget v4, p1, Landroid/os/Message;->arg1:I

    invoke-direct {p0, v3, v0, v2, v4}, Lcom/taobao/weex/ui/module/WXTimerModule;->postMessage(IIII)V

    .line 144
    iget v0, p1, Landroid/os/Message;->arg1:I

    iget-object v2, p1, Landroid/os/Message;->obj:Ljava/lang/Object;

    check-cast v2, Ljava/lang/Integer;

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

    move-result v2

    invoke-direct {p0, v0, v2, v1}, Lcom/taobao/weex/ui/module/WXTimerModule;->createTimerArgs(IIZ)[Lcom/taobao/weex/bridge/WXJSObject;

    move-result-object v7

    .line 145
    invoke-static {}, Lcom/taobao/weex/bridge/WXBridgeManager;->getInstance()Lcom/taobao/weex/bridge/WXBridgeManager;

    move-result-object v3

    iget p1, p1, Landroid/os/Message;->arg1:I

    invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v4

    const/4 v5, 0x0

    const/4 v8, 0x1

    const-string v6, "callJS"

    invoke-virtual/range {v3 .. v8}, Lcom/taobao/weex/bridge/WXBridgeManager;->invokeExecJS(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[Lcom/taobao/weex/bridge/WXJSObject;Z)V

    goto :goto_8f

    .line 130
    :cond_66
    iget-object v2, p1, Landroid/os/Message;->obj:Ljava/lang/Object;

    if-nez v2, :cond_6b

    goto :goto_90

    .line 133
    :cond_6b
    iget v2, p1, Landroid/os/Message;->arg1:I

    invoke-direct {p0, v2}, Lcom/taobao/weex/ui/module/WXTimerModule;->checkIfTimerInBack(I)V

    .line 134
    iget v2, p1, Landroid/os/Message;->arg1:I

    iget-object v3, p1, Landroid/os/Message;->obj:Ljava/lang/Object;

    check-cast v3, Ljava/lang/Integer;

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

    move-result v3

    invoke-direct {p0, v2, v3, v0}, Lcom/taobao/weex/ui/module/WXTimerModule;->createTimerArgs(IIZ)[Lcom/taobao/weex/bridge/WXJSObject;

    move-result-object v8

    .line 135
    invoke-static {}, Lcom/taobao/weex/bridge/WXBridgeManager;->getInstance()Lcom/taobao/weex/bridge/WXBridgeManager;

    move-result-object v4

    iget p1, p1, Landroid/os/Message;->arg1:I

    invoke-static {p1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v5

    const/4 v6, 0x0

    const/4 v9, 0x1

    const-string v7, "callJS"

    invoke-virtual/range {v4 .. v9}, Lcom/taobao/weex/bridge/WXBridgeManager;->invokeExecJS(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[Lcom/taobao/weex/bridge/WXJSObject;Z)V

    :goto_8f
    move v0, v1

    :cond_90
    :goto_90
    return v0
.end method

.method setHandler(Landroid/os/Handler;)V
    .registers 2
    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0
        }
        names = {
            "handler"
        }
    .end annotation

    .line 167
    iput-object p1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->handler:Landroid/os/Handler;

    return-void
.end method

.method public setInterval(IF)V
    .registers 5
    .annotation runtime Lcom/taobao/weex/annotation/JSMethod;
        uiThread = false
    .end annotation

    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0,
            0x0
        }
        names = {
            "funcId",
            "interval"
        }
    .end annotation

    .line 83
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    if-eqz v0, :cond_36

    const/16 v0, 0xc

    float-to-int p2, p2

    .line 84
    iget-object v1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {v1}, Lcom/taobao/weex/WXSDKInstance;->getInstanceId()Ljava/lang/String;

    move-result-object v1

    invoke-static {v1}, Lcom/taobao/weex/utils/WXUtils;->parseInt(Ljava/lang/String;)I

    move-result v1

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/taobao/weex/ui/module/WXTimerModule;->postOrHoldMessage(IIII)V

    .line 85
    iget-object p1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->getWXPerformance()Lcom/taobao/weex/common/WXPerformance;

    move-result-object p1

    if-eqz p1, :cond_28

    .line 86
    iget-object p1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->getWXPerformance()Lcom/taobao/weex/common/WXPerformance;

    move-result-object p1

    iget p2, p1, Lcom/taobao/weex/common/WXPerformance;->timerInvokeCount:I

    add-int/lit8 p2, p2, 0x1

    iput p2, p1, Lcom/taobao/weex/common/WXPerformance;->timerInvokeCount:I

    .line 88
    :cond_28
    iget-object p1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->getApmForInstance()Lcom/taobao/weex/performance/WXInstanceApm;

    move-result-object p1

    const-wide/high16 v0, 0x3ff0000000000000L    # 1.0

    const-string/jumbo p2, "wxFSTimerCount"

    invoke-virtual {p1, p2, v0, v1}, Lcom/taobao/weex/performance/WXInstanceApm;->updateFSDiffStats(Ljava/lang/String;D)V

    :cond_36
    return-void
.end method

.method public setTimeout(IF)V
    .registers 5
    .annotation runtime Lcom/taobao/weex/annotation/JSMethod;
        uiThread = false
    .end annotation

    .annotation system Ldalvik/annotation/MethodParameters;
        accessFlags = {
            0x0,
            0x0
        }
        names = {
            "funcId",
            "delay"
        }
    .end annotation

    .line 72
    iget-object v0, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    if-eqz v0, :cond_36

    const/16 v0, 0xb

    float-to-int p2, p2

    .line 73
    iget-object v1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {v1}, Lcom/taobao/weex/WXSDKInstance;->getInstanceId()Ljava/lang/String;

    move-result-object v1

    invoke-static {v1}, Lcom/taobao/weex/utils/WXUtils;->parseInt(Ljava/lang/String;)I

    move-result v1

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/taobao/weex/ui/module/WXTimerModule;->postOrHoldMessage(IIII)V

    .line 74
    iget-object p1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->getWXPerformance()Lcom/taobao/weex/common/WXPerformance;

    move-result-object p1

    if-eqz p1, :cond_28

    .line 75
    iget-object p1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->getWXPerformance()Lcom/taobao/weex/common/WXPerformance;

    move-result-object p1

    iget p2, p1, Lcom/taobao/weex/common/WXPerformance;->timerInvokeCount:I

    add-int/lit8 p2, p2, 0x1

    iput p2, p1, Lcom/taobao/weex/common/WXPerformance;->timerInvokeCount:I

    .line 77
    :cond_28
    iget-object p1, p0, Lcom/taobao/weex/ui/module/WXTimerModule;->mWXSDKInstance:Lcom/taobao/weex/WXSDKInstance;

    invoke-virtual {p1}, Lcom/taobao/weex/WXSDKInstance;->getApmForInstance()Lcom/taobao/weex/performance/WXInstanceApm;

    move-result-object p1

    const-wide/high16 v0, 0x3ff0000000000000L    # 1.0

    const-string/jumbo p2, "wxFSTimerCount"

    invoke-virtual {p1, p2, v0, v1}, Lcom/taobao/weex/performance/WXInstanceApm;->updateFSDiffStats(Ljava/lang/String;D)V

    :cond_36
    return-void
.end method