mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
1364 lines
33 KiB
Smali
1364 lines
33 KiB
Smali
.class public final Lio/sentry/MetricsAggregator;
|
|
.super Ljava/lang/Object;
|
|
.source "MetricsAggregator.java"
|
|
|
|
# interfaces
|
|
.implements Lio/sentry/IMetricsAggregator;
|
|
.implements Ljava/lang/Runnable;
|
|
.implements Ljava/io/Closeable;
|
|
|
|
|
|
# static fields
|
|
.field private static final UTF8:Ljava/nio/charset/Charset;
|
|
|
|
|
|
# instance fields
|
|
.field private final beforeEmitCallback:Lio/sentry/SentryOptions$BeforeEmitMetricCallback;
|
|
|
|
.field private final buckets:Ljava/util/NavigableMap;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"Ljava/util/NavigableMap<",
|
|
"Ljava/lang/Long;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Lio/sentry/metrics/Metric;",
|
|
">;>;"
|
|
}
|
|
.end annotation
|
|
.end field
|
|
|
|
.field private final client:Lio/sentry/metrics/IMetricsClient;
|
|
|
|
.field private final dateProvider:Lio/sentry/SentryDateProvider;
|
|
|
|
.field private volatile executorService:Lio/sentry/ISentryExecutorService;
|
|
|
|
.field private volatile flushScheduled:Z
|
|
|
|
.field private volatile isClosed:Z
|
|
|
|
.field private final logger:Lio/sentry/ILogger;
|
|
|
|
.field private final maxWeight:I
|
|
|
|
.field private final totalBucketsWeight:Ljava/util/concurrent/atomic/AtomicInteger;
|
|
|
|
|
|
# direct methods
|
|
.method static constructor <clinit>()V
|
|
.locals 1
|
|
|
|
const-string v0, "UTF-8"
|
|
|
|
.line 33
|
|
invoke-static {v0}, Ljava/nio/charset/Charset;->forName(Ljava/lang/String;)Ljava/nio/charset/Charset;
|
|
|
|
move-result-object v0
|
|
|
|
sput-object v0, Lio/sentry/MetricsAggregator;->UTF8:Ljava/nio/charset/Charset;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public constructor <init>(Lio/sentry/SentryOptions;Lio/sentry/metrics/IMetricsClient;)V
|
|
.locals 7
|
|
|
|
.line 59
|
|
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getLogger()Lio/sentry/ILogger;
|
|
|
|
move-result-object v2
|
|
|
|
.line 60
|
|
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getDateProvider()Lio/sentry/SentryDateProvider;
|
|
|
|
move-result-object v3
|
|
|
|
const v4, 0x186a0
|
|
|
|
.line 62
|
|
invoke-virtual {p1}, Lio/sentry/SentryOptions;->getBeforeEmitMetricCallback()Lio/sentry/SentryOptions$BeforeEmitMetricCallback;
|
|
|
|
move-result-object v5
|
|
|
|
.line 63
|
|
invoke-static {}, Lio/sentry/NoOpSentryExecutorService;->getInstance()Lio/sentry/ISentryExecutorService;
|
|
|
|
move-result-object v6
|
|
|
|
move-object v0, p0
|
|
|
|
move-object v1, p2
|
|
|
|
.line 57
|
|
invoke-direct/range {v0 .. v6}, Lio/sentry/MetricsAggregator;-><init>(Lio/sentry/metrics/IMetricsClient;Lio/sentry/ILogger;Lio/sentry/SentryDateProvider;ILio/sentry/SentryOptions$BeforeEmitMetricCallback;Lio/sentry/ISentryExecutorService;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public constructor <init>(Lio/sentry/metrics/IMetricsClient;Lio/sentry/ILogger;Lio/sentry/SentryDateProvider;ILio/sentry/SentryOptions$BeforeEmitMetricCallback;Lio/sentry/ISentryExecutorService;)V
|
|
.locals 1
|
|
|
|
.line 73
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
const/4 v0, 0x0
|
|
|
|
iput-boolean v0, p0, Lio/sentry/MetricsAggregator;->isClosed:Z
|
|
|
|
iput-boolean v0, p0, Lio/sentry/MetricsAggregator;->flushScheduled:Z
|
|
|
|
.line 49
|
|
new-instance v0, Ljava/util/concurrent/ConcurrentSkipListMap;
|
|
|
|
invoke-direct {v0}, Ljava/util/concurrent/ConcurrentSkipListMap;-><init>()V
|
|
|
|
iput-object v0, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 52
|
|
new-instance v0, Ljava/util/concurrent/atomic/AtomicInteger;
|
|
|
|
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>()V
|
|
|
|
iput-object v0, p0, Lio/sentry/MetricsAggregator;->totalBucketsWeight:Ljava/util/concurrent/atomic/AtomicInteger;
|
|
|
|
iput-object p1, p0, Lio/sentry/MetricsAggregator;->client:Lio/sentry/metrics/IMetricsClient;
|
|
|
|
iput-object p2, p0, Lio/sentry/MetricsAggregator;->logger:Lio/sentry/ILogger;
|
|
|
|
iput-object p3, p0, Lio/sentry/MetricsAggregator;->dateProvider:Lio/sentry/SentryDateProvider;
|
|
|
|
iput p4, p0, Lio/sentry/MetricsAggregator;->maxWeight:I
|
|
|
|
iput-object p5, p0, Lio/sentry/MetricsAggregator;->beforeEmitCallback:Lio/sentry/SentryOptions$BeforeEmitMetricCallback;
|
|
|
|
iput-object p6, p0, Lio/sentry/MetricsAggregator;->executorService:Lio/sentry/ISentryExecutorService;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method private add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
.locals 17
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Lio/sentry/metrics/MetricType;",
|
|
"Ljava/lang/String;",
|
|
"D",
|
|
"Lio/sentry/MeasurementUnit;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;J",
|
|
"Lio/sentry/metrics/LocalMetricsAggregator;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
move-object/from16 v1, p0
|
|
|
|
move-object/from16 v0, p1
|
|
|
|
move-object/from16 v8, p2
|
|
|
|
move-wide/from16 v9, p3
|
|
|
|
move-object/from16 v11, p5
|
|
|
|
move-object/from16 v12, p6
|
|
|
|
const-string v2, "Unknown MetricType: "
|
|
|
|
iget-boolean v3, v1, Lio/sentry/MetricsAggregator;->isClosed:Z
|
|
|
|
if-eqz v3, :cond_0
|
|
|
|
return-void
|
|
|
|
:cond_0
|
|
iget-object v3, v1, Lio/sentry/MetricsAggregator;->beforeEmitCallback:Lio/sentry/SentryOptions$BeforeEmitMetricCallback;
|
|
|
|
if-eqz v3, :cond_1
|
|
|
|
.line 177
|
|
invoke-interface {v3, v8, v12}, Lio/sentry/SentryOptions$BeforeEmitMetricCallback;->execute(Ljava/lang/String;Ljava/util/Map;)Z
|
|
|
|
move-result v3
|
|
|
|
if-nez v3, :cond_1
|
|
|
|
return-void
|
|
|
|
.line 182
|
|
:cond_1
|
|
invoke-static/range {p7 .. p8}, Lio/sentry/metrics/MetricsHelper;->getTimeBucketKey(J)J
|
|
|
|
move-result-wide v3
|
|
|
|
.line 183
|
|
invoke-direct {v1, v3, v4}, Lio/sentry/MetricsAggregator;->getOrAddTimeBucket(J)Ljava/util/Map;
|
|
|
|
move-result-object v13
|
|
|
|
.line 185
|
|
invoke-static {v0, v8, v11, v12}, Lio/sentry/metrics/MetricsHelper;->getMetricBucketKey(Lio/sentry/metrics/MetricType;Ljava/lang/String;Lio/sentry/MeasurementUnit;Ljava/util/Map;)Ljava/lang/String;
|
|
|
|
move-result-object v14
|
|
|
|
.line 190
|
|
monitor-enter v13
|
|
|
|
.line 191
|
|
:try_start_0
|
|
invoke-interface {v13, v14}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v3
|
|
|
|
check-cast v3, Lio/sentry/metrics/Metric;
|
|
|
|
const/4 v15, 0x1
|
|
|
|
if-eqz v3, :cond_2
|
|
|
|
.line 193
|
|
invoke-virtual {v3}, Lio/sentry/metrics/Metric;->getWeight()I
|
|
|
|
move-result v2
|
|
|
|
.line 194
|
|
invoke-virtual {v3, v9, v10}, Lio/sentry/metrics/Metric;->add(D)V
|
|
|
|
.line 195
|
|
invoke-virtual {v3}, Lio/sentry/metrics/Metric;->getWeight()I
|
|
|
|
move-result v3
|
|
|
|
sub-int/2addr v3, v2
|
|
|
|
goto/16 :goto_2
|
|
|
|
.line 198
|
|
:cond_2
|
|
sget-object v3, Lio/sentry/MetricsAggregator$1;->$SwitchMap$io$sentry$metrics$MetricType:[I
|
|
|
|
invoke-virtual/range {p1 .. p1}, Lio/sentry/metrics/MetricType;->ordinal()I
|
|
|
|
move-result v4
|
|
|
|
aget v3, v3, v4
|
|
|
|
if-eq v3, v15, :cond_6
|
|
|
|
const/4 v4, 0x2
|
|
|
|
if-eq v3, v4, :cond_5
|
|
|
|
const/4 v4, 0x3
|
|
|
|
if-eq v3, v4, :cond_4
|
|
|
|
const/4 v4, 0x4
|
|
|
|
if-ne v3, v4, :cond_3
|
|
|
|
.line 209
|
|
new-instance v2, Lio/sentry/metrics/SetMetric;
|
|
|
|
invoke-direct {v2, v8, v11, v12}, Lio/sentry/metrics/SetMetric;-><init>(Ljava/lang/String;Lio/sentry/MeasurementUnit;Ljava/util/Map;)V
|
|
|
|
double-to-int v3, v9
|
|
|
|
int-to-double v3, v3
|
|
|
|
.line 212
|
|
invoke-virtual {v2, v3, v4}, Lio/sentry/metrics/Metric;->add(D)V
|
|
|
|
goto :goto_1
|
|
|
|
.line 215
|
|
:cond_3
|
|
new-instance v1, Ljava/lang/IllegalArgumentException;
|
|
|
|
new-instance v3, Ljava/lang/StringBuilder;
|
|
|
|
invoke-direct {v3, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
|
|
|
|
invoke-virtual/range {p1 .. p1}, Lio/sentry/metrics/MetricType;->name()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v0
|
|
|
|
invoke-direct {v1, v0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
|
|
|
|
throw v1
|
|
|
|
.line 206
|
|
:cond_4
|
|
new-instance v16, Lio/sentry/metrics/DistributionMetric;
|
|
|
|
move-object/from16 v2, v16
|
|
|
|
move-object/from16 v3, p2
|
|
|
|
move-wide/from16 v4, p3
|
|
|
|
move-object/from16 v6, p5
|
|
|
|
move-object/from16 v7, p6
|
|
|
|
invoke-direct/range {v2 .. v7}, Lio/sentry/metrics/DistributionMetric;-><init>(Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;)V
|
|
|
|
goto :goto_0
|
|
|
|
.line 203
|
|
:cond_5
|
|
new-instance v16, Lio/sentry/metrics/GaugeMetric;
|
|
|
|
move-object/from16 v2, v16
|
|
|
|
move-object/from16 v3, p2
|
|
|
|
move-wide/from16 v4, p3
|
|
|
|
move-object/from16 v6, p5
|
|
|
|
move-object/from16 v7, p6
|
|
|
|
invoke-direct/range {v2 .. v7}, Lio/sentry/metrics/GaugeMetric;-><init>(Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;)V
|
|
|
|
goto :goto_0
|
|
|
|
.line 200
|
|
:cond_6
|
|
new-instance v16, Lio/sentry/metrics/CounterMetric;
|
|
|
|
move-object/from16 v2, v16
|
|
|
|
move-object/from16 v3, p2
|
|
|
|
move-wide/from16 v4, p3
|
|
|
|
move-object/from16 v6, p5
|
|
|
|
move-object/from16 v7, p6
|
|
|
|
invoke-direct/range {v2 .. v7}, Lio/sentry/metrics/CounterMetric;-><init>(Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;)V
|
|
|
|
:goto_0
|
|
move-object/from16 v2, v16
|
|
|
|
.line 217
|
|
:goto_1
|
|
invoke-virtual {v2}, Lio/sentry/metrics/Metric;->getWeight()I
|
|
|
|
move-result v3
|
|
|
|
.line 218
|
|
invoke-interface {v13, v14, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
:goto_2
|
|
iget-object v2, v1, Lio/sentry/MetricsAggregator;->totalBucketsWeight:Ljava/util/concurrent/atomic/AtomicInteger;
|
|
|
|
.line 220
|
|
invoke-virtual {v2, v3}, Ljava/util/concurrent/atomic/AtomicInteger;->addAndGet(I)I
|
|
|
|
.line 221
|
|
monitor-exit v13
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_1
|
|
|
|
if-eqz p9, :cond_8
|
|
|
|
.line 226
|
|
sget-object v2, Lio/sentry/metrics/MetricType;->Set:Lio/sentry/metrics/MetricType;
|
|
|
|
if-ne v0, v2, :cond_7
|
|
|
|
int-to-double v2, v3
|
|
|
|
move-wide v6, v2
|
|
|
|
goto :goto_3
|
|
|
|
:cond_7
|
|
move-wide v6, v9
|
|
|
|
:goto_3
|
|
move-object/from16 v2, p9
|
|
|
|
move-object v3, v14
|
|
|
|
move-object/from16 v4, p1
|
|
|
|
move-object/from16 v5, p2
|
|
|
|
move-object/from16 v8, p5
|
|
|
|
move-object/from16 v9, p6
|
|
|
|
move-wide/from16 v10, p7
|
|
|
|
.line 227
|
|
invoke-virtual/range {v2 .. v11}, Lio/sentry/metrics/LocalMetricsAggregator;->add(Ljava/lang/String;Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;J)V
|
|
|
|
.line 230
|
|
:cond_8
|
|
invoke-direct/range {p0 .. p0}, Lio/sentry/MetricsAggregator;->isOverWeight()Z
|
|
|
|
move-result v0
|
|
|
|
iget-boolean v2, v1, Lio/sentry/MetricsAggregator;->isClosed:Z
|
|
|
|
if-nez v2, :cond_d
|
|
|
|
if-nez v0, :cond_9
|
|
|
|
iget-boolean v2, v1, Lio/sentry/MetricsAggregator;->flushScheduled:Z
|
|
|
|
if-nez v2, :cond_d
|
|
|
|
.line 232
|
|
:cond_9
|
|
monitor-enter p0
|
|
|
|
:try_start_1
|
|
iget-boolean v2, v1, Lio/sentry/MetricsAggregator;->isClosed:Z
|
|
|
|
if-nez v2, :cond_c
|
|
|
|
iget-object v2, v1, Lio/sentry/MetricsAggregator;->executorService:Lio/sentry/ISentryExecutorService;
|
|
|
|
.line 237
|
|
instance-of v2, v2, Lio/sentry/NoOpSentryExecutorService;
|
|
|
|
if-eqz v2, :cond_a
|
|
|
|
.line 238
|
|
new-instance v2, Lio/sentry/SentryExecutorService;
|
|
|
|
invoke-direct {v2}, Lio/sentry/SentryExecutorService;-><init>()V
|
|
|
|
iput-object v2, v1, Lio/sentry/MetricsAggregator;->executorService:Lio/sentry/ISentryExecutorService;
|
|
|
|
:cond_a
|
|
iput-boolean v15, v1, Lio/sentry/MetricsAggregator;->flushScheduled:Z
|
|
|
|
if-eqz v0, :cond_b
|
|
|
|
const-wide/16 v2, 0x0
|
|
|
|
goto :goto_4
|
|
|
|
:cond_b
|
|
const-wide/16 v2, 0x1388
|
|
|
|
:goto_4
|
|
iget-object v0, v1, Lio/sentry/MetricsAggregator;->executorService:Lio/sentry/ISentryExecutorService;
|
|
|
|
.line 243
|
|
invoke-interface {v0, v1, v2, v3}, Lio/sentry/ISentryExecutorService;->schedule(Ljava/lang/Runnable;J)Ljava/util/concurrent/Future;
|
|
|
|
.line 245
|
|
:cond_c
|
|
monitor-exit p0
|
|
|
|
goto :goto_5
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
throw v0
|
|
|
|
:cond_d
|
|
:goto_5
|
|
return-void
|
|
|
|
:catchall_1
|
|
move-exception v0
|
|
|
|
.line 221
|
|
:try_start_2
|
|
monitor-exit v13
|
|
:try_end_2
|
|
.catchall {:try_start_2 .. :try_end_2} :catchall_1
|
|
|
|
throw v0
|
|
.end method
|
|
|
|
.method private static getBucketWeight(Ljava/util/Map;)I
|
|
.locals 2
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Lio/sentry/metrics/Metric;",
|
|
">;)I"
|
|
}
|
|
.end annotation
|
|
|
|
.line 294
|
|
invoke-interface {p0}, Ljava/util/Map;->values()Ljava/util/Collection;
|
|
|
|
move-result-object p0
|
|
|
|
invoke-interface {p0}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object p0
|
|
|
|
const/4 v0, 0x0
|
|
|
|
:goto_0
|
|
invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v1
|
|
|
|
check-cast v1, Lio/sentry/metrics/Metric;
|
|
|
|
.line 295
|
|
invoke-virtual {v1}, Lio/sentry/metrics/Metric;->getWeight()I
|
|
|
|
move-result v1
|
|
|
|
add-int/2addr v0, v1
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
return v0
|
|
.end method
|
|
|
|
.method private getFlushableBuckets(Z)Ljava/util/Set;
|
|
.locals 2
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(Z)",
|
|
"Ljava/util/Set<",
|
|
"Ljava/lang/Long;",
|
|
">;"
|
|
}
|
|
.end annotation
|
|
|
|
if-eqz p1, :cond_0
|
|
|
|
iget-object p0, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 303
|
|
invoke-interface {p0}, Ljava/util/NavigableMap;->keySet()Ljava/util/Set;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
|
|
.line 306
|
|
:cond_0
|
|
invoke-direct {p0}, Lio/sentry/MetricsAggregator;->nowMillis()J
|
|
|
|
move-result-wide v0
|
|
|
|
invoke-static {v0, v1}, Lio/sentry/metrics/MetricsHelper;->getCutoffTimestampMs(J)J
|
|
|
|
move-result-wide v0
|
|
|
|
.line 307
|
|
invoke-static {v0, v1}, Lio/sentry/metrics/MetricsHelper;->getTimeBucketKey(J)J
|
|
|
|
move-result-wide v0
|
|
|
|
iget-object p0, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 308
|
|
invoke-static {v0, v1}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object p1
|
|
|
|
const/4 v0, 0x1
|
|
|
|
invoke-interface {p0, p1, v0}, Ljava/util/NavigableMap;->headMap(Ljava/lang/Object;Z)Ljava/util/NavigableMap;
|
|
|
|
move-result-object p0
|
|
|
|
invoke-interface {p0}, Ljava/util/NavigableMap;->keySet()Ljava/util/Set;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
.end method
|
|
|
|
.method private getOrAddTimeBucket(J)Ljava/util/Map;
|
|
.locals 3
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(J)",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Lio/sentry/metrics/Metric;",
|
|
">;"
|
|
}
|
|
.end annotation
|
|
|
|
iget-object v0, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 315
|
|
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v1
|
|
|
|
invoke-interface {v0, v1}, Ljava/util/NavigableMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
check-cast v0, Ljava/util/Map;
|
|
|
|
if-nez v0, :cond_1
|
|
|
|
iget-object v1, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 319
|
|
monitor-enter v1
|
|
|
|
:try_start_0
|
|
iget-object v0, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 320
|
|
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v2
|
|
|
|
invoke-interface {v0, v2}, Ljava/util/NavigableMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v0
|
|
|
|
check-cast v0, Ljava/util/Map;
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
.line 322
|
|
new-instance v0, Ljava/util/HashMap;
|
|
|
|
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
|
|
|
|
iget-object p0, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 323
|
|
invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-interface {p0, p1, v0}, Ljava/util/NavigableMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
.line 325
|
|
:cond_0
|
|
monitor-exit v1
|
|
|
|
goto :goto_0
|
|
|
|
:catchall_0
|
|
move-exception p0
|
|
|
|
monitor-exit v1
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
throw p0
|
|
|
|
:cond_1
|
|
:goto_0
|
|
return-object v0
|
|
.end method
|
|
|
|
.method private isOverWeight()Z
|
|
.locals 2
|
|
|
|
iget-object v0, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 288
|
|
invoke-interface {v0}, Ljava/util/NavigableMap;->size()I
|
|
|
|
move-result v0
|
|
|
|
iget-object v1, p0, Lio/sentry/MetricsAggregator;->totalBucketsWeight:Ljava/util/concurrent/atomic/AtomicInteger;
|
|
|
|
invoke-virtual {v1}, Ljava/util/concurrent/atomic/AtomicInteger;->get()I
|
|
|
|
move-result v1
|
|
|
|
add-int/2addr v0, v1
|
|
|
|
iget p0, p0, Lio/sentry/MetricsAggregator;->maxWeight:I
|
|
|
|
if-lt v0, p0, :cond_0
|
|
|
|
const/4 p0, 0x1
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
const/4 p0, 0x0
|
|
|
|
:goto_0
|
|
return p0
|
|
.end method
|
|
|
|
.method private nowMillis()J
|
|
.locals 3
|
|
|
|
.line 352
|
|
sget-object v0, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;
|
|
|
|
iget-object p0, p0, Lio/sentry/MetricsAggregator;->dateProvider:Lio/sentry/SentryDateProvider;
|
|
|
|
invoke-interface {p0}, Lio/sentry/SentryDateProvider;->now()Lio/sentry/SentryDate;
|
|
|
|
move-result-object p0
|
|
|
|
invoke-virtual {p0}, Lio/sentry/SentryDate;->nanoTimestamp()J
|
|
|
|
move-result-wide v1
|
|
|
|
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
|
|
|
|
move-result-wide v0
|
|
|
|
return-wide v0
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public close()V
|
|
.locals 4
|
|
.annotation system Ldalvik/annotation/Throws;
|
|
value = {
|
|
Ljava/io/IOException;
|
|
}
|
|
.end annotation
|
|
|
|
.line 332
|
|
monitor-enter p0
|
|
|
|
const/4 v0, 0x1
|
|
|
|
:try_start_0
|
|
iput-boolean v0, p0, Lio/sentry/MetricsAggregator;->isClosed:Z
|
|
|
|
iget-object v1, p0, Lio/sentry/MetricsAggregator;->executorService:Lio/sentry/ISentryExecutorService;
|
|
|
|
const-wide/16 v2, 0x0
|
|
|
|
.line 334
|
|
invoke-interface {v1, v2, v3}, Lio/sentry/ISentryExecutorService;->close(J)V
|
|
|
|
.line 335
|
|
monitor-exit p0
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
.line 336
|
|
invoke-virtual {p0, v0}, Lio/sentry/MetricsAggregator;->flush(Z)V
|
|
|
|
return-void
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
.line 335
|
|
:try_start_1
|
|
monitor-exit p0
|
|
:try_end_1
|
|
.catchall {:try_start_1 .. :try_end_1} :catchall_0
|
|
|
|
throw v0
|
|
.end method
|
|
|
|
.method public distribution(Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
.locals 10
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
"D",
|
|
"Lio/sentry/MeasurementUnit;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;J",
|
|
"Lio/sentry/metrics/LocalMetricsAggregator;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
.line 112
|
|
sget-object v1, Lio/sentry/metrics/MetricType;->Distribution:Lio/sentry/metrics/MetricType;
|
|
|
|
move-object v0, p0
|
|
|
|
move-object v2, p1
|
|
|
|
move-wide v3, p2
|
|
|
|
move-object v5, p4
|
|
|
|
move-object v6, p5
|
|
|
|
move-wide/from16 v7, p6
|
|
|
|
move-object/from16 v9, p8
|
|
|
|
invoke-direct/range {v0 .. v9}, Lio/sentry/MetricsAggregator;->add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public flush(Z)V
|
|
.locals 8
|
|
|
|
const/4 v0, 0x0
|
|
|
|
if-nez p1, :cond_0
|
|
|
|
.line 251
|
|
invoke-direct {p0}, Lio/sentry/MetricsAggregator;->isOverWeight()Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
iget-object p1, p0, Lio/sentry/MetricsAggregator;->logger:Lio/sentry/ILogger;
|
|
|
|
.line 252
|
|
sget-object v1, Lio/sentry/SentryLevel;->INFO:Lio/sentry/SentryLevel;
|
|
|
|
const-string v2, "Metrics: total weight exceeded, flushing all buckets"
|
|
|
|
new-array v3, v0, [Ljava/lang/Object;
|
|
|
|
invoke-interface {p1, v1, v2, v3}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
const/4 p1, 0x1
|
|
|
|
.line 256
|
|
:cond_0
|
|
invoke-direct {p0, p1}, Lio/sentry/MetricsAggregator;->getFlushableBuckets(Z)Ljava/util/Set;
|
|
|
|
move-result-object p1
|
|
|
|
.line 257
|
|
invoke-interface {p1}, Ljava/util/Set;->isEmpty()Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_1
|
|
|
|
iget-object p0, p0, Lio/sentry/MetricsAggregator;->logger:Lio/sentry/ILogger;
|
|
|
|
.line 258
|
|
sget-object p1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
|
|
|
|
const-string v1, "Metrics: nothing to flush"
|
|
|
|
new-array v0, v0, [Ljava/lang/Object;
|
|
|
|
invoke-interface {p0, p1, v1, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
:cond_1
|
|
iget-object v1, p0, Lio/sentry/MetricsAggregator;->logger:Lio/sentry/ILogger;
|
|
|
|
.line 261
|
|
sget-object v2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
|
|
|
|
new-instance v3, Ljava/lang/StringBuilder;
|
|
|
|
const-string v4, "Metrics: flushing "
|
|
|
|
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
|
|
|
|
invoke-interface {p1}, Ljava/util/Set;->size()I
|
|
|
|
move-result v4
|
|
|
|
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
|
|
|
|
move-result-object v3
|
|
|
|
const-string v4, " buckets"
|
|
|
|
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
|
|
|
|
move-result-object v3
|
|
|
|
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
|
|
|
|
move-result-object v3
|
|
|
|
new-array v4, v0, [Ljava/lang/Object;
|
|
|
|
invoke-interface {v1, v2, v3, v4}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
.line 263
|
|
new-instance v1, Ljava/util/HashMap;
|
|
|
|
invoke-direct {v1}, Ljava/util/HashMap;-><init>()V
|
|
|
|
.line 265
|
|
invoke-interface {p1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
|
|
|
|
move-result-object p1
|
|
|
|
move v2, v0
|
|
|
|
:cond_2
|
|
:goto_0
|
|
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v3
|
|
|
|
if-eqz v3, :cond_3
|
|
|
|
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v3
|
|
|
|
check-cast v3, Ljava/lang/Long;
|
|
|
|
invoke-virtual {v3}, Ljava/lang/Long;->longValue()J
|
|
|
|
move-result-wide v3
|
|
|
|
iget-object v5, p0, Lio/sentry/MetricsAggregator;->buckets:Ljava/util/NavigableMap;
|
|
|
|
.line 266
|
|
invoke-static {v3, v4}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v6
|
|
|
|
invoke-interface {v5, v6}, Ljava/util/NavigableMap;->remove(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object v5
|
|
|
|
check-cast v5, Ljava/util/Map;
|
|
|
|
if-eqz v5, :cond_2
|
|
|
|
.line 268
|
|
monitor-enter v5
|
|
|
|
.line 269
|
|
:try_start_0
|
|
invoke-static {v5}, Lio/sentry/MetricsAggregator;->getBucketWeight(Ljava/util/Map;)I
|
|
|
|
move-result v6
|
|
|
|
iget-object v7, p0, Lio/sentry/MetricsAggregator;->totalBucketsWeight:Ljava/util/concurrent/atomic/AtomicInteger;
|
|
|
|
neg-int v6, v6
|
|
|
|
.line 270
|
|
invoke-virtual {v7, v6}, Ljava/util/concurrent/atomic/AtomicInteger;->addAndGet(I)I
|
|
|
|
.line 272
|
|
invoke-interface {v5}, Ljava/util/Map;->size()I
|
|
|
|
move-result v6
|
|
|
|
add-int/2addr v2, v6
|
|
|
|
.line 273
|
|
invoke-static {v3, v4}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
|
|
|
|
move-result-object v3
|
|
|
|
invoke-interface {v1, v3, v5}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
.line 274
|
|
monitor-exit v5
|
|
|
|
goto :goto_0
|
|
|
|
:catchall_0
|
|
move-exception p0
|
|
|
|
monitor-exit v5
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
throw p0
|
|
|
|
:cond_3
|
|
if-nez v2, :cond_4
|
|
|
|
iget-object p0, p0, Lio/sentry/MetricsAggregator;->logger:Lio/sentry/ILogger;
|
|
|
|
.line 279
|
|
sget-object p1, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
|
|
|
|
const-string v1, "Metrics: only empty buckets found"
|
|
|
|
new-array v0, v0, [Ljava/lang/Object;
|
|
|
|
invoke-interface {p0, p1, v1, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
return-void
|
|
|
|
:cond_4
|
|
iget-object p1, p0, Lio/sentry/MetricsAggregator;->logger:Lio/sentry/ILogger;
|
|
|
|
.line 283
|
|
sget-object v2, Lio/sentry/SentryLevel;->DEBUG:Lio/sentry/SentryLevel;
|
|
|
|
const-string v3, "Metrics: capturing metrics"
|
|
|
|
new-array v0, v0, [Ljava/lang/Object;
|
|
|
|
invoke-interface {p1, v2, v3, v0}, Lio/sentry/ILogger;->log(Lio/sentry/SentryLevel;Ljava/lang/String;[Ljava/lang/Object;)V
|
|
|
|
iget-object p0, p0, Lio/sentry/MetricsAggregator;->client:Lio/sentry/metrics/IMetricsClient;
|
|
|
|
.line 284
|
|
new-instance p1, Lio/sentry/metrics/EncodedMetrics;
|
|
|
|
invoke-direct {p1, v1}, Lio/sentry/metrics/EncodedMetrics;-><init>(Ljava/util/Map;)V
|
|
|
|
invoke-interface {p0, p1}, Lio/sentry/metrics/IMetricsClient;->captureMetrics(Lio/sentry/metrics/EncodedMetrics;)Lio/sentry/protocol/SentryId;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public gauge(Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
.locals 10
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
"D",
|
|
"Lio/sentry/MeasurementUnit;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;J",
|
|
"Lio/sentry/metrics/LocalMetricsAggregator;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
.line 101
|
|
sget-object v1, Lio/sentry/metrics/MetricType;->Gauge:Lio/sentry/metrics/MetricType;
|
|
|
|
move-object v0, p0
|
|
|
|
move-object v2, p1
|
|
|
|
move-wide v3, p2
|
|
|
|
move-object v5, p4
|
|
|
|
move-object v6, p5
|
|
|
|
move-wide/from16 v7, p6
|
|
|
|
move-object/from16 v9, p8
|
|
|
|
invoke-direct/range {v0 .. v9}, Lio/sentry/MetricsAggregator;->add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public increment(Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
.locals 10
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
"D",
|
|
"Lio/sentry/MeasurementUnit;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;J",
|
|
"Lio/sentry/metrics/LocalMetricsAggregator;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
.line 90
|
|
sget-object v1, Lio/sentry/metrics/MetricType;->Counter:Lio/sentry/metrics/MetricType;
|
|
|
|
move-object v0, p0
|
|
|
|
move-object v2, p1
|
|
|
|
move-wide v3, p2
|
|
|
|
move-object v5, p4
|
|
|
|
move-object v6, p5
|
|
|
|
move-wide/from16 v7, p6
|
|
|
|
move-object/from16 v9, p8
|
|
|
|
invoke-direct/range {v0 .. v9}, Lio/sentry/MetricsAggregator;->add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public run()V
|
|
.locals 3
|
|
|
|
const/4 v0, 0x0
|
|
|
|
.line 342
|
|
invoke-virtual {p0, v0}, Lio/sentry/MetricsAggregator;->flush(Z)V
|
|
|
|
.line 344
|
|
monitor-enter p0
|
|
|
|
:try_start_0
|
|
iget-boolean v0, p0, Lio/sentry/MetricsAggregator;->isClosed:Z
|
|
|
|
if-nez v0, :cond_0
|
|
|
|
iget-object v0, p0, Lio/sentry/MetricsAggregator;->executorService:Lio/sentry/ISentryExecutorService;
|
|
|
|
const-wide/16 v1, 0x1388
|
|
|
|
.line 346
|
|
invoke-interface {v0, p0, v1, v2}, Lio/sentry/ISentryExecutorService;->schedule(Ljava/lang/Runnable;J)Ljava/util/concurrent/Future;
|
|
|
|
.line 348
|
|
:cond_0
|
|
monitor-exit p0
|
|
|
|
return-void
|
|
|
|
:catchall_0
|
|
move-exception v0
|
|
|
|
monitor-exit p0
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
throw v0
|
|
.end method
|
|
|
|
.method public set(Ljava/lang/String;ILio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
.locals 10
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
"I",
|
|
"Lio/sentry/MeasurementUnit;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;J",
|
|
"Lio/sentry/metrics/LocalMetricsAggregator;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
.line 123
|
|
sget-object v1, Lio/sentry/metrics/MetricType;->Set:Lio/sentry/metrics/MetricType;
|
|
|
|
move v0, p2
|
|
|
|
int-to-double v3, v0
|
|
|
|
move-object v0, p0
|
|
|
|
move-object v2, p1
|
|
|
|
move-object v5, p3
|
|
|
|
move-object v6, p4
|
|
|
|
move-wide v7, p5
|
|
|
|
move-object/from16 v9, p7
|
|
|
|
invoke-direct/range {v0 .. v9}, Lio/sentry/MetricsAggregator;->add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public set(Ljava/lang/String;Ljava/lang/String;Lio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
.locals 11
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
"Lio/sentry/MeasurementUnit;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;J",
|
|
"Lio/sentry/metrics/LocalMetricsAggregator;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
sget-object v0, Lio/sentry/MetricsAggregator;->UTF8:Ljava/nio/charset/Charset;
|
|
|
|
move-object v1, p2
|
|
|
|
.line 135
|
|
invoke-virtual {p2, v0}, Ljava/lang/String;->getBytes(Ljava/nio/charset/Charset;)[B
|
|
|
|
move-result-object v0
|
|
|
|
.line 137
|
|
new-instance v1, Ljava/util/zip/CRC32;
|
|
|
|
invoke-direct {v1}, Ljava/util/zip/CRC32;-><init>()V
|
|
|
|
const/4 v2, 0x0
|
|
|
|
.line 138
|
|
array-length v3, v0
|
|
|
|
invoke-virtual {v1, v0, v2, v3}, Ljava/util/zip/CRC32;->update([BII)V
|
|
|
|
.line 139
|
|
invoke-virtual {v1}, Ljava/util/zip/CRC32;->getValue()J
|
|
|
|
move-result-wide v0
|
|
|
|
long-to-int v0, v0
|
|
|
|
.line 141
|
|
sget-object v2, Lio/sentry/metrics/MetricType;->Set:Lio/sentry/metrics/MetricType;
|
|
|
|
int-to-double v4, v0
|
|
|
|
move-object v1, p0
|
|
|
|
move-object v3, p1
|
|
|
|
move-object v6, p3
|
|
|
|
move-object v7, p4
|
|
|
|
move-wide/from16 v8, p5
|
|
|
|
move-object/from16 v10, p7
|
|
|
|
invoke-direct/range {v1 .. v10}, Lio/sentry/MetricsAggregator;->add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public timing(Ljava/lang/String;Ljava/lang/Runnable;Lio/sentry/MeasurementUnit$Duration;Ljava/util/Map;Lio/sentry/metrics/LocalMetricsAggregator;)V
|
|
.locals 10
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/Runnable;",
|
|
"Lio/sentry/MeasurementUnit$Duration;",
|
|
"Ljava/util/Map<",
|
|
"Ljava/lang/String;",
|
|
"Ljava/lang/String;",
|
|
">;",
|
|
"Lio/sentry/metrics/LocalMetricsAggregator;",
|
|
")V"
|
|
}
|
|
.end annotation
|
|
|
|
.line 151
|
|
invoke-direct {p0}, Lio/sentry/MetricsAggregator;->nowMillis()J
|
|
|
|
move-result-wide v7
|
|
|
|
.line 152
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v0
|
|
|
|
.line 154
|
|
:try_start_0
|
|
invoke-interface {p2}, Ljava/lang/Runnable;->run()V
|
|
:try_end_0
|
|
.catchall {:try_start_0 .. :try_end_0} :catchall_0
|
|
|
|
.line 156
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v2
|
|
|
|
sub-long/2addr v2, v0
|
|
|
|
.line 157
|
|
invoke-static {p3, v2, v3}, Lio/sentry/metrics/MetricsHelper;->convertNanosTo(Lio/sentry/MeasurementUnit$Duration;J)D
|
|
|
|
move-result-wide v3
|
|
|
|
.line 158
|
|
sget-object v1, Lio/sentry/metrics/MetricType;->Distribution:Lio/sentry/metrics/MetricType;
|
|
|
|
move-object v0, p0
|
|
|
|
move-object v2, p1
|
|
|
|
move-object v5, p3
|
|
|
|
move-object v6, p4
|
|
|
|
move-object v9, p5
|
|
|
|
invoke-direct/range {v0 .. v9}, Lio/sentry/MetricsAggregator;->add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
|
|
return-void
|
|
|
|
:catchall_0
|
|
move-exception p2
|
|
|
|
.line 156
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v2
|
|
|
|
sub-long/2addr v2, v0
|
|
|
|
.line 157
|
|
invoke-static {p3, v2, v3}, Lio/sentry/metrics/MetricsHelper;->convertNanosTo(Lio/sentry/MeasurementUnit$Duration;J)D
|
|
|
|
move-result-wide v3
|
|
|
|
.line 158
|
|
sget-object v1, Lio/sentry/metrics/MetricType;->Distribution:Lio/sentry/metrics/MetricType;
|
|
|
|
move-object v0, p0
|
|
|
|
move-object v2, p1
|
|
|
|
move-object v5, p3
|
|
|
|
move-object v6, p4
|
|
|
|
move-object v9, p5
|
|
|
|
invoke-direct/range {v0 .. v9}, Lio/sentry/MetricsAggregator;->add(Lio/sentry/metrics/MetricType;Ljava/lang/String;DLio/sentry/MeasurementUnit;Ljava/util/Map;JLio/sentry/metrics/LocalMetricsAggregator;)V
|
|
|
|
.line 159
|
|
throw p2
|
|
.end method
|