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