ServiceLatencyProvider.smali

.class public Lcom/amazonaws/metrics/ServiceLatencyProvider;
.super Ljava/lang/Object;
.source "ServiceLatencyProvider.java"


# instance fields
.field private endNano:J

.field private final serviceMetricType:Lcom/amazonaws/metrics/ServiceMetricType;

.field private final startNano:J


# direct methods
.method public constructor <init>(Lcom/amazonaws/metrics/ServiceMetricType;)V
    .registers 4

    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 2
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v0

    iput-wide v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->startNano:J

    .line 3
    iget-wide v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->startNano:J

    iput-wide v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endNano:J

    .line 4
    iput-object p1, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->serviceMetricType:Lcom/amazonaws/metrics/ServiceMetricType;

    return-void
.end method


# virtual methods
.method public endTiming()Lcom/amazonaws/metrics/ServiceLatencyProvider;
    .registers 6

    .line 1
    iget-wide v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endNano:J

    iget-wide v2, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->startNano:J

    cmp-long v4, v0, v2

    if-nez v4, :cond_f

    .line 2
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v0

    iput-wide v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endNano:J

    return-object p0

    .line 3
    :cond_f
    new-instance v0, Ljava/lang/IllegalStateException;

    invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V

    throw v0
.end method

.method public getDurationMilli()D
    .registers 6

    .line 1
    iget-wide v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endNano:J

    iget-wide v2, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->startNano:J

    cmp-long v4, v0, v2

    if-nez v4, :cond_13

    .line 2
    const-class v0, Lcom/amazonaws/metrics/ServiceLatencyProvider;

    invoke-static {v0}, Lcom/amazonaws/logging/LogFactory;->getLog(Ljava/lang/Class;)Lcom/amazonaws/logging/Log;

    move-result-object v0

    const-string v1, "Likely to be a missing invocation of endTiming()."

    invoke-interface {v0, v1}, Lcom/amazonaws/logging/Log;->debug(Ljava/lang/Object;)V

    .line 3
    :cond_13
    iget-wide v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->startNano:J

    iget-wide v2, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endNano:J

    invoke-static {v0, v1, v2, v3}, Lcom/amazonaws/util/TimingInfo;->durationMilliOf(JJ)D

    move-result-wide v0

    return-wide v0
.end method

.method public getProviderId()Ljava/lang/String;
    .registers 2

    .line 1
    invoke-super {p0}, Ljava/lang/Object;->toString()Ljava/lang/String;

    move-result-object v0

    return-object v0
.end method

.method public getServiceMetricType()Lcom/amazonaws/metrics/ServiceMetricType;
    .registers 2

    .line 1
    iget-object v0, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->serviceMetricType:Lcom/amazonaws/metrics/ServiceMetricType;

    return-object v0
.end method

.method public toString()Ljava/lang/String;
    .registers 4

    const/4 v0, 0x4

    .line 1
    new-array v0, v0, [Ljava/lang/Object;

    .line 2
    invoke-virtual {p0}, Lcom/amazonaws/metrics/ServiceLatencyProvider;->getProviderId()Ljava/lang/String;

    move-result-object v1

    const/4 v2, 0x0

    aput-object v1, v0, v2

    iget-object v1, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->serviceMetricType:Lcom/amazonaws/metrics/ServiceMetricType;

    const/4 v2, 0x1

    aput-object v1, v0, v2

    iget-wide v1, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->startNano:J

    invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v1

    const/4 v2, 0x2

    aput-object v1, v0, v2

    iget-wide v1, p0, Lcom/amazonaws/metrics/ServiceLatencyProvider;->endNano:J

    invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v1

    const/4 v2, 0x3

    aput-object v1, v0, v2

    const-string v1, "providerId=%s, serviceMetricType=%s, startNano=%d, endNano=%d"

    .line 3
    invoke-static {v1, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v0

    return-object v0
.end method