Timer.smali

.class public Lcom/mopub/common/util/Timer;
.super Ljava/lang/Object;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/mopub/common/util/Timer$State;
    }
.end annotation


# instance fields
.field private mStartTimeNanos:J

.field private mState:Lcom/mopub/common/util/Timer$State;

.field private mStopTimeNanos:J


# direct methods
.method public constructor <init>()V
    .registers 2

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

    .line 16
    sget-object v0, Lcom/mopub/common/util/Timer$State;->STOPPED:Lcom/mopub/common/util/Timer$State;

    iput-object v0, p0, Lcom/mopub/common/util/Timer;->mState:Lcom/mopub/common/util/Timer$State;

    return-void
.end method


# virtual methods
.method public getTime()J
    .registers 6

    .line 35
    iget-object v0, p0, Lcom/mopub/common/util/Timer;->mState:Lcom/mopub/common/util/Timer$State;

    sget-object v1, Lcom/mopub/common/util/Timer$State;->STARTED:Lcom/mopub/common/util/Timer$State;

    if-ne v0, v1, :cond_b

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

    move-result-wide v0

    goto :goto_d

    .line 38
    :cond_b
    iget-wide v0, p0, Lcom/mopub/common/util/Timer;->mStopTimeNanos:J

    .line 40
    :goto_d
    sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;

    iget-wide v3, p0, Lcom/mopub/common/util/Timer;->mStartTimeNanos:J

    sub-long/2addr v0, v3

    sget-object v3, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-virtual {v2, v0, v1, v3}, Ljava/util/concurrent/TimeUnit;->convert(JLjava/util/concurrent/TimeUnit;)J

    move-result-wide v0

    return-wide v0
.end method

.method public start()V
    .registers 3

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

    move-result-wide v0

    iput-wide v0, p0, Lcom/mopub/common/util/Timer;->mStartTimeNanos:J

    .line 22
    sget-object v0, Lcom/mopub/common/util/Timer$State;->STARTED:Lcom/mopub/common/util/Timer$State;

    iput-object v0, p0, Lcom/mopub/common/util/Timer;->mState:Lcom/mopub/common/util/Timer$State;

    return-void
.end method

.method public stop()V
    .registers 3

    .line 26
    iget-object v0, p0, Lcom/mopub/common/util/Timer;->mState:Lcom/mopub/common/util/Timer$State;

    sget-object v1, Lcom/mopub/common/util/Timer$State;->STARTED:Lcom/mopub/common/util/Timer$State;

    if-ne v0, v1, :cond_11

    .line 29
    sget-object v0, Lcom/mopub/common/util/Timer$State;->STOPPED:Lcom/mopub/common/util/Timer$State;

    iput-object v0, p0, Lcom/mopub/common/util/Timer;->mState:Lcom/mopub/common/util/Timer$State;

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

    move-result-wide v0

    iput-wide v0, p0, Lcom/mopub/common/util/Timer;->mStopTimeNanos:J

    return-void

    .line 27
    :cond_11
    new-instance v0, Ljava/lang/IllegalStateException;

    const-string v1, "EventTimer was not started."

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

    throw v0
.end method