ByteThroughputHelper.smali
.class Lcom/amazonaws/metrics/ByteThroughputHelper;
.super Lcom/amazonaws/metrics/ByteThroughputProvider;
.source "ByteThroughputHelper.java"
# static fields
.field private static final REPORT_INTERVAL_SECS:I = 0xa
# direct methods
.method constructor <init>(Lcom/amazonaws/metrics/ThroughputMetricType;)V
.registers 2
.line 1
invoke-direct {p0, p1}, Lcom/amazonaws/metrics/ByteThroughputProvider;-><init>(Lcom/amazonaws/metrics/ThroughputMetricType;)V
return-void
.end method
# virtual methods
.method public increment(IJ)V
.registers 4
.line 1
invoke-super {p0, p1, p2, p3}, Lcom/amazonaws/metrics/ByteThroughputProvider;->increment(IJ)V
return-void
.end method
.method reportMetrics()V
.registers 2
.line 1
invoke-virtual {p0}, Lcom/amazonaws/metrics/ByteThroughputProvider;->getByteCount()I
move-result v0
if-lez v0, :cond_10
.line 2
invoke-static {}, Lcom/amazonaws/metrics/AwsSdkMetrics;->getServiceMetricCollector()Lcom/amazonaws/metrics/ServiceMetricCollector;
move-result-object v0
.line 3
invoke-virtual {v0, p0}, Lcom/amazonaws/metrics/ServiceMetricCollector;->collectByteThroughput(Lcom/amazonaws/metrics/ByteThroughputProvider;)V
.line 4
invoke-virtual {p0}, Lcom/amazonaws/metrics/ByteThroughputProvider;->reset()V
:cond_10
return-void
.end method
.method startTiming()J
.registers 6
.line 1
sget-object v0, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {p0}, Lcom/amazonaws/metrics/ByteThroughputProvider;->getDurationNano()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toSeconds(J)J
move-result-wide v0
const-wide/16 v2, 0xa
cmp-long v4, v0, v2
if-lez v4, :cond_13
.line 2
invoke-virtual {p0}, Lcom/amazonaws/metrics/ByteThroughputHelper;->reportMetrics()V
.line 3
:cond_13
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
return-wide v0
.end method