apkfuckery/com.discord/smali/androidx/core/os/TraceCompat.smali

451 lines
10 KiB
Smali
Raw Normal View History

2019-07-24 11:27:29 +00:00
.class public final Landroidx/core/os/TraceCompat;
.super Ljava/lang/Object;
.source "TraceCompat.java"
2019-10-01 14:15:45 +00:00
# static fields
2019-12-06 03:29:40 +00:00
.field public static final TAG:Ljava/lang/String; = "TraceCompat"
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
.field public static sAsyncTraceBeginMethod:Ljava/lang/reflect/Method;
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
.field public static sAsyncTraceEndMethod:Ljava/lang/reflect/Method;
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
.field public static sIsTagEnabledMethod:Ljava/lang/reflect/Method;
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
.field public static sTraceCounterMethod:Ljava/lang/reflect/Method;
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
.field public static sTraceTagApp:J
2019-10-01 14:15:45 +00:00
2019-07-24 11:27:29 +00:00
# direct methods
2019-12-06 03:29:40 +00:00
.method public static constructor <clinit>()V
2019-10-01 14:15:45 +00:00
.locals 8
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-ge v0, v1, :cond_0
:try_start_0
const-class v0, Landroid/os/Trace;
const-string v1, "TRACE_TAG_APP"
invoke-virtual {v0, v1}, Ljava/lang/Class;->getField(Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v0
const/4 v1, 0x0
invoke-virtual {v0, v1}, Ljava/lang/reflect/Field;->getLong(Ljava/lang/Object;)J
move-result-wide v0
sput-wide v0, Landroidx/core/os/TraceCompat;->sTraceTagApp:J
const-class v0, Landroid/os/Trace;
const-string v1, "isTagEnabled"
const/4 v2, 0x1
new-array v3, v2, [Ljava/lang/Class;
sget-object v4, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
const/4 v5, 0x0
aput-object v4, v3, v5
invoke-virtual {v0, v1, v3}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v0
sput-object v0, Landroidx/core/os/TraceCompat;->sIsTagEnabledMethod:Ljava/lang/reflect/Method;
const-class v0, Landroid/os/Trace;
const-string v1, "asyncTraceBegin"
const/4 v3, 0x3
new-array v4, v3, [Ljava/lang/Class;
sget-object v6, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
aput-object v6, v4, v5
const-class v6, Ljava/lang/String;
aput-object v6, v4, v2
sget-object v6, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
const/4 v7, 0x2
aput-object v6, v4, v7
invoke-virtual {v0, v1, v4}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v0
sput-object v0, Landroidx/core/os/TraceCompat;->sAsyncTraceBeginMethod:Ljava/lang/reflect/Method;
const-class v0, Landroid/os/Trace;
const-string v1, "asyncTraceEnd"
new-array v4, v3, [Ljava/lang/Class;
sget-object v6, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
aput-object v6, v4, v5
const-class v6, Ljava/lang/String;
aput-object v6, v4, v2
sget-object v6, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
aput-object v6, v4, v7
invoke-virtual {v0, v1, v4}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v0
sput-object v0, Landroidx/core/os/TraceCompat;->sAsyncTraceEndMethod:Ljava/lang/reflect/Method;
const-class v0, Landroid/os/Trace;
const-string v1, "traceCounter"
new-array v3, v3, [Ljava/lang/Class;
sget-object v4, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
aput-object v4, v3, v5
const-class v4, Ljava/lang/String;
aput-object v4, v3, v2
sget-object v2, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
aput-object v2, v3, v7
invoke-virtual {v0, v1, v3}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v0
sput-object v0, Landroidx/core/os/TraceCompat;->sTraceCounterMethod:Ljava/lang/reflect/Method;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
2019-12-06 03:29:40 +00:00
goto :goto_0
2019-10-01 14:15:45 +00:00
:catch_0
move-exception v0
const-string v1, "TraceCompat"
const-string v2, "Unable to initialize via reflection."
invoke-static {v1, v2, v0}, Landroid/util/Log;->i(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:cond_0
2019-12-06 03:29:40 +00:00
:goto_0
2019-10-01 14:15:45 +00:00
return-void
.end method
2019-12-06 03:29:40 +00:00
.method public constructor <init>()V
2019-07-24 11:27:29 +00:00
.locals 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
2019-10-01 14:15:45 +00:00
.method public static beginAsyncSection(Ljava/lang/String;I)V
.locals 6
2019-12-06 03:29:40 +00:00
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
2019-10-01 14:15:45 +00:00
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
invoke-static {p0, p1}, Landroid/os/Trace;->beginAsyncSection(Ljava/lang/String;I)V
2019-12-06 03:29:40 +00:00
goto :goto_0
2019-10-01 14:15:45 +00:00
:cond_0
:try_start_0
sget-object v0, Landroidx/core/os/TraceCompat;->sAsyncTraceBeginMethod:Ljava/lang/reflect/Method;
const/4 v1, 0x0
const/4 v2, 0x3
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
sget-wide v4, Landroidx/core/os/TraceCompat;->sTraceTagApp:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
aput-object v4, v2, v3
const/4 v3, 0x1
aput-object p0, v2, v3
const/4 p0, 0x2
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
aput-object p1, v2, p0
invoke-virtual {v0, v1, v2}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
2019-12-06 03:29:40 +00:00
goto :goto_0
2019-10-01 14:15:45 +00:00
:catch_0
const-string p0, "TraceCompat"
const-string p1, "Unable to invoke asyncTraceBegin() via reflection."
invoke-static {p0, p1}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
2019-12-06 03:29:40 +00:00
:goto_0
2019-10-01 14:15:45 +00:00
return-void
.end method
2019-07-24 11:27:29 +00:00
.method public static beginSection(Ljava/lang/String;)V
2019-12-06 03:29:40 +00:00
.locals 1
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
2019-07-24 11:27:29 +00:00
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
invoke-static {p0}, Landroid/os/Trace;->beginSection(Ljava/lang/String;)V
return-void
.end method
2019-10-01 14:15:45 +00:00
.method public static endAsyncSection(Ljava/lang/String;I)V
.locals 6
2019-12-06 03:29:40 +00:00
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
2019-10-01 14:15:45 +00:00
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
invoke-static {p0, p1}, Landroid/os/Trace;->endAsyncSection(Ljava/lang/String;I)V
2019-12-06 03:29:40 +00:00
goto :goto_0
2019-10-01 14:15:45 +00:00
:cond_0
:try_start_0
sget-object v0, Landroidx/core/os/TraceCompat;->sAsyncTraceEndMethod:Ljava/lang/reflect/Method;
const/4 v1, 0x0
const/4 v2, 0x3
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
sget-wide v4, Landroidx/core/os/TraceCompat;->sTraceTagApp:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
aput-object v4, v2, v3
const/4 v3, 0x1
aput-object p0, v2, v3
const/4 p0, 0x2
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
aput-object p1, v2, p0
invoke-virtual {v0, v1, v2}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
2019-12-06 03:29:40 +00:00
goto :goto_0
2019-10-01 14:15:45 +00:00
:catch_0
const-string p0, "TraceCompat"
const-string p1, "Unable to invoke endAsyncSection() via reflection."
invoke-static {p0, p1}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
2019-12-06 03:29:40 +00:00
:goto_0
2019-10-01 14:15:45 +00:00
return-void
.end method
2019-07-24 11:27:29 +00:00
.method public static endSection()V
2019-12-06 03:29:40 +00:00
.locals 1
2019-07-24 11:27:29 +00:00
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
invoke-static {}, Landroid/os/Trace;->endSection()V
return-void
.end method
2019-10-01 14:15:45 +00:00
.method public static isEnabled()Z
.locals 6
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
invoke-static {}, Landroid/os/Trace;->isEnabled()Z
move-result v0
return v0
:cond_0
2019-12-06 03:29:40 +00:00
const/4 v0, 0x0
2019-10-01 14:15:45 +00:00
:try_start_0
2019-12-06 03:29:40 +00:00
sget-object v1, Landroidx/core/os/TraceCompat;->sIsTagEnabledMethod:Ljava/lang/reflect/Method;
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
const/4 v2, 0x0
2019-10-01 14:15:45 +00:00
const/4 v3, 0x1
new-array v3, v3, [Ljava/lang/Object;
sget-wide v4, Landroidx/core/os/TraceCompat;->sTraceTagApp:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
2019-12-06 03:29:40 +00:00
aput-object v4, v3, v0
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
invoke-virtual {v1, v2, v3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
move-result-object v1
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
check-cast v1, Ljava/lang/Boolean;
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
invoke-virtual {v1}, Ljava/lang/Boolean;->booleanValue()Z
2019-10-01 14:15:45 +00:00
move-result v0
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
return v0
:catch_0
2019-12-06 03:29:40 +00:00
const-string v1, "TraceCompat"
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
const-string v2, "Unable to invoke isTagEnabled() via reflection."
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
invoke-static {v1, v2}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
2019-10-01 14:15:45 +00:00
2019-12-06 03:29:40 +00:00
return v0
2019-10-01 14:15:45 +00:00
.end method
.method public static setCounter(Ljava/lang/String;I)V
.locals 6
2019-12-06 03:29:40 +00:00
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
2019-10-01 14:15:45 +00:00
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
int-to-long v0, p1
invoke-static {p0, v0, v1}, Landroid/os/Trace;->setCounter(Ljava/lang/String;J)V
2019-12-06 03:29:40 +00:00
goto :goto_0
2019-10-01 14:15:45 +00:00
:cond_0
:try_start_0
sget-object v0, Landroidx/core/os/TraceCompat;->sTraceCounterMethod:Ljava/lang/reflect/Method;
const/4 v1, 0x0
const/4 v2, 0x3
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
sget-wide v4, Landroidx/core/os/TraceCompat;->sTraceTagApp:J
invoke-static {v4, v5}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
aput-object v4, v2, v3
const/4 v3, 0x1
aput-object p0, v2, v3
const/4 p0, 0x2
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p1
aput-object p1, v2, p0
invoke-virtual {v0, v1, v2}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
2019-12-06 03:29:40 +00:00
goto :goto_0
2019-10-01 14:15:45 +00:00
:catch_0
const-string p0, "TraceCompat"
const-string p1, "Unable to invoke traceCounter() via reflection."
invoke-static {p0, p1}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I
2019-12-06 03:29:40 +00:00
:goto_0
2019-10-01 14:15:45 +00:00
return-void
.end method