Files
rr3-apk/smali/androidx/tracing/Trace.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

697 lines
16 KiB
Smali

.class public final Landroidx/tracing/Trace;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field static final MAX_TRACE_LABEL_LENGTH:I = 0x7f
.field static final TAG:Ljava/lang/String; = "Trace"
.field private static sAsyncTraceBeginMethod:Ljava/lang/reflect/Method;
.field private static sAsyncTraceEndMethod:Ljava/lang/reflect/Method;
.field private static sHasAppTracingEnabled:Z
.field private static sIsTagEnabledMethod:Ljava/lang/reflect/Method;
.field private static sTraceCounterMethod:Ljava/lang/reflect/Method;
.field private static sTraceTagApp:J
# direct methods
.method private constructor <init>()V
.locals 0
.line 312
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static beginAsyncSection(Ljava/lang/String;I)V
.locals 2
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
.line 179
invoke-static {p0}, Landroidx/tracing/Trace;->truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0, p1}, Landroidx/tracing/TraceApi29Impl;->beginAsyncSection(Ljava/lang/String;I)V
goto :goto_0
.line 181
:cond_0
invoke-static {p0}, Landroidx/tracing/Trace;->truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0, p1}, Landroidx/tracing/Trace;->beginAsyncSectionFallback(Ljava/lang/String;I)V
:goto_0
return-void
.end method
.method private static beginAsyncSectionFallback(Ljava/lang/String;I)V
.locals 8
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
const-string v0, "asyncTraceBegin"
:try_start_0
sget-object v1, Landroidx/tracing/Trace;->sAsyncTraceBeginMethod:Ljava/lang/reflect/Method;
const/4 v2, 0x2
const/4 v3, 0x1
const/4 v4, 0x0
const/4 v5, 0x3
if-nez v1, :cond_0
const-class v1, Landroid/os/Trace;
new-array v6, v5, [Ljava/lang/Class;
sget-object v7, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
aput-object v7, v6, v4
const-class v7, Ljava/lang/String;
aput-object v7, v6, v3
sget-object v7, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
aput-object v7, v6, v2
.line 242
invoke-virtual {v1, v0, v6}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v1
sput-object v1, Landroidx/tracing/Trace;->sAsyncTraceBeginMethod:Ljava/lang/reflect/Method;
goto :goto_0
:catch_0
move-exception p0
goto :goto_1
:cond_0
:goto_0
sget-object v1, Landroidx/tracing/Trace;->sAsyncTraceBeginMethod:Ljava/lang/reflect/Method;
new-array v5, v5, [Ljava/lang/Object;
sget-wide v6, Landroidx/tracing/Trace;->sTraceTagApp:J
.line 248
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v6
aput-object v6, v5, v4
aput-object p0, v5, v3
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p0
aput-object p0, v5, v2
const/4 p0, 0x0
invoke-virtual {v1, p0, v5}, 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
goto :goto_2
.line 250
:goto_1
invoke-static {v0, p0}, Landroidx/tracing/Trace;->handleException(Ljava/lang/String;Ljava/lang/Exception;)V
:goto_2
return-void
.end method
.method public static beginSection(Ljava/lang/String;)V
.locals 0
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.line 130
invoke-static {p0}, Landroidx/tracing/Trace;->truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0}, Landroidx/tracing/TraceApi18Impl;->beginSection(Ljava/lang/String;)V
return-void
.end method
.method public static endAsyncSection(Ljava/lang/String;I)V
.locals 2
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
.line 198
invoke-static {p0}, Landroidx/tracing/Trace;->truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0, p1}, Landroidx/tracing/TraceApi29Impl;->endAsyncSection(Ljava/lang/String;I)V
goto :goto_0
.line 200
:cond_0
invoke-static {p0}, Landroidx/tracing/Trace;->truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0, p1}, Landroidx/tracing/Trace;->endAsyncSectionFallback(Ljava/lang/String;I)V
:goto_0
return-void
.end method
.method private static endAsyncSectionFallback(Ljava/lang/String;I)V
.locals 8
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
const-string v0, "asyncTraceEnd"
:try_start_0
sget-object v1, Landroidx/tracing/Trace;->sAsyncTraceEndMethod:Ljava/lang/reflect/Method;
const/4 v2, 0x2
const/4 v3, 0x1
const/4 v4, 0x0
const/4 v5, 0x3
if-nez v1, :cond_0
const-class v1, Landroid/os/Trace;
new-array v6, v5, [Ljava/lang/Class;
sget-object v7, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
aput-object v7, v6, v4
const-class v7, Ljava/lang/String;
aput-object v7, v6, v3
sget-object v7, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
aput-object v7, v6, v2
.line 260
invoke-virtual {v1, v0, v6}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v1
sput-object v1, Landroidx/tracing/Trace;->sAsyncTraceEndMethod:Ljava/lang/reflect/Method;
goto :goto_0
:catch_0
move-exception p0
goto :goto_1
:cond_0
:goto_0
sget-object v1, Landroidx/tracing/Trace;->sAsyncTraceEndMethod:Ljava/lang/reflect/Method;
new-array v5, v5, [Ljava/lang/Object;
sget-wide v6, Landroidx/tracing/Trace;->sTraceTagApp:J
.line 266
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v6
aput-object v6, v5, v4
aput-object p0, v5, v3
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p0
aput-object p0, v5, v2
const/4 p0, 0x0
invoke-virtual {v1, p0, v5}, 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
goto :goto_2
.line 268
:goto_1
invoke-static {v0, p0}, Landroidx/tracing/Trace;->handleException(Ljava/lang/String;Ljava/lang/Exception;)V
:goto_2
return-void
.end method
.method public static endSection()V
.locals 0
.line 144
invoke-static {}, Landroidx/tracing/TraceApi18Impl;->endSection()V
return-void
.end method
.method public static forceEnableAppTracing()V
.locals 6
const-string v0, "setAppTracingAllowed"
sget v1, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v2, 0x1f
if-ge v1, v2, :cond_0
:try_start_0
sget-boolean v1, Landroidx/tracing/Trace;->sHasAppTracingEnabled:Z
if-nez v1, :cond_0
const/4 v1, 0x1
sput-boolean v1, Landroidx/tracing/Trace;->sHasAppTracingEnabled:Z
const-class v2, Landroid/os/Trace;
new-array v3, v1, [Ljava/lang/Class;
sget-object v4, Ljava/lang/Boolean;->TYPE:Ljava/lang/Class;
const/4 v5, 0x0
aput-object v4, v3, v5
.line 104
invoke-virtual {v2, v0, v3}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v2
new-array v1, v1, [Ljava/lang/Object;
sget-object v3, Ljava/lang/Boolean;->TRUE:Ljava/lang/Boolean;
aput-object v3, v1, v5
const/4 v3, 0x0
.line 108
invoke-virtual {v2, v3, v1}, 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
goto :goto_0
:catch_0
move-exception v1
.line 111
invoke-static {v0, v1}, Landroidx/tracing/Trace;->handleException(Ljava/lang/String;Ljava/lang/Exception;)V
:cond_0
:goto_0
return-void
.end method
.method private static handleException(Ljava/lang/String;Ljava/lang/Exception;)V
.locals 1
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.param p1 # Ljava/lang/Exception;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.line 293
instance-of v0, p1, Ljava/lang/reflect/InvocationTargetException;
if-eqz v0, :cond_1
.line 294
invoke-virtual {p1}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;
move-result-object p0
.line 295
instance-of p1, p0, Ljava/lang/RuntimeException;
if-eqz p1, :cond_0
.line 296
check-cast p0, Ljava/lang/RuntimeException;
throw p0
.line 298
:cond_0
new-instance p1, Ljava/lang/RuntimeException;
invoke-direct {p1, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
throw p1
.line 301
:cond_1
new-instance p1, Ljava/lang/StringBuilder;
invoke-direct {p1}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Unable to call "
invoke-virtual {p1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, " via reflection"
invoke-virtual {p1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
return-void
.end method
.method public static isEnabled()Z
.locals 2
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
.line 79
invoke-static {}, Landroidx/tracing/TraceApi29Impl;->isEnabled()Z
move-result v0
return v0
.line 81
:cond_0
invoke-static {}, Landroidx/tracing/Trace;->isEnabledFallback()Z
move-result v0
return v0
.end method
.method private static isEnabledFallback()Z
.locals 8
const-string v0, "isTagEnabled"
const-class v1, Landroid/os/Trace;
const/4 v2, 0x0
:try_start_0
sget-object v3, Landroidx/tracing/Trace;->sIsTagEnabledMethod:Ljava/lang/reflect/Method;
const/4 v4, 0x1
const/4 v5, 0x0
if-nez v3, :cond_0
const-string v3, "TRACE_TAG_APP"
.line 223
invoke-virtual {v1, v3}, Ljava/lang/Class;->getField(Ljava/lang/String;)Ljava/lang/reflect/Field;
move-result-object v3
.line 224
invoke-virtual {v3, v5}, Ljava/lang/reflect/Field;->getLong(Ljava/lang/Object;)J
move-result-wide v6
sput-wide v6, Landroidx/tracing/Trace;->sTraceTagApp:J
new-array v3, v4, [Ljava/lang/Class;
sget-object v6, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
aput-object v6, v3, v2
.line 226
invoke-virtual {v1, v0, v3}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v1
sput-object v1, Landroidx/tracing/Trace;->sIsTagEnabledMethod:Ljava/lang/reflect/Method;
goto :goto_0
:catch_0
move-exception v1
goto :goto_1
:cond_0
:goto_0
sget-object v1, Landroidx/tracing/Trace;->sIsTagEnabledMethod:Ljava/lang/reflect/Method;
new-array v3, v4, [Ljava/lang/Object;
sget-wide v6, Landroidx/tracing/Trace;->sTraceTagApp:J
.line 228
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v4
aput-object v4, v3, v2
invoke-virtual {v1, v5, v3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/lang/Boolean;
invoke-virtual {v1}, Ljava/lang/Boolean;->booleanValue()Z
move-result v0
:try_end_0
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0
return v0
.line 230
:goto_1
invoke-static {v0, v1}, Landroidx/tracing/Trace;->handleException(Ljava/lang/String;Ljava/lang/Exception;)V
return v2
.end method
.method public static setCounter(Ljava/lang/String;I)V
.locals 2
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
sget v0, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v1, 0x1d
if-lt v0, v1, :cond_0
.line 212
invoke-static {p0}, Landroidx/tracing/Trace;->truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0, p1}, Landroidx/tracing/TraceApi29Impl;->setCounter(Ljava/lang/String;I)V
goto :goto_0
.line 214
:cond_0
invoke-static {p0}, Landroidx/tracing/Trace;->truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
move-result-object p0
invoke-static {p0, p1}, Landroidx/tracing/Trace;->setCounterFallback(Ljava/lang/String;I)V
:goto_0
return-void
.end method
.method private static setCounterFallback(Ljava/lang/String;I)V
.locals 8
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
const-string v0, "traceCounter"
:try_start_0
sget-object v1, Landroidx/tracing/Trace;->sTraceCounterMethod:Ljava/lang/reflect/Method;
const/4 v2, 0x2
const/4 v3, 0x1
const/4 v4, 0x0
const/4 v5, 0x3
if-nez v1, :cond_0
const-class v1, Landroid/os/Trace;
new-array v6, v5, [Ljava/lang/Class;
sget-object v7, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
aput-object v7, v6, v4
const-class v7, Ljava/lang/String;
aput-object v7, v6, v3
sget-object v7, Ljava/lang/Integer;->TYPE:Ljava/lang/Class;
aput-object v7, v6, v2
.line 278
invoke-virtual {v1, v0, v6}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
move-result-object v1
sput-object v1, Landroidx/tracing/Trace;->sTraceCounterMethod:Ljava/lang/reflect/Method;
goto :goto_0
:catch_0
move-exception p0
goto :goto_1
:cond_0
:goto_0
sget-object v1, Landroidx/tracing/Trace;->sTraceCounterMethod:Ljava/lang/reflect/Method;
new-array v5, v5, [Ljava/lang/Object;
sget-wide v6, Landroidx/tracing/Trace;->sTraceTagApp:J
.line 285
invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v6
aput-object v6, v5, v4
aput-object p0, v5, v3
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object p0
aput-object p0, v5, v2
const/4 p0, 0x0
invoke-virtual {v1, p0, v5}, 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
goto :goto_2
.line 287
:goto_1
invoke-static {v0, p0}, Landroidx/tracing/Trace;->handleException(Ljava/lang/String;Ljava/lang/Exception;)V
:goto_2
return-void
.end method
.method private static truncatedTraceSectionLabel(Ljava/lang/String;)Ljava/lang/String;
.locals 2
.param p0 # Ljava/lang/String;
.annotation build Landroidx/annotation/NonNull;
.end annotation
.end param
.annotation build Landroidx/annotation/NonNull;
.end annotation
.line 306
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v0
const/16 v1, 0x7f
if-gt v0, v1, :cond_0
return-object p0
:cond_0
const/4 v0, 0x0
.line 309
invoke-virtual {p0, v0, v1}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object p0
return-object p0
.end method