.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 ()V .locals 0 .line 312 invoke-direct {p0}, Ljava/lang/Object;->()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;->(Ljava/lang/Throwable;)V throw p1 .line 301 :cond_1 new-instance p1, Ljava/lang/StringBuilder; invoke-direct {p1}, Ljava/lang/StringBuilder;->()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