StopWatch.smali
.class public Lorg/apache/commons/lang3/time/StopWatch;
.super Ljava/lang/Object;
.source "StopWatch.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lorg/apache/commons/lang3/time/StopWatch$SplitState;,
Lorg/apache/commons/lang3/time/StopWatch$State;
}
.end annotation
# static fields
.field private static final NANO_2_MILLIS:J = 0xf4240L
# instance fields
.field private runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
.field private splitState:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
.field private startTime:J
.field private startTimeMillis:J
.field private stopTime:J
# direct methods
.method public constructor <init>()V
.registers 2
.line 162
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 132
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$State;->UNSTARTED:Lorg/apache/commons/lang3/time/StopWatch$State;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
.line 137
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$SplitState;->UNSPLIT:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->splitState:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
return-void
.end method
# virtual methods
.method public getNanoTime()J
.registers 5
.line 338
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->STOPPED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-eq v0, v1, :cond_2c
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->SUSPENDED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_d
goto :goto_2c
.line 340
:cond_d
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->UNSTARTED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_16
const-wide/16 v0, 0x0
return-wide v0
.line 342
:cond_16
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_24
.line 343
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
iget-wide v2, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
:goto_22
sub-long/2addr v0, v2
return-wide v0
.line 345
:cond_24
new-instance v0, Ljava/lang/RuntimeException;
const-string v1, "Illegal running state has occurred."
invoke-direct {v0, v1}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
throw v0
.line 339
:cond_2c
:goto_2c
iget-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
iget-wide v2, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
goto :goto_22
.end method
.method public getSplitNanoTime()J
.registers 5
.line 382
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->splitState:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$SplitState;->SPLIT:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
if-ne v0, v1, :cond_c
.line 385
iget-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
iget-wide v2, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
sub-long/2addr v0, v2
return-wide v0
.line 383
:cond_c
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch must be split to get the split time. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public getSplitTime()J
.registers 5
.line 364
invoke-virtual {p0}, Lorg/apache/commons/lang3/time/StopWatch;->getSplitNanoTime()J
move-result-wide v0
const-wide/32 v2, 0xf4240
div-long/2addr v0, v2
return-wide v0
.end method
.method public getStartTime()J
.registers 3
.line 397
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->UNSTARTED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-eq v0, v1, :cond_9
.line 401
iget-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTimeMillis:J
return-wide v0
.line 398
:cond_9
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch has not been started"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public getTime()J
.registers 5
.line 322
invoke-virtual {p0}, Lorg/apache/commons/lang3/time/StopWatch;->getNanoTime()J
move-result-wide v0
const-wide/32 v2, 0xf4240
div-long/2addr v0, v2
return-wide v0
.end method
.method public isStarted()Z
.registers 2
.line 447
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
invoke-virtual {v0}, Lorg/apache/commons/lang3/time/StopWatch$State;->isStarted()Z
move-result v0
return v0
.end method
.method public isStopped()Z
.registers 2
.line 475
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
invoke-virtual {v0}, Lorg/apache/commons/lang3/time/StopWatch$State;->isStopped()Z
move-result v0
return v0
.end method
.method public isSuspended()Z
.registers 2
.line 460
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
invoke-virtual {v0}, Lorg/apache/commons/lang3/time/StopWatch$State;->isSuspended()Z
move-result v0
return v0
.end method
.method public reset()V
.registers 2
.line 222
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$State;->UNSTARTED:Lorg/apache/commons/lang3/time/StopWatch$State;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
.line 223
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$SplitState;->UNSPLIT:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->splitState:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
return-void
.end method
.method public resume()V
.registers 7
.line 302
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->SUSPENDED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_17
.line 305
iget-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v2
iget-wide v4, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
sub-long/2addr v2, v4
add-long/2addr v0, v2
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
.line 306
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
return-void
.line 303
:cond_17
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch must be suspended to resume. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public split()V
.registers 3
.line 240
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_11
.line 243
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
.line 244
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$SplitState;->SPLIT:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->splitState:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
return-void
.line 241
:cond_11
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch is not running. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public start()V
.registers 3
.line 178
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->STOPPED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-eq v0, v1, :cond_25
.line 181
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->UNSTARTED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_1d
.line 184
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
.line 185
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTimeMillis:J
.line 186
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
return-void
.line 182
:cond_1d
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch already started. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 179
:cond_25
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch must be reset before being restarted. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public stop()V
.registers 3
.line 203
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
if-eq v0, v1, :cond_15
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->SUSPENDED:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_d
goto :goto_15
.line 204
:cond_d
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch is not running. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.line 206
:cond_15
:goto_15
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_21
.line 207
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
.line 209
:cond_21
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$State;->STOPPED:Lorg/apache/commons/lang3/time/StopWatch$State;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
return-void
.end method
.method public suspend()V
.registers 3
.line 281
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
if-ne v0, v1, :cond_11
.line 284
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v0
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
.line 285
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$State;->SUSPENDED:Lorg/apache/commons/lang3/time/StopWatch$State;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->runningState:Lorg/apache/commons/lang3/time/StopWatch$State;
return-void
.line 282
:cond_11
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch must be running to suspend. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public toSplitString()Ljava/lang/String;
.registers 3
.line 433
invoke-virtual {p0}, Lorg/apache/commons/lang3/time/StopWatch;->getSplitTime()J
move-result-wide v0
invoke-static {v0, v1}, Lorg/apache/commons/lang3/time/DurationFormatUtils;->formatDurationHMS(J)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public toString()Ljava/lang/String;
.registers 3
.line 417
invoke-virtual {p0}, Lorg/apache/commons/lang3/time/StopWatch;->getTime()J
move-result-wide v0
invoke-static {v0, v1}, Lorg/apache/commons/lang3/time/DurationFormatUtils;->formatDurationHMS(J)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public unsplit()V
.registers 3
.line 261
iget-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->splitState:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$SplitState;->SPLIT:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
if-ne v0, v1, :cond_b
.line 264
sget-object v0, Lorg/apache/commons/lang3/time/StopWatch$SplitState;->UNSPLIT:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
iput-object v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->splitState:Lorg/apache/commons/lang3/time/StopWatch$SplitState;
return-void
.line 262
:cond_b
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Stopwatch has not been split. "
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method