TraceEvent.smali
.class public Laegon/chrome/base/TraceEvent;
.super Ljava/lang/Object;
# interfaces
.implements Ljava/lang/AutoCloseable;
# annotations
.annotation runtime Laegon/chrome/base/annotations/JNINamespace;
value = "base::android"
.end annotation
.annotation build Laegon/chrome/base/annotations/MainDex;
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Laegon/chrome/base/TraceEvent$LooperMonitorHolder;,
Laegon/chrome/base/TraceEvent$IdleTracingLooperMonitor;,
Laegon/chrome/base/TraceEvent$BasicLooperMonitor;
}
.end annotation
# static fields
.field private static volatile sATraceEnabled:Z
.field private static volatile sEnabled:Z
# instance fields
.field private final mName:Ljava/lang/String;
# direct methods
.method private constructor <init>(Ljava/lang/String;Ljava/lang/String;)V
.registers 3
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Laegon/chrome/base/TraceEvent;->mName:Ljava/lang/String;
invoke-static {p1, p2}, Laegon/chrome/base/TraceEvent;->begin(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method static synthetic access$000()Z
.registers 1
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
return v0
.end method
.method static synthetic access$100(Ljava/lang/String;)V
.registers 1
invoke-static {p0}, Laegon/chrome/base/TraceEvent;->nativeBeginToplevel(Ljava/lang/String;)V
return-void
.end method
.method static synthetic access$200(Ljava/lang/String;)V
.registers 1
invoke-static {p0}, Laegon/chrome/base/TraceEvent;->nativeEndToplevel(Ljava/lang/String;)V
return-void
.end method
.method public static begin(Ljava/lang/String;)V
.registers 2
const/4 v0, 0x0
invoke-static {p0, v0}, Laegon/chrome/base/TraceEvent;->begin(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public static begin(Ljava/lang/String;Ljava/lang/String;)V
.registers 3
invoke-static {p0}, Laegon/chrome/base/EarlyTraceEvent;->begin(Ljava/lang/String;)V
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
if-eqz v0, :cond_a
invoke-static {p0, p1}, Laegon/chrome/base/TraceEvent;->nativeBegin(Ljava/lang/String;Ljava/lang/String;)V
:cond_a
return-void
.end method
.method public static enabled()Z
.registers 1
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
return v0
.end method
.method public static end(Ljava/lang/String;)V
.registers 2
const/4 v0, 0x0
invoke-static {p0, v0}, Laegon/chrome/base/TraceEvent;->end(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public static end(Ljava/lang/String;Ljava/lang/String;)V
.registers 3
invoke-static {p0}, Laegon/chrome/base/EarlyTraceEvent;->end(Ljava/lang/String;)V
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
if-eqz v0, :cond_a
invoke-static {p0, p1}, Laegon/chrome/base/TraceEvent;->nativeEnd(Ljava/lang/String;Ljava/lang/String;)V
:cond_a
return-void
.end method
.method public static finishAsync(Ljava/lang/String;J)V
.registers 4
invoke-static {p0, p1, p2}, Laegon/chrome/base/EarlyTraceEvent;->finishAsync(Ljava/lang/String;J)V
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
if-eqz v0, :cond_a
invoke-static {p0, p1, p2}, Laegon/chrome/base/TraceEvent;->nativeFinishAsync(Ljava/lang/String;J)V
:cond_a
return-void
.end method
.method public static instant(Ljava/lang/String;)V
.registers 2
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
if-eqz v0, :cond_8
const/4 v0, 0x0
invoke-static {p0, v0}, Laegon/chrome/base/TraceEvent;->nativeInstant(Ljava/lang/String;Ljava/lang/String;)V
:cond_8
return-void
.end method
.method public static instant(Ljava/lang/String;Ljava/lang/String;)V
.registers 3
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
if-eqz v0, :cond_7
invoke-static {p0, p1}, Laegon/chrome/base/TraceEvent;->nativeInstant(Ljava/lang/String;Ljava/lang/String;)V
:cond_7
return-void
.end method
.method public static maybeEnableEarlyTracing()V
.registers 2
invoke-static {}, Laegon/chrome/base/EarlyTraceEvent;->maybeEnable()V
invoke-static {}, Laegon/chrome/base/EarlyTraceEvent;->isActive()Z
move-result v0
if-eqz v0, :cond_14
invoke-static {}, Laegon/chrome/base/ThreadUtils;->getUiThreadLooper()Landroid/os/Looper;
move-result-object v0
# getter for: Laegon/chrome/base/TraceEvent$LooperMonitorHolder;->sInstance:Laegon/chrome/base/TraceEvent$BasicLooperMonitor;
invoke-static {}, Laegon/chrome/base/TraceEvent$LooperMonitorHolder;->access$500()Laegon/chrome/base/TraceEvent$BasicLooperMonitor;
move-result-object v1
invoke-virtual {v0, v1}, Landroid/os/Looper;->setMessageLogging(Landroid/util/Printer;)V
:cond_14
return-void
.end method
.method private static native nativeBegin(Ljava/lang/String;Ljava/lang/String;)V
.end method
.method private static native nativeBeginToplevel(Ljava/lang/String;)V
.end method
.method private static native nativeEnd(Ljava/lang/String;Ljava/lang/String;)V
.end method
.method private static native nativeEndToplevel(Ljava/lang/String;)V
.end method
.method private static native nativeFinishAsync(Ljava/lang/String;J)V
.end method
.method private static native nativeInstant(Ljava/lang/String;Ljava/lang/String;)V
.end method
.method private static native nativeRegisterEnabledObserver()V
.end method
.method private static native nativeStartATrace()V
.end method
.method private static native nativeStartAsync(Ljava/lang/String;J)V
.end method
.method private static native nativeStopATrace()V
.end method
.method public static registerNativeEnabledObserver()V
.registers 0
invoke-static {}, Laegon/chrome/base/TraceEvent;->nativeRegisterEnabledObserver()V
return-void
.end method
.method public static scoped(Ljava/lang/String;)Laegon/chrome/base/TraceEvent;
.registers 2
const/4 v0, 0x0
invoke-static {p0, v0}, Laegon/chrome/base/TraceEvent;->scoped(Ljava/lang/String;Ljava/lang/String;)Laegon/chrome/base/TraceEvent;
move-result-object v0
return-object v0
.end method
.method public static scoped(Ljava/lang/String;Ljava/lang/String;)Laegon/chrome/base/TraceEvent;
.registers 3
invoke-static {}, Laegon/chrome/base/EarlyTraceEvent;->enabled()Z
move-result v0
if-nez v0, :cond_e
invoke-static {}, Laegon/chrome/base/TraceEvent;->enabled()Z
move-result v0
if-nez v0, :cond_e
const/4 v0, 0x0
:goto_d
return-object v0
:cond_e
new-instance v0, Laegon/chrome/base/TraceEvent;
invoke-direct {v0, p0, p1}, Laegon/chrome/base/TraceEvent;-><init>(Ljava/lang/String;Ljava/lang/String;)V
goto :goto_d
.end method
.method public static setATraceEnabled(Z)V
.registers 2
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sATraceEnabled:Z
if-ne v0, p0, :cond_5
:goto_4
return-void
:cond_5
sput-boolean p0, Laegon/chrome/base/TraceEvent;->sATraceEnabled:Z
if-eqz p0, :cond_d
invoke-static {}, Laegon/chrome/base/TraceEvent;->nativeStartATrace()V
goto :goto_4
:cond_d
invoke-static {}, Laegon/chrome/base/TraceEvent;->nativeStopATrace()V
goto :goto_4
.end method
.method public static setEnabled(Z)V
.registers 3
.annotation build Laegon/chrome/base/annotations/CalledByNative;
.end annotation
if-eqz p0, :cond_5
invoke-static {}, Laegon/chrome/base/EarlyTraceEvent;->disable()V
:cond_5
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
if-eq v0, p0, :cond_f
sput-boolean p0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sATraceEnabled:Z
if-eqz v0, :cond_10
:cond_f
:goto_f
return-void
:cond_10
invoke-static {}, Laegon/chrome/base/ThreadUtils;->getUiThreadLooper()Landroid/os/Looper;
move-result-object v1
if-eqz p0, :cond_1e
# getter for: Laegon/chrome/base/TraceEvent$LooperMonitorHolder;->sInstance:Laegon/chrome/base/TraceEvent$BasicLooperMonitor;
invoke-static {}, Laegon/chrome/base/TraceEvent$LooperMonitorHolder;->access$500()Laegon/chrome/base/TraceEvent$BasicLooperMonitor;
move-result-object v0
:goto_1a
invoke-virtual {v1, v0}, Landroid/os/Looper;->setMessageLogging(Landroid/util/Printer;)V
goto :goto_f
:cond_1e
const/4 v0, 0x0
goto :goto_1a
.end method
.method public static startAsync(Ljava/lang/String;J)V
.registers 4
invoke-static {p0, p1, p2}, Laegon/chrome/base/EarlyTraceEvent;->startAsync(Ljava/lang/String;J)V
sget-boolean v0, Laegon/chrome/base/TraceEvent;->sEnabled:Z
if-eqz v0, :cond_a
invoke-static {p0, p1, p2}, Laegon/chrome/base/TraceEvent;->nativeStartAsync(Ljava/lang/String;J)V
:cond_a
return-void
.end method
# virtual methods
.method public close()V
.registers 2
iget-object v0, p0, Laegon/chrome/base/TraceEvent;->mName:Ljava/lang/String;
invoke-static {v0}, Laegon/chrome/base/TraceEvent;->end(Ljava/lang/String;)V
return-void
.end method