First Upload

Just the APK
Force update disabled, will only work offline.
This commit is contained in:
supermegamestre
2026-01-26 00:26:29 -03:00
commit 4bbd74a497
44413 changed files with 11043538 additions and 0 deletions

View File

@@ -0,0 +1,42 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda0;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# instance fields
.field public final synthetic f$0:Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
.field public final synthetic f$1:Lcom/google/firebase/perf/util/Timer;
# direct methods
.method public synthetic constructor <init>(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda0;->f$0:Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda0;->f$1:Lcom/google/firebase/perf/util/Timer;
return-void
.end method
# virtual methods
.method public final run()V
.locals 2
.line 0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda0;->f$0:Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda0;->f$1:Lcom/google/firebase/perf/util/Timer;
invoke-static {v0, v1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->$r8$lambda$p77EKzPdzJ7MbrcFX3THwssgjtg(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method

View File

@@ -0,0 +1,42 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda1;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# instance fields
.field public final synthetic f$0:Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
.field public final synthetic f$1:Lcom/google/firebase/perf/util/Timer;
# direct methods
.method public synthetic constructor <init>(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda1;->f$0:Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda1;->f$1:Lcom/google/firebase/perf/util/Timer;
return-void
.end method
# virtual methods
.method public final run()V
.locals 2
.line 0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda1;->f$0:Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda1;->f$1:Lcom/google/firebase/perf/util/Timer;
invoke-static {v0, v1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->$r8$lambda$g2KYXxcbOj044k0xx626FslioXI(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method

View File

@@ -0,0 +1,711 @@
.class public Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field public static final MICROSECONDS_PER_SECOND:J
.field public static final logger:Lcom/google/firebase/perf/logging/AndroidLogger;
# instance fields
.field public final clockTicksPerSecond:J
.field public cpuMetricCollectionRateMs:J
.field public final cpuMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.field public cpuMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
.field public final cpuMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
.field public final procFileName:Ljava/lang/String;
# direct methods
.method public static synthetic $r8$lambda$g2KYXxcbOj044k0xx626FslioXI(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->lambda$scheduleCpuMetricCollectionOnce$1(Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method public static synthetic $r8$lambda$p77EKzPdzJ7MbrcFX3THwssgjtg(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->lambda$scheduleCpuMetricCollectionWithRate$0(Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method static constructor <clinit>()V
.locals 3
.line 47
invoke-static {}, Lcom/google/firebase/perf/logging/AndroidLogger;->getInstance()Lcom/google/firebase/perf/logging/AndroidLogger;
move-result-object v0
sput-object v0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 73
sget-object v0, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v1, 0x1
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMicros(J)J
move-result-wide v0
sput-wide v0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->MICROSECONDS_PER_SECOND:J
return-void
.end method
.method public constructor <init>()V
.locals 3
.line 86
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
const-wide/16 v0, -0x1
iput-wide v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectionRateMs:J
.line 87
new-instance v0, Ljava/util/concurrent/ConcurrentLinkedQueue;
invoke-direct {v0}, Ljava/util/concurrent/ConcurrentLinkedQueue;-><init>()V
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
.line 88
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 90
invoke-static {}, Landroid/os/Process;->myPid()I
move-result v0
.line 91
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "/proc/"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {v0}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;
move-result-object v0
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v0, "/stat"
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->procFileName:Ljava/lang/String;
.line 93
invoke-virtual {p0}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->getClockTicksPerSecond()J
move-result-wide v0
iput-wide v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->clockTicksPerSecond:J
return-void
.end method
.method public static isInvalidCollectionFrequency(J)Z
.locals 2
const-wide/16 v0, 0x0
cmp-long p0, p0, v0
if-gtz p0, :cond_0
const/4 p0, 0x1
goto :goto_0
:cond_0
const/4 p0, 0x0
:goto_0
return p0
.end method
# virtual methods
.method public collectOnce(Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 156
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->scheduleCpuMetricCollectionOnce(Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method public final convertClockTicksToMicroseconds(J)J
.locals 2
long-to-double p1, p1
iget-wide v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->clockTicksPerSecond:J
long-to-double v0, v0
div-double/2addr p1, v0
sget-wide v0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->MICROSECONDS_PER_SECOND:J
long-to-double v0, v0
mul-double/2addr p1, v0
.line 239
invoke-static {p1, p2}, Ljava/lang/Math;->round(D)J
move-result-wide p1
return-wide p1
.end method
.method public final getClockTicksPerSecond()J
.locals 2
.line 231
sget v0, Landroid/system/OsConstants;->_SC_CLK_TCK:I
invoke-static {v0}, Landroid/system/Os;->sysconf(I)J
move-result-wide v0
return-wide v0
.end method
.method public final synthetic lambda$scheduleCpuMetricCollectionOnce$1(Lcom/google/firebase/perf/util/Timer;)V
.locals 1
.line 187
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->syncCollectCpuMetric(Lcom/google/firebase/perf/util/Timer;)Lcom/google/firebase/perf/v1/CpuMetricReading;
move-result-object p1
if-eqz p1, :cond_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
.line 189
invoke-virtual {v0, p1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->add(Ljava/lang/Object;)Z
:cond_0
return-void
.end method
.method public final synthetic lambda$scheduleCpuMetricCollectionWithRate$0(Lcom/google/firebase/perf/util/Timer;)V
.locals 1
.line 168
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->syncCollectCpuMetric(Lcom/google/firebase/perf/util/Timer;)Lcom/google/firebase/perf/v1/CpuMetricReading;
move-result-object p1
if-eqz p1, :cond_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
.line 170
invoke-virtual {v0, p1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->add(Ljava/lang/Object;)Z
:cond_0
return-void
.end method
.method public final declared-synchronized scheduleCpuMetricCollectionOnce(Lcom/google/firebase/perf/util/Timer;)V
.locals 4
monitor-enter p0
:try_start_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 184
new-instance v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda1;
invoke-direct {v1, p0, p1}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda1;-><init>(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
sget-object p1, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v2, 0x0
.line 185
invoke-interface {v0, v1, v2, v3, p1}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
:try_end_0
.catch Ljava/util/concurrent/RejectedExecutionException; {:try_start_0 .. :try_end_0} :catch_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_0
:catchall_0
move-exception p1
goto :goto_1
:catch_0
move-exception p1
:try_start_1
sget-object v0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 195
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Unable to collect Cpu Metric: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
.line 197
:goto_0
monitor-exit p0
return-void
:goto_1
monitor-exit p0
throw p1
.end method
.method public final declared-synchronized scheduleCpuMetricCollectionWithRate(JLcom/google/firebase/perf/util/Timer;)V
.locals 7
monitor-enter p0
:try_start_0
iput-wide p1, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectionRateMs:J
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
:try_start_1
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 165
new-instance v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda0;
invoke-direct {v1, p0, p3}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector$$ExternalSyntheticLambda0;-><init>(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
const-wide/16 v2, 0x0
sget-object v6, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
move-wide v4, p1
.line 166
invoke-interface/range {v0 .. v6}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object p1
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
:try_end_1
.catch Ljava/util/concurrent/RejectedExecutionException; {:try_start_1 .. :try_end_1} :catch_0
.catchall {:try_start_1 .. :try_end_1} :catchall_0
goto :goto_0
:catchall_0
move-exception p1
goto :goto_1
:catch_0
move-exception p1
:try_start_2
sget-object p2, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 177
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Unable to start collecting Cpu Metrics: "
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {p2, p1}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_0
.line 179
:goto_0
monitor-exit p0
return-void
:goto_1
monitor-exit p0
throw p1
.end method
.method public startCollecting(JLcom/google/firebase/perf/util/Timer;)V
.locals 4
iget-wide v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->clockTicksPerSecond:J
const-wide/16 v2, -0x1
cmp-long v2, v0, v2
if-eqz v2, :cond_4
const-wide/16 v2, 0x0
cmp-long v0, v0, v2
if-nez v0, :cond_0
goto :goto_0
.line 124
:cond_0
invoke-static {p1, p2}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->isInvalidCollectionFrequency(J)Z
move-result v0
if-eqz v0, :cond_1
return-void
:cond_1
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
if-eqz v0, :cond_3
iget-wide v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectionRateMs:J
cmp-long v0, v0, p1
if-eqz v0, :cond_2
.line 130
invoke-virtual {p0}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->stopCollecting()V
.line 131
invoke-virtual {p0, p1, p2, p3}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->scheduleCpuMetricCollectionWithRate(JLcom/google/firebase/perf/util/Timer;)V
:cond_2
return-void
.line 135
:cond_3
invoke-virtual {p0, p1, p2, p3}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->scheduleCpuMetricCollectionWithRate(JLcom/google/firebase/perf/util/Timer;)V
:cond_4
:goto_0
return-void
.end method
.method public stopCollecting()V
.locals 2
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
if-nez v0, :cond_0
return-void
:cond_0
const/4 v1, 0x0
.line 144
invoke-interface {v0, v1}, Ljava/util/concurrent/Future;->cancel(Z)Z
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
const-wide/16 v0, -0x1
iput-wide v0, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricCollectionRateMs:J
return-void
.end method
.method public final syncCollectCpuMetric(Lcom/google/firebase/perf/util/Timer;)Lcom/google/firebase/perf/v1/CpuMetricReading;
.locals 12
const/4 v0, 0x0
if-nez p1, :cond_0
return-object v0
.line 205
:cond_0
:try_start_0
new-instance v1, Ljava/io/BufferedReader;
new-instance v2, Ljava/io/FileReader;
iget-object v3, p0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->procFileName:Ljava/lang/String;
invoke-direct {v2, v3}, Ljava/io/FileReader;-><init>(Ljava/lang/String;)V
invoke-direct {v1, v2}, Ljava/io/BufferedReader;-><init>(Ljava/io/Reader;)V
:try_end_0
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_0} :catch_3
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_0 .. :try_end_0} :catch_2
.catch Ljava/lang/NumberFormatException; {:try_start_0 .. :try_end_0} :catch_1
.catch Ljava/lang/NullPointerException; {:try_start_0 .. :try_end_0} :catch_0
.line 206
:try_start_1
invoke-virtual {p1}, Lcom/google/firebase/perf/util/Timer;->getCurrentTimestampMicros()J
move-result-wide v2
.line 207
invoke-virtual {v1}, Ljava/io/BufferedReader;->readLine()Ljava/lang/String;
move-result-object p1
const-string v4, " "
.line 208
invoke-virtual {p1, v4}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object p1
const/16 v4, 0xd
.line 210
aget-object v4, p1, v4
invoke-static {v4}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v4
const/16 v6, 0xf
.line 211
aget-object v6, p1, v6
invoke-static {v6}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v6
const/16 v8, 0xe
.line 213
aget-object v8, p1, v8
invoke-static {v8}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v8
const/16 v10, 0x10
.line 214
aget-object p1, p1, v10
invoke-static {p1}, Ljava/lang/Long;->parseLong(Ljava/lang/String;)J
move-result-wide v10
.line 216
invoke-static {}, Lcom/google/firebase/perf/v1/CpuMetricReading;->newBuilder()Lcom/google/firebase/perf/v1/CpuMetricReading$Builder;
move-result-object p1
.line 217
invoke-virtual {p1, v2, v3}, Lcom/google/firebase/perf/v1/CpuMetricReading$Builder;->setClientTimeUs(J)Lcom/google/firebase/perf/v1/CpuMetricReading$Builder;
move-result-object p1
add-long/2addr v8, v10
.line 218
invoke-virtual {p0, v8, v9}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->convertClockTicksToMicroseconds(J)J
move-result-wide v2
invoke-virtual {p1, v2, v3}, Lcom/google/firebase/perf/v1/CpuMetricReading$Builder;->setSystemTimeUs(J)Lcom/google/firebase/perf/v1/CpuMetricReading$Builder;
move-result-object p1
add-long/2addr v4, v6
.line 219
invoke-virtual {p0, v4, v5}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->convertClockTicksToMicroseconds(J)J
move-result-wide v2
invoke-virtual {p1, v2, v3}, Lcom/google/firebase/perf/v1/CpuMetricReading$Builder;->setUserTimeUs(J)Lcom/google/firebase/perf/v1/CpuMetricReading$Builder;
move-result-object p1
.line 220
invoke-virtual {p1}, Lcom/google/protobuf/GeneratedMessageLite$Builder;->build()Lcom/google/protobuf/GeneratedMessageLite;
move-result-object p1
check-cast p1, Lcom/google/firebase/perf/v1/CpuMetricReading;
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
.line 221
:try_start_2
invoke-virtual {v1}, Ljava/io/BufferedReader;->close()V
:try_end_2
.catch Ljava/io/IOException; {:try_start_2 .. :try_end_2} :catch_3
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_2 .. :try_end_2} :catch_2
.catch Ljava/lang/NumberFormatException; {:try_start_2 .. :try_end_2} :catch_1
.catch Ljava/lang/NullPointerException; {:try_start_2 .. :try_end_2} :catch_0
return-object p1
:catch_0
move-exception p1
goto :goto_1
:catch_1
move-exception p1
goto :goto_1
:catch_2
move-exception p1
goto :goto_1
:catch_3
move-exception p1
goto :goto_2
:catchall_0
move-exception p1
.line 205
:try_start_3
invoke-virtual {v1}, Ljava/io/BufferedReader;->close()V
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_1
goto :goto_0
:catchall_1
move-exception v1
:try_start_4
invoke-virtual {p1, v1}, Ljava/lang/Throwable;->addSuppressed(Ljava/lang/Throwable;)V
:goto_0
throw p1
:try_end_4
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_4} :catch_3
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_4 .. :try_end_4} :catch_2
.catch Ljava/lang/NumberFormatException; {:try_start_4 .. :try_end_4} :catch_1
.catch Ljava/lang/NullPointerException; {:try_start_4 .. :try_end_4} :catch_0
:goto_1
sget-object v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 224
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Unexpected \'/proc/[pid]/stat\' file format encountered: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
goto :goto_3
:goto_2
sget-object v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 222
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "Unable to read \'proc/[pid]/stat\' file: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
:goto_3
return-object v0
.end method

View File

@@ -0,0 +1,48 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# instance fields
.field public final synthetic f$0:Lcom/google/firebase/perf/session/gauges/GaugeManager;
.field public final synthetic f$1:Ljava/lang/String;
.field public final synthetic f$2:Lcom/google/firebase/perf/v1/ApplicationProcessState;
# direct methods
.method public synthetic constructor <init>(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 0
.line 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;->f$0:Lcom/google/firebase/perf/session/gauges/GaugeManager;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;->f$1:Ljava/lang/String;
iput-object p3, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;->f$2:Lcom/google/firebase/perf/v1/ApplicationProcessState;
return-void
.end method
# virtual methods
.method public final run()V
.locals 3
.line 0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;->f$0:Lcom/google/firebase/perf/session/gauges/GaugeManager;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;->f$1:Ljava/lang/String;
iget-object v2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;->f$2:Lcom/google/firebase/perf/v1/ApplicationProcessState;
invoke-static {v0, v1, v2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->$r8$lambda$fzBB10FJVt-tkjrkengAYFtEKSs(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
return-void
.end method

View File

@@ -0,0 +1,48 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# instance fields
.field public final synthetic f$0:Lcom/google/firebase/perf/session/gauges/GaugeManager;
.field public final synthetic f$1:Ljava/lang/String;
.field public final synthetic f$2:Lcom/google/firebase/perf/v1/ApplicationProcessState;
# direct methods
.method public synthetic constructor <init>(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 0
.line 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;->f$0:Lcom/google/firebase/perf/session/gauges/GaugeManager;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;->f$1:Ljava/lang/String;
iput-object p3, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;->f$2:Lcom/google/firebase/perf/v1/ApplicationProcessState;
return-void
.end method
# virtual methods
.method public final run()V
.locals 3
.line 0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;->f$0:Lcom/google/firebase/perf/session/gauges/GaugeManager;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;->f$1:Ljava/lang/String;
iget-object v2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;->f$2:Lcom/google/firebase/perf/v1/ApplicationProcessState;
invoke-static {v0, v1, v2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->$r8$lambda$J9Kmau4s0cy_l-ud1Mrra7n0nXo(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
return-void
.end method

View File

@@ -0,0 +1,29 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda2;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/google/firebase/inject/Provider;
# direct methods
.method public synthetic constructor <init>()V
.locals 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public final get()Ljava/lang/Object;
.locals 1
.line 0
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
return-object v0
.end method

View File

@@ -0,0 +1,29 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda3;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/google/firebase/inject/Provider;
# direct methods
.method public synthetic constructor <init>()V
.locals 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public final get()Ljava/lang/Object;
.locals 1
.line 0
invoke-static {}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->$r8$lambda$4sn4weVQp3_rzSjqFWINTztsOPE()Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
move-result-object v0
return-object v0
.end method

View File

@@ -0,0 +1,29 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda4;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/google/firebase/inject/Provider;
# direct methods
.method public synthetic constructor <init>()V
.locals 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public final get()Ljava/lang/Object;
.locals 1
.line 0
invoke-static {}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->$r8$lambda$CVeqxoaaNuh325PscFQO7837kDg()Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
move-result-object v0
return-object v0
.end method

View File

@@ -0,0 +1,67 @@
.class public abstract synthetic Lcom/google/firebase/perf/session/gauges/GaugeManager$1;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/google/firebase/perf/session/gauges/GaugeManager;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x1009
name = null
.end annotation
# static fields
.field public static final synthetic $SwitchMap$com$google$firebase$perf$v1$ApplicationProcessState:[I
# direct methods
.method static constructor <clinit>()V
.locals 3
.line 355
invoke-static {}, Lcom/google/firebase/perf/v1/ApplicationProcessState;->values()[Lcom/google/firebase/perf/v1/ApplicationProcessState;
move-result-object v0
array-length v0, v0
new-array v0, v0, [I
sput-object v0, Lcom/google/firebase/perf/session/gauges/GaugeManager$1;->$SwitchMap$com$google$firebase$perf$v1$ApplicationProcessState:[I
:try_start_0
sget-object v1, Lcom/google/firebase/perf/v1/ApplicationProcessState;->BACKGROUND:Lcom/google/firebase/perf/v1/ApplicationProcessState;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x1
aput v2, v0, v1
:try_end_0
.catch Ljava/lang/NoSuchFieldError; {:try_start_0 .. :try_end_0} :catch_0
:catch_0
:try_start_1
sget-object v0, Lcom/google/firebase/perf/session/gauges/GaugeManager$1;->$SwitchMap$com$google$firebase$perf$v1$ApplicationProcessState:[I
sget-object v1, Lcom/google/firebase/perf/v1/ApplicationProcessState;->FOREGROUND:Lcom/google/firebase/perf/v1/ApplicationProcessState;
invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I
move-result v1
const/4 v2, 0x2
aput v2, v0, v1
:try_end_1
.catch Ljava/lang/NoSuchFieldError; {:try_start_1 .. :try_end_1} :catch_1
:catch_1
return-void
.end method

View File

@@ -0,0 +1,984 @@
.class public Lcom/google/firebase/perf/session/gauges/GaugeManager;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation build Landroidx/annotation/Keep;
.end annotation
# static fields
.field private static final APPROX_NUMBER_OF_DATA_POINTS_PER_GAUGE_METRIC:J = 0x14L
.field private static final INVALID_GAUGE_COLLECTION_FREQUENCY:J = -0x1L
.field private static final TIME_TO_WAIT_BEFORE_FLUSHING_GAUGES_QUEUE_MS:J = 0x14L
.field private static final instance:Lcom/google/firebase/perf/session/gauges/GaugeManager;
.field private static final logger:Lcom/google/firebase/perf/logging/AndroidLogger;
# instance fields
.field private applicationProcessState:Lcom/google/firebase/perf/v1/ApplicationProcessState;
.field private final configResolver:Lcom/google/firebase/perf/config/ConfigResolver;
.field private final cpuGaugeCollector:Lcom/google/firebase/components/Lazy;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/firebase/components/Lazy;"
}
.end annotation
.end field
.field private gaugeManagerDataCollectionJob:Ljava/util/concurrent/ScheduledFuture;
.annotation build Landroidx/annotation/Nullable;
.end annotation
.end field
.field private final gaugeManagerExecutor:Lcom/google/firebase/components/Lazy;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/firebase/components/Lazy;"
}
.end annotation
.end field
.field private gaugeMetadataManager:Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
.annotation build Landroidx/annotation/Nullable;
.end annotation
.end field
.field private final memoryGaugeCollector:Lcom/google/firebase/components/Lazy;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/firebase/components/Lazy;"
}
.end annotation
.end field
.field private sessionId:Ljava/lang/String;
.annotation build Landroidx/annotation/Nullable;
.end annotation
.end field
.field private final transportManager:Lcom/google/firebase/perf/transport/TransportManager;
# direct methods
.method public static synthetic $r8$lambda$4sn4weVQp3_rzSjqFWINTztsOPE()Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
.locals 1
.line 0
invoke-static {}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->lambda$new$0()Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
move-result-object v0
return-object v0
.end method
.method public static synthetic $r8$lambda$CVeqxoaaNuh325PscFQO7837kDg()Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
.locals 1
.line 0
invoke-static {}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->lambda$new$1()Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
move-result-object v0
return-object v0
.end method
.method public static synthetic $r8$lambda$J9Kmau4s0cy_l-ud1Mrra7n0nXo(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 0
.line 0
invoke-direct {p0, p1, p2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->lambda$startCollectingGauges$2(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
return-void
.end method
.method public static synthetic $r8$lambda$fzBB10FJVt-tkjrkengAYFtEKSs(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 0
.line 0
invoke-direct {p0, p1, p2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->lambda$stopCollectingGauges$3(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
return-void
.end method
.method static constructor <clinit>()V
.locals 1
.line 46
invoke-static {}, Lcom/google/firebase/perf/logging/AndroidLogger;->getInstance()Lcom/google/firebase/perf/logging/AndroidLogger;
move-result-object v0
sput-object v0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 47
new-instance v0, Lcom/google/firebase/perf/session/gauges/GaugeManager;
invoke-direct {v0}, Lcom/google/firebase/perf/session/gauges/GaugeManager;-><init>()V
sput-object v0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->instance:Lcom/google/firebase/perf/session/gauges/GaugeManager;
return-void
.end method
.method private constructor <init>()V
.locals 7
.annotation build Landroid/annotation/SuppressLint;
value = {
"ThreadPoolCreation"
}
.end annotation
.line 70
new-instance v1, Lcom/google/firebase/components/Lazy;
new-instance v0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda2;
invoke-direct {v0}, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda2;-><init>()V
invoke-direct {v1, v0}, Lcom/google/firebase/components/Lazy;-><init>(Lcom/google/firebase/inject/Provider;)V
.line 72
invoke-static {}, Lcom/google/firebase/perf/transport/TransportManager;->getInstance()Lcom/google/firebase/perf/transport/TransportManager;
move-result-object v2
.line 73
invoke-static {}, Lcom/google/firebase/perf/config/ConfigResolver;->getInstance()Lcom/google/firebase/perf/config/ConfigResolver;
move-result-object v3
const/4 v4, 0x0
new-instance v5, Lcom/google/firebase/components/Lazy;
new-instance v0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda3;
invoke-direct {v0}, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda3;-><init>()V
invoke-direct {v5, v0}, Lcom/google/firebase/components/Lazy;-><init>(Lcom/google/firebase/inject/Provider;)V
new-instance v6, Lcom/google/firebase/components/Lazy;
new-instance v0, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda4;
invoke-direct {v0}, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda4;-><init>()V
invoke-direct {v6, v0}, Lcom/google/firebase/components/Lazy;-><init>(Lcom/google/firebase/inject/Provider;)V
move-object v0, p0
.line 70
invoke-direct/range {v0 .. v6}, Lcom/google/firebase/perf/session/gauges/GaugeManager;-><init>(Lcom/google/firebase/components/Lazy;Lcom/google/firebase/perf/transport/TransportManager;Lcom/google/firebase/perf/config/ConfigResolver;Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;Lcom/google/firebase/components/Lazy;Lcom/google/firebase/components/Lazy;)V
return-void
.end method
.method public constructor <init>(Lcom/google/firebase/components/Lazy;Lcom/google/firebase/perf/transport/TransportManager;Lcom/google/firebase/perf/config/ConfigResolver;Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;Lcom/google/firebase/components/Lazy;Lcom/google/firebase/components/Lazy;)V
.locals 1
.annotation build Landroidx/annotation/VisibleForTesting;
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/google/firebase/components/Lazy;",
"Lcom/google/firebase/perf/transport/TransportManager;",
"Lcom/google/firebase/perf/config/ConfigResolver;",
"Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;",
"Lcom/google/firebase/components/Lazy;",
"Lcom/google/firebase/components/Lazy;",
")V"
}
.end annotation
.line 86
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeManagerDataCollectionJob:Ljava/util/concurrent/ScheduledFuture;
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->sessionId:Ljava/lang/String;
.line 64
sget-object v0, Lcom/google/firebase/perf/v1/ApplicationProcessState;->APPLICATION_PROCESS_STATE_UNKNOWN:Lcom/google/firebase/perf/v1/ApplicationProcessState;
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->applicationProcessState:Lcom/google/firebase/perf/v1/ApplicationProcessState;
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeManagerExecutor:Lcom/google/firebase/components/Lazy;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->transportManager:Lcom/google/firebase/perf/transport/TransportManager;
iput-object p3, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->configResolver:Lcom/google/firebase/perf/config/ConfigResolver;
iput-object p4, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeMetadataManager:Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
iput-object p5, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->cpuGaugeCollector:Lcom/google/firebase/components/Lazy;
iput-object p6, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->memoryGaugeCollector:Lcom/google/firebase/components/Lazy;
return-void
.end method
.method private static collectGaugeMetricOnce(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 340
invoke-virtual {p0, p2}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->collectOnce(Lcom/google/firebase/perf/util/Timer;)V
.line 341
invoke-virtual {p1, p2}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->collectOnce(Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method private getCpuGaugeCollectionFrequencyMs(Lcom/google/firebase/perf/v1/ApplicationProcessState;)J
.locals 5
.line 355
sget-object v0, Lcom/google/firebase/perf/session/gauges/GaugeManager$1;->$SwitchMap$com$google$firebase$perf$v1$ApplicationProcessState:[I
invoke-virtual {p1}, Ljava/lang/Enum;->ordinal()I
move-result p1
aget p1, v0, p1
const/4 v0, 0x1
const-wide/16 v1, -0x1
if-eq p1, v0, :cond_1
const/4 v0, 0x2
if-eq p1, v0, :cond_0
move-wide v3, v1
goto :goto_0
:cond_0
iget-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->configResolver:Lcom/google/firebase/perf/config/ConfigResolver;
.line 360
invoke-virtual {p1}, Lcom/google/firebase/perf/config/ConfigResolver;->getSessionsCpuCaptureFrequencyForegroundMs()J
move-result-wide v3
goto :goto_0
:cond_1
iget-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->configResolver:Lcom/google/firebase/perf/config/ConfigResolver;
.line 357
invoke-virtual {p1}, Lcom/google/firebase/perf/config/ConfigResolver;->getSessionsCpuCaptureFrequencyBackgroundMs()J
move-result-wide v3
.line 366
:goto_0
invoke-static {v3, v4}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->isInvalidCollectionFrequency(J)Z
move-result p1
if-eqz p1, :cond_2
return-wide v1
:cond_2
return-wide v3
.end method
.method private getGaugeMetadata()Lcom/google/firebase/perf/v1/GaugeMetadata;
.locals 2
.line 272
invoke-static {}, Lcom/google/firebase/perf/v1/GaugeMetadata;->newBuilder()Lcom/google/firebase/perf/v1/GaugeMetadata$Builder;
move-result-object v0
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeMetadataManager:Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
.line 273
invoke-virtual {v1}, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->getDeviceRamSizeKb()I
move-result v1
invoke-virtual {v0, v1}, Lcom/google/firebase/perf/v1/GaugeMetadata$Builder;->setDeviceRamSizeKb(I)Lcom/google/firebase/perf/v1/GaugeMetadata$Builder;
move-result-object v0
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeMetadataManager:Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
.line 274
invoke-virtual {v1}, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->getMaxAppJavaHeapMemoryKb()I
move-result v1
invoke-virtual {v0, v1}, Lcom/google/firebase/perf/v1/GaugeMetadata$Builder;->setMaxAppJavaHeapMemoryKb(I)Lcom/google/firebase/perf/v1/GaugeMetadata$Builder;
move-result-object v0
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeMetadataManager:Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
.line 276
invoke-virtual {v1}, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->getMaxEncouragedAppJavaHeapMemoryKb()I
move-result v1
.line 275
invoke-virtual {v0, v1}, Lcom/google/firebase/perf/v1/GaugeMetadata$Builder;->setMaxEncouragedAppJavaHeapMemoryKb(I)Lcom/google/firebase/perf/v1/GaugeMetadata$Builder;
move-result-object v0
.line 277
invoke-virtual {v0}, Lcom/google/protobuf/GeneratedMessageLite$Builder;->build()Lcom/google/protobuf/GeneratedMessageLite;
move-result-object v0
check-cast v0, Lcom/google/firebase/perf/v1/GaugeMetadata;
return-object v0
.end method
.method public static declared-synchronized getInstance()Lcom/google/firebase/perf/session/gauges/GaugeManager;
.locals 2
const-class v0, Lcom/google/firebase/perf/session/gauges/GaugeManager;
monitor-enter v0
:try_start_0
sget-object v1, Lcom/google/firebase/perf/session/gauges/GaugeManager;->instance:Lcom/google/firebase/perf/session/gauges/GaugeManager;
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
.line 103
monitor-exit v0
return-object v1
:catchall_0
move-exception v1
monitor-exit v0
throw v1
.end method
.method private getMemoryGaugeCollectionFrequencyMs(Lcom/google/firebase/perf/v1/ApplicationProcessState;)J
.locals 5
.line 386
sget-object v0, Lcom/google/firebase/perf/session/gauges/GaugeManager$1;->$SwitchMap$com$google$firebase$perf$v1$ApplicationProcessState:[I
invoke-virtual {p1}, Ljava/lang/Enum;->ordinal()I
move-result p1
aget p1, v0, p1
const/4 v0, 0x1
const-wide/16 v1, -0x1
if-eq p1, v0, :cond_1
const/4 v0, 0x2
if-eq p1, v0, :cond_0
move-wide v3, v1
goto :goto_0
:cond_0
iget-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->configResolver:Lcom/google/firebase/perf/config/ConfigResolver;
.line 393
invoke-virtual {p1}, Lcom/google/firebase/perf/config/ConfigResolver;->getSessionsMemoryCaptureFrequencyForegroundMs()J
move-result-wide v3
goto :goto_0
:cond_1
iget-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->configResolver:Lcom/google/firebase/perf/config/ConfigResolver;
.line 389
invoke-virtual {p1}, Lcom/google/firebase/perf/config/ConfigResolver;->getSessionsMemoryCaptureFrequencyBackgroundMs()J
move-result-wide v3
.line 399
:goto_0
invoke-static {v3, v4}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->isInvalidCollectionFrequency(J)Z
move-result p1
if-eqz p1, :cond_2
return-wide v1
:cond_2
return-wide v3
.end method
.method private static synthetic lambda$new$0()Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
.locals 1
.line 75
new-instance v0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
invoke-direct {v0}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;-><init>()V
return-object v0
.end method
.method private static synthetic lambda$new$1()Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
.locals 1
.line 76
new-instance v0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
invoke-direct {v0}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;-><init>()V
return-object v0
.end method
.method private synthetic lambda$startCollectingGauges$2(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 0
.line 145
invoke-direct {p0, p1, p2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->syncFlush(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
return-void
.end method
.method private synthetic lambda$stopCollectingGauges$3(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 0
.line 214
invoke-direct {p0, p1, p2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->syncFlush(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
return-void
.end method
.method private startCollectingCpuMetrics(JLcom/google/firebase/perf/util/Timer;)Z
.locals 2
const-wide/16 v0, -0x1
cmp-long v0, p1, v0
if-nez v0, :cond_0
sget-object p1, Lcom/google/firebase/perf/session/gauges/GaugeManager;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
const-string p2, "Invalid Cpu Metrics collection frequency. Did not collect Cpu Metrics."
.line 292
invoke-virtual {p1, p2}, Lcom/google/firebase/perf/logging/AndroidLogger;->debug(Ljava/lang/String;)V
const/4 p1, 0x0
return p1
:cond_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->cpuGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 296
invoke-virtual {v0}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
invoke-virtual {v0, p1, p2, p3}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->startCollecting(JLcom/google/firebase/perf/util/Timer;)V
const/4 p1, 0x1
return p1
.end method
.method private startCollectingGauges(Lcom/google/firebase/perf/v1/ApplicationProcessState;Lcom/google/firebase/perf/util/Timer;)J
.locals 7
.line 169
invoke-direct {p0, p1}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->getCpuGaugeCollectionFrequencyMs(Lcom/google/firebase/perf/v1/ApplicationProcessState;)J
move-result-wide v0
.line 170
invoke-direct {p0, v0, v1, p2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->startCollectingCpuMetrics(JLcom/google/firebase/perf/util/Timer;)Z
move-result v2
const-wide/16 v3, -0x1
if-eqz v2, :cond_0
goto :goto_0
:cond_0
move-wide v0, v3
.line 174
:goto_0
invoke-direct {p0, p1}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->getMemoryGaugeCollectionFrequencyMs(Lcom/google/firebase/perf/v1/ApplicationProcessState;)J
move-result-wide v5
.line 175
invoke-direct {p0, v5, v6, p2}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->startCollectingMemoryMetrics(JLcom/google/firebase/perf/util/Timer;)Z
move-result p1
if-eqz p1, :cond_2
cmp-long p1, v0, v3
if-nez p1, :cond_1
move-wide v0, v5
goto :goto_1
.line 179
:cond_1
invoke-static {v0, v1, v5, v6}, Ljava/lang/Math;->min(JJ)J
move-result-wide p1
move-wide v0, p1
:cond_2
:goto_1
return-wide v0
.end method
.method private startCollectingMemoryMetrics(JLcom/google/firebase/perf/util/Timer;)Z
.locals 2
const-wide/16 v0, -0x1
cmp-long v0, p1, v0
if-nez v0, :cond_0
sget-object p1, Lcom/google/firebase/perf/session/gauges/GaugeManager;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
const-string p2, "Invalid Memory Metrics collection frequency. Did not collect Memory Metrics."
.line 313
invoke-virtual {p1, p2}, Lcom/google/firebase/perf/logging/AndroidLogger;->debug(Ljava/lang/String;)V
const/4 p1, 0x0
return p1
:cond_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->memoryGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 317
invoke-virtual {v0}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
invoke-virtual {v0, p1, p2, p3}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->startCollecting(JLcom/google/firebase/perf/util/Timer;)V
const/4 p1, 0x1
return p1
.end method
.method private syncFlush(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 2
.line 231
invoke-static {}, Lcom/google/firebase/perf/v1/GaugeMetric;->newBuilder()Lcom/google/firebase/perf/v1/GaugeMetric$Builder;
move-result-object v0
:goto_0
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->cpuGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 234
invoke-virtual {v1}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
iget-object v1, v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
invoke-virtual {v1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->isEmpty()Z
move-result v1
if-nez v1, :cond_0
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->cpuGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 235
invoke-virtual {v1}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
iget-object v1, v1, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->cpuMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
invoke-virtual {v1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->poll()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/firebase/perf/v1/CpuMetricReading;
invoke-virtual {v0, v1}, Lcom/google/firebase/perf/v1/GaugeMetric$Builder;->addCpuMetricReadings(Lcom/google/firebase/perf/v1/CpuMetricReading;)Lcom/google/firebase/perf/v1/GaugeMetric$Builder;
goto :goto_0
:cond_0
:goto_1
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->memoryGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 239
invoke-virtual {v1}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
iget-object v1, v1, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
invoke-virtual {v1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->isEmpty()Z
move-result v1
if-nez v1, :cond_1
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->memoryGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 241
invoke-virtual {v1}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
iget-object v1, v1, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
invoke-virtual {v1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->poll()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/firebase/perf/v1/AndroidMemoryReading;
.line 240
invoke-virtual {v0, v1}, Lcom/google/firebase/perf/v1/GaugeMetric$Builder;->addAndroidMemoryReadings(Lcom/google/firebase/perf/v1/AndroidMemoryReading;)Lcom/google/firebase/perf/v1/GaugeMetric$Builder;
goto :goto_1
.line 245
:cond_1
invoke-virtual {v0, p1}, Lcom/google/firebase/perf/v1/GaugeMetric$Builder;->setSessionId(Ljava/lang/String;)Lcom/google/firebase/perf/v1/GaugeMetric$Builder;
iget-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->transportManager:Lcom/google/firebase/perf/transport/TransportManager;
.line 247
invoke-virtual {v0}, Lcom/google/protobuf/GeneratedMessageLite$Builder;->build()Lcom/google/protobuf/GeneratedMessageLite;
move-result-object v0
check-cast v0, Lcom/google/firebase/perf/v1/GaugeMetric;
invoke-virtual {p1, v0, p2}, Lcom/google/firebase/perf/transport/TransportManager;->log(Lcom/google/firebase/perf/v1/GaugeMetric;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
return-void
.end method
# virtual methods
.method public collectGaugeMetricOnce(Lcom/google/firebase/perf/util/Timer;)V
.locals 2
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->cpuGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 332
invoke-virtual {v0}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->memoryGaugeCollector:Lcom/google/firebase/components/Lazy;
invoke-virtual {v1}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
invoke-static {v0, v1, p1}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->collectGaugeMetricOnce(Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method public initializeGaugeMetadataManager(Landroid/content/Context;)V
.locals 1
.line 98
new-instance v0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
invoke-direct {v0, p1}, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;-><init>(Landroid/content/Context;)V
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeMetadataManager:Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
return-void
.end method
.method public logGaugeMetadata(Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)Z
.locals 1
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeMetadataManager:Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
if-eqz v0, :cond_0
.line 261
invoke-static {}, Lcom/google/firebase/perf/v1/GaugeMetric;->newBuilder()Lcom/google/firebase/perf/v1/GaugeMetric$Builder;
move-result-object v0
.line 262
invoke-virtual {v0, p1}, Lcom/google/firebase/perf/v1/GaugeMetric$Builder;->setSessionId(Ljava/lang/String;)Lcom/google/firebase/perf/v1/GaugeMetric$Builder;
move-result-object p1
.line 263
invoke-direct {p0}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->getGaugeMetadata()Lcom/google/firebase/perf/v1/GaugeMetadata;
move-result-object v0
invoke-virtual {p1, v0}, Lcom/google/firebase/perf/v1/GaugeMetric$Builder;->setGaugeMetadata(Lcom/google/firebase/perf/v1/GaugeMetadata;)Lcom/google/firebase/perf/v1/GaugeMetric$Builder;
move-result-object p1
.line 264
invoke-virtual {p1}, Lcom/google/protobuf/GeneratedMessageLite$Builder;->build()Lcom/google/protobuf/GeneratedMessageLite;
move-result-object p1
check-cast p1, Lcom/google/firebase/perf/v1/GaugeMetric;
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->transportManager:Lcom/google/firebase/perf/transport/TransportManager;
.line 265
invoke-virtual {v0, p1, p2}, Lcom/google/firebase/perf/transport/TransportManager;->log(Lcom/google/firebase/perf/v1/GaugeMetric;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
const/4 p1, 0x1
return p1
:cond_0
const/4 p1, 0x0
return p1
.end method
.method public startCollectingGauges(Lcom/google/firebase/perf/session/PerfSession;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
.locals 10
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->sessionId:Ljava/lang/String;
if-eqz v0, :cond_0
.line 123
invoke-virtual {p0}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->stopCollectingGauges()V
.line 126
:cond_0
invoke-virtual {p1}, Lcom/google/firebase/perf/session/PerfSession;->getTimer()Lcom/google/firebase/perf/util/Timer;
move-result-object v0
invoke-direct {p0, p2, v0}, Lcom/google/firebase/perf/session/gauges/GaugeManager;->startCollectingGauges(Lcom/google/firebase/perf/v1/ApplicationProcessState;Lcom/google/firebase/perf/util/Timer;)J
move-result-wide v0
const-wide/16 v2, -0x1
cmp-long v2, v0, v2
if-nez v2, :cond_1
sget-object p1, Lcom/google/firebase/perf/session/gauges/GaugeManager;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
const-string p2, "Invalid gauge collection frequency. Unable to start collecting Gauges."
.line 128
invoke-virtual {p1, p2}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
return-void
.line 132
:cond_1
invoke-virtual {p1}, Lcom/google/firebase/perf/session/PerfSession;->sessionId()Ljava/lang/String;
move-result-object p1
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->sessionId:Ljava/lang/String;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->applicationProcessState:Lcom/google/firebase/perf/v1/ApplicationProcessState;
:try_start_0
iget-object v2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeManagerExecutor:Lcom/google/firebase/components/Lazy;
.line 142
invoke-virtual {v2}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v2
move-object v3, v2
check-cast v3, Ljava/util/concurrent/ScheduledExecutorService;
new-instance v4, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;
invoke-direct {v4, p0, p1, p2}, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda1;-><init>(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
const-wide/16 p1, 0x14
mul-long v7, v0, p1
sget-object v9, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
move-wide v5, v7
.line 143
invoke-interface/range {v3 .. v9}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object p1
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeManagerDataCollectionJob:Ljava/util/concurrent/ScheduledFuture;
:try_end_0
.catch Ljava/util/concurrent/RejectedExecutionException; {:try_start_0 .. :try_end_0} :catch_0
goto :goto_0
:catch_0
move-exception p1
sget-object p2, Lcom/google/firebase/perf/session/gauges/GaugeManager;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 153
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Unable to start collecting Gauges: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {p2, p1}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
:goto_0
return-void
.end method
.method public stopCollectingGauges()V
.locals 5
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->sessionId:Ljava/lang/String;
if-nez v0, :cond_0
return-void
:cond_0
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->applicationProcessState:Lcom/google/firebase/perf/v1/ApplicationProcessState;
iget-object v2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->cpuGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 200
invoke-virtual {v2}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;
invoke-virtual {v2}, Lcom/google/firebase/perf/session/gauges/CpuGaugeCollector;->stopCollecting()V
iget-object v2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->memoryGaugeCollector:Lcom/google/firebase/components/Lazy;
.line 201
invoke-virtual {v2}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
invoke-virtual {v2}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->stopCollecting()V
iget-object v2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeManagerDataCollectionJob:Ljava/util/concurrent/ScheduledFuture;
if-eqz v2, :cond_1
const/4 v3, 0x0
.line 204
invoke-interface {v2, v3}, Ljava/util/concurrent/Future;->cancel(Z)Z
:cond_1
iget-object v2, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->gaugeManagerExecutor:Lcom/google/firebase/components/Lazy;
.line 211
invoke-virtual {v2}, Lcom/google/firebase/components/Lazy;->get()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/util/concurrent/ScheduledExecutorService;
new-instance v3, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;
invoke-direct {v3, p0, v0, v1}, Lcom/google/firebase/perf/session/gauges/GaugeManager$$ExternalSyntheticLambda0;-><init>(Lcom/google/firebase/perf/session/gauges/GaugeManager;Ljava/lang/String;Lcom/google/firebase/perf/v1/ApplicationProcessState;)V
const-wide/16 v0, 0x14
sget-object v4, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
.line 212
invoke-interface {v2, v3, v0, v1, v4}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->sessionId:Ljava/lang/String;
.line 220
sget-object v0, Lcom/google/firebase/perf/v1/ApplicationProcessState;->APPLICATION_PROCESS_STATE_UNKNOWN:Lcom/google/firebase/perf/v1/ApplicationProcessState;
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/GaugeManager;->applicationProcessState:Lcom/google/firebase/perf/v1/ApplicationProcessState;
return-void
.end method

View File

@@ -0,0 +1,152 @@
.class public Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field public static final logger:Lcom/google/firebase/perf/logging/AndroidLogger;
# instance fields
.field public final activityManager:Landroid/app/ActivityManager;
.field public final appContext:Landroid/content/Context;
.field public final memoryInfo:Landroid/app/ActivityManager$MemoryInfo;
.field public final runtime:Ljava/lang/Runtime;
# direct methods
.method static constructor <clinit>()V
.locals 1
.line 39
invoke-static {}, Lcom/google/firebase/perf/logging/AndroidLogger;->getInstance()Lcom/google/firebase/perf/logging/AndroidLogger;
move-result-object v0
sput-object v0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;)V
.locals 1
.line 47
invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime;
move-result-object v0
invoke-direct {p0, v0, p1}, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;-><init>(Ljava/lang/Runtime;Landroid/content/Context;)V
return-void
.end method
.method public constructor <init>(Ljava/lang/Runtime;Landroid/content/Context;)V
.locals 0
.line 51
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->runtime:Ljava/lang/Runtime;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->appContext:Landroid/content/Context;
const-string p1, "activity"
.line 54
invoke-virtual {p2, p1}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Landroid/app/ActivityManager;
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->activityManager:Landroid/app/ActivityManager;
.line 55
new-instance p2, Landroid/app/ActivityManager$MemoryInfo;
invoke-direct {p2}, Landroid/app/ActivityManager$MemoryInfo;-><init>()V
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->memoryInfo:Landroid/app/ActivityManager$MemoryInfo;
.line 56
invoke-virtual {p1, p2}, Landroid/app/ActivityManager;->getMemoryInfo(Landroid/app/ActivityManager$MemoryInfo;)V
return-void
.end method
# virtual methods
.method public getDeviceRamSizeKb()I
.locals 3
.line 79
sget-object v0, Lcom/google/firebase/perf/util/StorageUnit;->BYTES:Lcom/google/firebase/perf/util/StorageUnit;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->memoryInfo:Landroid/app/ActivityManager$MemoryInfo;
iget-wide v1, v1, Landroid/app/ActivityManager$MemoryInfo;->totalMem:J
invoke-virtual {v0, v1, v2}, Lcom/google/firebase/perf/util/StorageUnit;->toKilobytes(J)J
move-result-wide v0
invoke-static {v0, v1}, Lcom/google/firebase/perf/util/Utils;->saturatedIntCast(J)I
move-result v0
return v0
.end method
.method public getMaxAppJavaHeapMemoryKb()I
.locals 3
.line 64
sget-object v0, Lcom/google/firebase/perf/util/StorageUnit;->BYTES:Lcom/google/firebase/perf/util/StorageUnit;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->runtime:Ljava/lang/Runtime;
invoke-virtual {v1}, Ljava/lang/Runtime;->maxMemory()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lcom/google/firebase/perf/util/StorageUnit;->toKilobytes(J)J
move-result-wide v0
invoke-static {v0, v1}, Lcom/google/firebase/perf/util/Utils;->saturatedIntCast(J)I
move-result v0
return v0
.end method
.method public getMaxEncouragedAppJavaHeapMemoryKb()I
.locals 3
.line 72
sget-object v0, Lcom/google/firebase/perf/util/StorageUnit;->MEGABYTES:Lcom/google/firebase/perf/util/StorageUnit;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/GaugeMetadataManager;->activityManager:Landroid/app/ActivityManager;
.line 73
invoke-virtual {v1}, Landroid/app/ActivityManager;->getMemoryClass()I
move-result v1
int-to-long v1, v1
invoke-virtual {v0, v1, v2}, Lcom/google/firebase/perf/util/StorageUnit;->toKilobytes(J)J
move-result-wide v0
.line 72
invoke-static {v0, v1}, Lcom/google/firebase/perf/util/Utils;->saturatedIntCast(J)I
move-result v0
return v0
.end method

View File

@@ -0,0 +1,42 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda0;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# instance fields
.field public final synthetic f$0:Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
.field public final synthetic f$1:Lcom/google/firebase/perf/util/Timer;
# direct methods
.method public synthetic constructor <init>(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda0;->f$0:Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda0;->f$1:Lcom/google/firebase/perf/util/Timer;
return-void
.end method
# virtual methods
.method public final run()V
.locals 2
.line 0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda0;->f$0:Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda0;->f$1:Lcom/google/firebase/perf/util/Timer;
invoke-static {v0, v1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->$r8$lambda$dh__sffx-vEwiXhDmYqVqUyF-fc(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method

View File

@@ -0,0 +1,42 @@
.class public final synthetic Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda1;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# instance fields
.field public final synthetic f$0:Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
.field public final synthetic f$1:Lcom/google/firebase/perf/util/Timer;
# direct methods
.method public synthetic constructor <init>(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda1;->f$0:Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda1;->f$1:Lcom/google/firebase/perf/util/Timer;
return-void
.end method
# virtual methods
.method public final run()V
.locals 2
.line 0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda1;->f$0:Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda1;->f$1:Lcom/google/firebase/perf/util/Timer;
invoke-static {v0, v1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->$r8$lambda$yJoqclBHN-rG8705bpwUCW9ynok(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method

View File

@@ -0,0 +1,461 @@
.class public Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field public static final logger:Lcom/google/firebase/perf/logging/AndroidLogger;
# instance fields
.field public memoryMetricCollectionRateMs:J
.field public final memoryMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.field public memoryMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
.field public final memoryMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
.field public final runtime:Ljava/lang/Runtime;
# direct methods
.method public static synthetic $r8$lambda$dh__sffx-vEwiXhDmYqVqUyF-fc(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->lambda$scheduleMemoryMetricCollectionWithRate$0(Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method public static synthetic $r8$lambda$yJoqclBHN-rG8705bpwUCW9ynok(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 0
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->lambda$scheduleMemoryMetricCollectionOnce$1(Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method static constructor <clinit>()V
.locals 1
.line 41
invoke-static {}, Lcom/google/firebase/perf/logging/AndroidLogger;->getInstance()Lcom/google/firebase/perf/logging/AndroidLogger;
move-result-object v0
sput-object v0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
return-void
.end method
.method public constructor <init>()V
.locals 2
.line 59
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
invoke-static {}, Ljava/lang/Runtime;->getRuntime()Ljava/lang/Runtime;
move-result-object v1
invoke-direct {p0, v0, v1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;-><init>(Ljava/util/concurrent/ScheduledExecutorService;Ljava/lang/Runtime;)V
return-void
.end method
.method public constructor <init>(Ljava/util/concurrent/ScheduledExecutorService;Ljava/lang/Runtime;)V
.locals 2
.line 63
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
const-wide/16 v0, -0x1
iput-wide v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectionRateMs:J
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 65
new-instance p1, Ljava/util/concurrent/ConcurrentLinkedQueue;
invoke-direct {p1}, Ljava/util/concurrent/ConcurrentLinkedQueue;-><init>()V
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
iput-object p2, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->runtime:Ljava/lang/Runtime;
return-void
.end method
.method public static isInvalidCollectionFrequency(J)Z
.locals 2
const-wide/16 v0, 0x0
cmp-long p0, p0, v0
if-gtz p0, :cond_0
const/4 p0, 0x1
goto :goto_0
:cond_0
const/4 p0, 0x0
:goto_0
return p0
.end method
# virtual methods
.method public collectOnce(Lcom/google/firebase/perf/util/Timer;)V
.locals 0
.line 116
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->scheduleMemoryMetricCollectionOnce(Lcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method public final getCurrentUsedAppJavaHeapMemoryKb()I
.locals 5
.line 180
sget-object v0, Lcom/google/firebase/perf/util/StorageUnit;->BYTES:Lcom/google/firebase/perf/util/StorageUnit;
iget-object v1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->runtime:Ljava/lang/Runtime;
.line 181
invoke-virtual {v1}, Ljava/lang/Runtime;->totalMemory()J
move-result-wide v1
iget-object v3, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->runtime:Ljava/lang/Runtime;
invoke-virtual {v3}, Ljava/lang/Runtime;->freeMemory()J
move-result-wide v3
sub-long/2addr v1, v3
invoke-virtual {v0, v1, v2}, Lcom/google/firebase/perf/util/StorageUnit;->toKilobytes(J)J
move-result-wide v0
.line 180
invoke-static {v0, v1}, Lcom/google/firebase/perf/util/Utils;->saturatedIntCast(J)I
move-result v0
return v0
.end method
.method public final synthetic lambda$scheduleMemoryMetricCollectionOnce$1(Lcom/google/firebase/perf/util/Timer;)V
.locals 1
.line 148
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->syncCollectMemoryMetric(Lcom/google/firebase/perf/util/Timer;)Lcom/google/firebase/perf/v1/AndroidMemoryReading;
move-result-object p1
if-eqz p1, :cond_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
.line 150
invoke-virtual {v0, p1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->add(Ljava/lang/Object;)Z
:cond_0
return-void
.end method
.method public final synthetic lambda$scheduleMemoryMetricCollectionWithRate$0(Lcom/google/firebase/perf/util/Timer;)V
.locals 1
.line 129
invoke-virtual {p0, p1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->syncCollectMemoryMetric(Lcom/google/firebase/perf/util/Timer;)Lcom/google/firebase/perf/v1/AndroidMemoryReading;
move-result-object p1
if-eqz p1, :cond_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricReadings:Ljava/util/concurrent/ConcurrentLinkedQueue;
.line 131
invoke-virtual {v0, p1}, Ljava/util/concurrent/ConcurrentLinkedQueue;->add(Ljava/lang/Object;)Z
:cond_0
return-void
.end method
.method public final declared-synchronized scheduleMemoryMetricCollectionOnce(Lcom/google/firebase/perf/util/Timer;)V
.locals 4
monitor-enter p0
:try_start_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 145
new-instance v1, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda1;
invoke-direct {v1, p0, p1}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda1;-><init>(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
sget-object p1, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
const-wide/16 v2, 0x0
.line 146
invoke-interface {v0, v1, v2, v3, p1}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
:try_end_0
.catch Ljava/util/concurrent/RejectedExecutionException; {:try_start_0 .. :try_end_0} :catch_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
goto :goto_0
:catchall_0
move-exception p1
goto :goto_1
:catch_0
move-exception p1
:try_start_1
sget-object v0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 156
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Unable to collect Memory Metric: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v0, p1}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
.line 158
:goto_0
monitor-exit p0
return-void
:goto_1
monitor-exit p0
throw p1
.end method
.method public final declared-synchronized scheduleMemoryMetricCollectionWithRate(JLcom/google/firebase/perf/util/Timer;)V
.locals 7
monitor-enter p0
:try_start_0
iput-wide p1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectionRateMs:J
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
:try_start_1
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 126
new-instance v1, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda0;
invoke-direct {v1, p0, p3}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector$$ExternalSyntheticLambda0;-><init>(Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;Lcom/google/firebase/perf/util/Timer;)V
const-wide/16 v2, 0x0
sget-object v6, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
move-wide v4, p1
.line 127
invoke-interface/range {v0 .. v6}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleAtFixedRate(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object p1
iput-object p1, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
:try_end_1
.catch Ljava/util/concurrent/RejectedExecutionException; {:try_start_1 .. :try_end_1} :catch_0
.catchall {:try_start_1 .. :try_end_1} :catchall_0
goto :goto_0
:catchall_0
move-exception p1
goto :goto_1
:catch_0
move-exception p1
:try_start_2
sget-object p2, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->logger:Lcom/google/firebase/perf/logging/AndroidLogger;
.line 138
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Unable to start collecting Memory Metrics: "
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object p1
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {p2, p1}, Lcom/google/firebase/perf/logging/AndroidLogger;->warn(Ljava/lang/String;)V
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_0
.line 140
:goto_0
monitor-exit p0
return-void
:goto_1
monitor-exit p0
throw p1
.end method
.method public startCollecting(JLcom/google/firebase/perf/util/Timer;)V
.locals 2
.line 82
invoke-static {p1, p2}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->isInvalidCollectionFrequency(J)Z
move-result v0
if-eqz v0, :cond_0
return-void
:cond_0
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
if-eqz v0, :cond_2
iget-wide v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectionRateMs:J
cmp-long v0, v0, p1
if-eqz v0, :cond_1
.line 88
invoke-virtual {p0}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->stopCollecting()V
.line 89
invoke-virtual {p0, p1, p2, p3}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->scheduleMemoryMetricCollectionWithRate(JLcom/google/firebase/perf/util/Timer;)V
:cond_1
return-void
.line 95
:cond_2
invoke-virtual {p0, p1, p2, p3}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->scheduleMemoryMetricCollectionWithRate(JLcom/google/firebase/perf/util/Timer;)V
return-void
.end method
.method public stopCollecting()V
.locals 2
iget-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
if-nez v0, :cond_0
return-void
:cond_0
const/4 v1, 0x0
.line 104
invoke-interface {v0, v1}, Ljava/util/concurrent/Future;->cancel(Z)Z
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectorJob:Ljava/util/concurrent/ScheduledFuture;
const-wide/16 v0, -0x1
iput-wide v0, p0, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->memoryMetricCollectionRateMs:J
return-void
.end method
.method public final syncCollectMemoryMetric(Lcom/google/firebase/perf/util/Timer;)Lcom/google/firebase/perf/v1/AndroidMemoryReading;
.locals 2
if-nez p1, :cond_0
const/4 p1, 0x0
return-object p1
.line 166
:cond_0
invoke-virtual {p1}, Lcom/google/firebase/perf/util/Timer;->getCurrentTimestampMicros()J
move-result-wide v0
.line 168
invoke-static {}, Lcom/google/firebase/perf/v1/AndroidMemoryReading;->newBuilder()Lcom/google/firebase/perf/v1/AndroidMemoryReading$Builder;
move-result-object p1
.line 169
invoke-virtual {p1, v0, v1}, Lcom/google/firebase/perf/v1/AndroidMemoryReading$Builder;->setClientTimeUs(J)Lcom/google/firebase/perf/v1/AndroidMemoryReading$Builder;
move-result-object p1
.line 170
invoke-virtual {p0}, Lcom/google/firebase/perf/session/gauges/MemoryGaugeCollector;->getCurrentUsedAppJavaHeapMemoryKb()I
move-result v0
invoke-virtual {p1, v0}, Lcom/google/firebase/perf/v1/AndroidMemoryReading$Builder;->setUsedAppJavaHeapMemoryKb(I)Lcom/google/firebase/perf/v1/AndroidMemoryReading$Builder;
move-result-object p1
.line 171
invoke-virtual {p1}, Lcom/google/protobuf/GeneratedMessageLite$Builder;->build()Lcom/google/protobuf/GeneratedMessageLite;
move-result-object p1
check-cast p1, Lcom/google/firebase/perf/v1/AndroidMemoryReading;
return-object p1
.end method