597 lines
13 KiB
Smali
597 lines
13 KiB
Smali
.class public final Lg3/b;
|
|
.super Ljava/lang/Object;
|
|
.source "Trace.java"
|
|
|
|
|
|
# static fields
|
|
.field public static final a:Ljava/lang/String; = "Trace"
|
|
|
|
.field public static b:J
|
|
|
|
.field public static c:Ljava/lang/reflect/Method;
|
|
|
|
.field public static d:Ljava/lang/reflect/Method;
|
|
|
|
.field public static e:Ljava/lang/reflect/Method;
|
|
|
|
.field public static f:Ljava/lang/reflect/Method;
|
|
|
|
|
|
# direct methods
|
|
.method public constructor <init>()V
|
|
.locals 0
|
|
|
|
.line 1
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static a(Ljava/lang/String;I)V
|
|
.locals 1
|
|
.param p0 # Ljava/lang/String;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroid/annotation/SuppressLint;
|
|
value = {
|
|
"NewApi"
|
|
}
|
|
.end annotation
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v0, Lg3/b;->d:Ljava/lang/reflect/Method;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
.line 2
|
|
invoke-static {p0, p1}, Lg3/d;->a(Ljava/lang/String;I)V
|
|
:try_end_0
|
|
.catch Ljava/lang/NoSuchMethodError; {:try_start_0 .. :try_end_0} :catch_0
|
|
.catch Ljava/lang/NoClassDefFoundError; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
return-void
|
|
|
|
.line 3
|
|
:catch_0
|
|
:cond_0
|
|
invoke-static {p0, p1}, Lg3/b;->b(Ljava/lang/String;I)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static b(Ljava/lang/String;I)V
|
|
.locals 9
|
|
.param p0 # Ljava/lang/String;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
|
|
const-string v0, "asyncTraceBegin"
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v1, Lg3/b;->d: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
|
|
|
|
.line 2
|
|
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
|
|
|
|
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, Lg3/b;->d:Ljava/lang/reflect/Method;
|
|
|
|
.line 3
|
|
:cond_0
|
|
sget-object v1, Lg3/b;->d:Ljava/lang/reflect/Method;
|
|
|
|
const/4 v6, 0x0
|
|
|
|
new-array v5, v5, [Ljava/lang/Object;
|
|
|
|
sget-wide v7, Lg3/b;->b:J
|
|
|
|
invoke-static {v7, v8}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v7
|
|
|
|
aput-object v7, 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
|
|
|
|
invoke-virtual {v1, v6, 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_0
|
|
|
|
:catch_0
|
|
move-exception p0
|
|
|
|
.line 4
|
|
invoke-static {v0, p0}, Lg3/b;->g(Ljava/lang/String;Ljava/lang/Exception;)V
|
|
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
.method public static c(Ljava/lang/String;)V
|
|
.locals 0
|
|
.param p0 # Ljava/lang/String;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
|
|
.line 1
|
|
invoke-static {p0}, Lg3/c;->a(Ljava/lang/String;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static d(Ljava/lang/String;I)V
|
|
.locals 1
|
|
.param p0 # Ljava/lang/String;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroid/annotation/SuppressLint;
|
|
value = {
|
|
"NewApi"
|
|
}
|
|
.end annotation
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v0, Lg3/b;->e:Ljava/lang/reflect/Method;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
.line 2
|
|
invoke-static {p0, p1}, Lg3/d;->b(Ljava/lang/String;I)V
|
|
:try_end_0
|
|
.catch Ljava/lang/NoSuchMethodError; {:try_start_0 .. :try_end_0} :catch_0
|
|
.catch Ljava/lang/NoClassDefFoundError; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
return-void
|
|
|
|
.line 3
|
|
:catch_0
|
|
:cond_0
|
|
invoke-static {p0, p1}, Lg3/b;->e(Ljava/lang/String;I)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static e(Ljava/lang/String;I)V
|
|
.locals 9
|
|
.param p0 # Ljava/lang/String;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
|
|
const-string v0, "asyncTraceEnd"
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v1, Lg3/b;->e: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
|
|
|
|
.line 2
|
|
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
|
|
|
|
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, Lg3/b;->e:Ljava/lang/reflect/Method;
|
|
|
|
.line 3
|
|
:cond_0
|
|
sget-object v1, Lg3/b;->e:Ljava/lang/reflect/Method;
|
|
|
|
const/4 v6, 0x0
|
|
|
|
new-array v5, v5, [Ljava/lang/Object;
|
|
|
|
sget-wide v7, Lg3/b;->b:J
|
|
|
|
invoke-static {v7, v8}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v7
|
|
|
|
aput-object v7, 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
|
|
|
|
invoke-virtual {v1, v6, 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_0
|
|
|
|
:catch_0
|
|
move-exception p0
|
|
|
|
.line 4
|
|
invoke-static {v0, p0}, Lg3/b;->g(Ljava/lang/String;Ljava/lang/Exception;)V
|
|
|
|
:goto_0
|
|
return-void
|
|
.end method
|
|
|
|
.method public static f()V
|
|
.locals 0
|
|
|
|
.line 1
|
|
invoke-static {}, Lg3/c;->b()V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static g(Ljava/lang/String;Ljava/lang/Exception;)V
|
|
.locals 2
|
|
.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 1
|
|
instance-of v0, p1, Ljava/lang/reflect/InvocationTargetException;
|
|
|
|
if-eqz v0, :cond_1
|
|
|
|
.line 2
|
|
invoke-virtual {p1}, Ljava/lang/Exception;->getCause()Ljava/lang/Throwable;
|
|
|
|
move-result-object p0
|
|
|
|
.line 3
|
|
instance-of p1, p0, Ljava/lang/RuntimeException;
|
|
|
|
if-eqz p1, :cond_0
|
|
|
|
.line 4
|
|
check-cast p0, Ljava/lang/RuntimeException;
|
|
|
|
throw p0
|
|
|
|
.line 5
|
|
:cond_0
|
|
new-instance p1, Ljava/lang/RuntimeException;
|
|
|
|
invoke-direct {p1, p0}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/Throwable;)V
|
|
|
|
throw p1
|
|
|
|
.line 6
|
|
:cond_1
|
|
new-instance v0, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
|
|
|
|
const-string v1, "Unable to call "
|
|
|
|
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
const-string p0, " via reflection"
|
|
|
|
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object p0
|
|
|
|
const-string v0, "Trace"
|
|
|
|
invoke-static {v0, p0, p1}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static h()Z
|
|
.locals 1
|
|
.annotation build Landroid/annotation/SuppressLint;
|
|
value = {
|
|
"NewApi"
|
|
}
|
|
.end annotation
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v0, Lg3/b;->c:Ljava/lang/reflect/Method;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
.line 2
|
|
invoke-static {}, Landroid/os/Trace;->isEnabled()Z
|
|
|
|
move-result v0
|
|
:try_end_0
|
|
.catch Ljava/lang/NoSuchMethodError; {:try_start_0 .. :try_end_0} :catch_0
|
|
.catch Ljava/lang/NoClassDefFoundError; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
return v0
|
|
|
|
.line 3
|
|
:catch_0
|
|
:cond_0
|
|
invoke-static {}, Lg3/b;->i()Z
|
|
|
|
move-result v0
|
|
|
|
return v0
|
|
.end method
|
|
|
|
.method public static i()Z
|
|
.locals 7
|
|
|
|
const-string v0, "isTagEnabled"
|
|
|
|
const/4 v1, 0x0
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v2, Lg3/b;->c:Ljava/lang/reflect/Method;
|
|
|
|
const/4 v3, 0x1
|
|
|
|
const/4 v4, 0x0
|
|
|
|
if-nez v2, :cond_0
|
|
|
|
.line 2
|
|
const-class v2, Landroid/os/Trace;
|
|
|
|
const-string v5, "TRACE_TAG_APP"
|
|
|
|
invoke-virtual {v2, v5}, Ljava/lang/Class;->getField(Ljava/lang/String;)Ljava/lang/reflect/Field;
|
|
|
|
move-result-object v2
|
|
|
|
.line 3
|
|
invoke-virtual {v2, v4}, Ljava/lang/reflect/Field;->getLong(Ljava/lang/Object;)J
|
|
|
|
move-result-wide v5
|
|
|
|
sput-wide v5, Lg3/b;->b:J
|
|
|
|
.line 4
|
|
const-class v2, Landroid/os/Trace;
|
|
|
|
new-array v5, v3, [Ljava/lang/Class;
|
|
|
|
sget-object v6, Ljava/lang/Long;->TYPE:Ljava/lang/Class;
|
|
|
|
aput-object v6, v5, v1
|
|
|
|
.line 5
|
|
invoke-virtual {v2, v0, v5}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
|
|
|
|
move-result-object v2
|
|
|
|
sput-object v2, Lg3/b;->c:Ljava/lang/reflect/Method;
|
|
|
|
.line 6
|
|
:cond_0
|
|
sget-object v2, Lg3/b;->c:Ljava/lang/reflect/Method;
|
|
|
|
new-array v3, v3, [Ljava/lang/Object;
|
|
|
|
sget-wide v5, Lg3/b;->b:J
|
|
|
|
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v5
|
|
|
|
aput-object v5, v3, v1
|
|
|
|
invoke-virtual {v2, v4, v3}, Ljava/lang/reflect/Method;->invoke(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v2
|
|
|
|
check-cast v2, Ljava/lang/Boolean;
|
|
|
|
invoke-virtual {v2}, 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
|
|
|
|
:catch_0
|
|
move-exception v2
|
|
|
|
.line 7
|
|
invoke-static {v0, v2}, Lg3/b;->g(Ljava/lang/String;Ljava/lang/Exception;)V
|
|
|
|
return v1
|
|
.end method
|
|
|
|
.method public static j(Ljava/lang/String;I)V
|
|
.locals 1
|
|
.param p0 # Ljava/lang/String;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
.annotation build Landroid/annotation/SuppressLint;
|
|
value = {
|
|
"NewApi"
|
|
}
|
|
.end annotation
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v0, Lg3/b;->f:Ljava/lang/reflect/Method;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
.line 2
|
|
invoke-static {p0, p1}, Lg3/d;->c(Ljava/lang/String;I)V
|
|
:try_end_0
|
|
.catch Ljava/lang/NoSuchMethodError; {:try_start_0 .. :try_end_0} :catch_0
|
|
.catch Ljava/lang/NoClassDefFoundError; {:try_start_0 .. :try_end_0} :catch_0
|
|
|
|
return-void
|
|
|
|
.line 3
|
|
:catch_0
|
|
:cond_0
|
|
invoke-static {p0, p1}, Lg3/b;->k(Ljava/lang/String;I)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static k(Ljava/lang/String;I)V
|
|
.locals 9
|
|
.param p0 # Ljava/lang/String;
|
|
.annotation build Landroidx/annotation/NonNull;
|
|
.end annotation
|
|
.end param
|
|
|
|
const-string v0, "traceCounter"
|
|
|
|
.line 1
|
|
:try_start_0
|
|
sget-object v1, Lg3/b;->f: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
|
|
|
|
.line 2
|
|
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
|
|
|
|
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, Lg3/b;->f:Ljava/lang/reflect/Method;
|
|
|
|
.line 3
|
|
:cond_0
|
|
sget-object v1, Lg3/b;->f:Ljava/lang/reflect/Method;
|
|
|
|
const/4 v6, 0x0
|
|
|
|
new-array v5, v5, [Ljava/lang/Object;
|
|
|
|
sget-wide v7, Lg3/b;->b:J
|
|
|
|
invoke-static {v7, v8}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v7
|
|
|
|
aput-object v7, 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
|
|
|
|
invoke-virtual {v1, v6, 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_0
|
|
|
|
:catch_0
|
|
move-exception p0
|
|
|
|
.line 4
|
|
invoke-static {v0, p0}, Lg3/b;->g(Ljava/lang/String;Ljava/lang/Exception;)V
|
|
|
|
:goto_0
|
|
return-void
|
|
.end method
|