.class public final Landroidx/core/os/TraceCompat; .super Ljava/lang/Object; .source "TraceCompat.java" # static fields .field public static final TAG:Ljava/lang/String; = "TraceCompat" .field public static sAsyncTraceBeginMethod:Ljava/lang/reflect/Method; .field public static sAsyncTraceEndMethod:Ljava/lang/reflect/Method; .field public static sIsTagEnabledMethod:Ljava/lang/reflect/Method; .field public static sTraceCounterMethod:Ljava/lang/reflect/Method; .field public static sTraceTagApp:J # direct methods .method public static constructor ()V .locals 9 const-class v0, Ljava/lang/String; sget v1, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v2, 0x1d if-ge v1, v2, :cond_0 :try_start_0 const-class v1, Landroid/os/Trace; const-string v2, "TRACE_TAG_APP" invoke-virtual {v1, v2}, Ljava/lang/Class;->getField(Ljava/lang/String;)Ljava/lang/reflect/Field; move-result-object v1 const/4 v2, 0x0 invoke-virtual {v1, v2}, Ljava/lang/reflect/Field;->getLong(Ljava/lang/Object;)J move-result-wide v1 sput-wide v1, Landroidx/core/os/TraceCompat;->sTraceTagApp:J const-class v1, Landroid/os/Trace; const-string v2, "isTagEnabled" const/4 v3, 0x1 new-array v4, v3, [Ljava/lang/Class; sget-object v5, Ljava/lang/Long;->TYPE:Ljava/lang/Class; const/4 v6, 0x0 aput-object v5, v4, v6 invoke-virtual {v1, v2, v4}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method; move-result-object v1 sput-object v1, Landroidx/core/os/TraceCompat;->sIsTagEnabledMethod:Ljava/lang/reflect/Method; const-class v1, Landroid/os/Trace; const-string v2, "asyncTraceBegin" const/4 v4, 0x3 new-array v5, v4, [Ljava/lang/Class; sget-object v7, Ljava/lang/Long;->TYPE:Ljava/lang/Class; aput-object v7, v5, v6 aput-object v0, v5, v3 sget-object v7, Ljava/lang/Integer;->TYPE:Ljava/lang/Class; const/4 v8, 0x2 aput-object v7, v5, v8 invoke-virtual {v1, v2, v5}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method; move-result-object v1 sput-object v1, Landroidx/core/os/TraceCompat;->sAsyncTraceBeginMethod:Ljava/lang/reflect/Method; const-class v1, Landroid/os/Trace; const-string v2, "asyncTraceEnd" new-array v5, v4, [Ljava/lang/Class; sget-object v7, Ljava/lang/Long;->TYPE:Ljava/lang/Class; aput-object v7, v5, v6 aput-object v0, v5, v3 sget-object v7, Ljava/lang/Integer;->TYPE:Ljava/lang/Class; aput-object v7, v5, v8 invoke-virtual {v1, v2, v5}, Ljava/lang/Class;->getMethod(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method; move-result-object v1 sput-object v1, Landroidx/core/os/TraceCompat;->sAsyncTraceEndMethod:Ljava/lang/reflect/Method; const-class v1, Landroid/os/Trace; const-string/jumbo v2, "traceCounter" new-array v4, v4, [Ljava/lang/Class; sget-object v5, Ljava/lang/Long;->TYPE:Ljava/lang/Class; aput-object v5, v4, v6 aput-object v0, v4, v3 sget-object v0, Ljava/lang/Integer;->TYPE:Ljava/lang/Class; aput-object v0, v4, v8 invoke-virtual {v1, v2, 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;->sTraceCounterMethod:Ljava/lang/reflect/Method; :try_end_0 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 :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 :goto_0 return-void .end method .method public constructor ()V .locals 0 invoke-direct {p0}, Ljava/lang/Object;->()V return-void .end method .method public static beginAsyncSection(Ljava/lang/String;I)V .locals 6 .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 invoke-static {p0, p1}, Landroid/os/Trace;->beginAsyncSection(Ljava/lang/String;I)V goto :goto_0 :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 goto :goto_0 :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 :goto_0 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 invoke-static {p0}, Landroid/os/Trace;->beginSection(Ljava/lang/String;)V return-void .end method .method public static endAsyncSection(Ljava/lang/String;I)V .locals 6 .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 invoke-static {p0, p1}, Landroid/os/Trace;->endAsyncSection(Ljava/lang/String;I)V goto :goto_0 :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 goto :goto_0 :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 :goto_0 return-void .end method .method public static endSection()V .locals 0 invoke-static {}, Landroid/os/Trace;->endSection()V return-void .end method .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 const/4 v0, 0x0 :try_start_0 sget-object v1, Landroidx/core/os/TraceCompat;->sIsTagEnabledMethod:Ljava/lang/reflect/Method; const/4 v2, 0x0 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 aput-object v4, v3, v0 invoke-virtual {v1, v2, 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 :catch_0 const-string v1, "TraceCompat" const-string v2, "Unable to invoke isTagEnabled() via reflection." invoke-static {v1, v2}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I return v0 .end method .method public static setCounter(Ljava/lang/String;I)V .locals 6 .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 int-to-long v0, p1 invoke-static {p0, v0, v1}, Landroid/os/Trace;->setCounter(Ljava/lang/String;J)V goto :goto_0 :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 goto :goto_0 :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 :goto_0 return-void .end method