WXTracing.smali
.class public Lcom/taobao/weex/tracing/WXTracing;
.super Ljava/lang/Object;
.source "WXTracing.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/taobao/weex/tracing/WXTracing$TraceInfo;,
Lcom/taobao/weex/tracing/WXTracing$TraceEvent;
}
.end annotation
# static fields
.field private static final sIdGenerator:Ljava/util/concurrent/atomic/AtomicInteger;
# direct methods
.method static constructor <clinit>()V
.registers 2
.line 37
new-instance v0, Ljava/util/concurrent/atomic/AtomicInteger;
const/4 v1, 0x0
invoke-direct {v0, v1}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>(I)V
sput-object v0, Lcom/taobao/weex/tracing/WXTracing;->sIdGenerator:Ljava/util/concurrent/atomic/AtomicInteger;
return-void
.end method
.method public constructor <init>()V
.registers 1
.line 36
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static currentThreadName()Ljava/lang/String;
.registers 3
.line 97
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v0
.line 98
invoke-virtual {v0}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v0
const-string v1, "WeexJSBridgeThread"
.line 100
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_13
const-string v0, "JSThread"
return-object v0
:cond_13
const-string v1, "WeeXDomThread"
.line 102
invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v1
if-eqz v1, :cond_1e
const-string v0, "DOMThread"
return-object v0
.line 104
:cond_1e
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v1
invoke-static {}, Landroid/os/Looper;->myLooper()Landroid/os/Looper;
move-result-object v2
if-ne v1, v2, :cond_2a
const-string v0, "UIThread"
:cond_2a
return-object v0
.end method
.method public static isAvailable()Z
.registers 1
.line 44
invoke-static {}, Lcom/taobao/weex/WXEnvironment;->isApkDebugable()Z
move-result v0
return v0
.end method
.method public static newEvent(Ljava/lang/String;Ljava/lang/String;I)Lcom/taobao/weex/tracing/WXTracing$TraceEvent;
.registers 4
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0,
0x0,
0x0
}
names = {
"fname",
"instanceId",
"parentId"
}
.end annotation
.line 112
new-instance v0, Lcom/taobao/weex/tracing/WXTracing$TraceEvent;
invoke-direct {v0}, Lcom/taobao/weex/tracing/WXTracing$TraceEvent;-><init>()V
.line 113
iput-object p0, v0, Lcom/taobao/weex/tracing/WXTracing$TraceEvent;->fname:Ljava/lang/String;
.line 114
iput-object p1, v0, Lcom/taobao/weex/tracing/WXTracing$TraceEvent;->iid:Ljava/lang/String;
.line 115
invoke-static {}, Lcom/taobao/weex/tracing/WXTracing;->nextId()I
move-result p0
iput p0, v0, Lcom/taobao/weex/tracing/WXTracing$TraceEvent;->traceId:I
.line 116
iput p2, v0, Lcom/taobao/weex/tracing/WXTracing$TraceEvent;->parentId:I
return-object v0
.end method
.method public static nextId()I
.registers 1
.line 40
sget-object v0, Lcom/taobao/weex/tracing/WXTracing;->sIdGenerator:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicInteger;->getAndIncrement()I
move-result v0
return v0
.end method
.method public static declared-synchronized submit(Lcom/taobao/weex/tracing/WXTracing$TraceEvent;)V
.registers 3
.annotation system Ldalvik/annotation/MethodParameters;
accessFlags = {
0x0
}
names = {
"event"
}
.end annotation
const-class v0, Lcom/taobao/weex/tracing/WXTracing;
monitor-enter v0
.line 48
:try_start_3
invoke-static {}, Lcom/taobao/weex/WXSDKManager;->getInstance()Lcom/taobao/weex/WXSDKManager;
move-result-object v1
invoke-virtual {v1}, Lcom/taobao/weex/WXSDKManager;->getTracingAdapter()Lcom/taobao/weex/adapter/ITracingAdapter;
move-result-object v1
if-eqz v1, :cond_10
.line 50
invoke-interface {v1, p0}, Lcom/taobao/weex/adapter/ITracingAdapter;->submitTracingEvent(Lcom/taobao/weex/tracing/WXTracing$TraceEvent;)V
:try_end_10
.catchall {:try_start_3 .. :try_end_10} :catchall_12
.line 52
:cond_10
monitor-exit v0
return-void
:catchall_12
move-exception p0
monitor-exit v0
throw p0
.end method