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