562 lines
15 KiB
Smali
562 lines
15 KiB
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
|
|
.locals 1
|
|
|
|
.line 1
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
.line 2
|
|
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 3
|
|
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 static createStarted()Lorg/apache/commons/lang3/time/StopWatch;
|
|
.locals 1
|
|
|
|
.line 1
|
|
new-instance v0, Lorg/apache/commons/lang3/time/StopWatch;
|
|
|
|
invoke-direct {v0}, Lorg/apache/commons/lang3/time/StopWatch;-><init>()V
|
|
|
|
.line 2
|
|
invoke-virtual {v0}, Lorg/apache/commons/lang3/time/StopWatch;->start()V
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public getNanoTime()J
|
|
.locals 4
|
|
|
|
.line 1
|
|
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_3
|
|
|
|
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->SUSPENDED:Lorg/apache/commons/lang3/time/StopWatch$State;
|
|
|
|
if-ne v0, v1, :cond_0
|
|
|
|
goto :goto_1
|
|
|
|
.line 2
|
|
:cond_0
|
|
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->UNSTARTED:Lorg/apache/commons/lang3/time/StopWatch$State;
|
|
|
|
if-ne v0, v1, :cond_1
|
|
|
|
const-wide/16 v0, 0x0
|
|
|
|
return-wide v0
|
|
|
|
.line 3
|
|
:cond_1
|
|
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->RUNNING:Lorg/apache/commons/lang3/time/StopWatch$State;
|
|
|
|
if-ne v0, v1, :cond_2
|
|
|
|
.line 4
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v0
|
|
|
|
iget-wide v2, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
|
|
|
|
:goto_0
|
|
sub-long/2addr v0, v2
|
|
|
|
return-wide v0
|
|
|
|
.line 5
|
|
:cond_2
|
|
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 6
|
|
:cond_3
|
|
:goto_1
|
|
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_0
|
|
.end method
|
|
|
|
.method public getSplitNanoTime()J
|
|
.locals 4
|
|
|
|
.line 1
|
|
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_0
|
|
|
|
.line 2
|
|
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 3
|
|
:cond_0
|
|
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
|
|
.locals 4
|
|
|
|
.line 1
|
|
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
|
|
.locals 2
|
|
|
|
.line 1
|
|
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_0
|
|
|
|
.line 2
|
|
iget-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTimeMillis:J
|
|
|
|
return-wide v0
|
|
|
|
.line 3
|
|
:cond_0
|
|
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
|
|
.locals 4
|
|
|
|
.line 1
|
|
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 getTime(Ljava/util/concurrent/TimeUnit;)J
|
|
.locals 3
|
|
|
|
.line 2
|
|
invoke-virtual {p0}, Lorg/apache/commons/lang3/time/StopWatch;->getNanoTime()J
|
|
|
|
move-result-wide v0
|
|
|
|
sget-object v2, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;
|
|
|
|
invoke-virtual {p1, v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->convert(JLjava/util/concurrent/TimeUnit;)J
|
|
|
|
move-result-wide v0
|
|
|
|
return-wide v0
|
|
.end method
|
|
|
|
.method public isStarted()Z
|
|
.locals 1
|
|
|
|
.line 1
|
|
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
|
|
.locals 1
|
|
|
|
.line 1
|
|
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
|
|
.locals 1
|
|
|
|
.line 1
|
|
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
|
|
.locals 1
|
|
|
|
.line 1
|
|
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 2
|
|
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
|
|
.locals 6
|
|
|
|
.line 1
|
|
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_0
|
|
|
|
.line 2
|
|
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 v2, v0
|
|
|
|
iput-wide v2, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
|
|
|
|
.line 3
|
|
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 4
|
|
:cond_0
|
|
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
|
|
.locals 2
|
|
|
|
.line 1
|
|
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_0
|
|
|
|
.line 2
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v0
|
|
|
|
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
|
|
|
|
.line 3
|
|
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 4
|
|
:cond_0
|
|
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
|
|
.locals 2
|
|
|
|
.line 1
|
|
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_1
|
|
|
|
.line 2
|
|
sget-object v1, Lorg/apache/commons/lang3/time/StopWatch$State;->UNSTARTED:Lorg/apache/commons/lang3/time/StopWatch$State;
|
|
|
|
if-ne v0, v1, :cond_0
|
|
|
|
.line 3
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v0
|
|
|
|
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTime:J
|
|
|
|
.line 4
|
|
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
|
|
|
|
move-result-wide v0
|
|
|
|
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->startTimeMillis:J
|
|
|
|
.line 5
|
|
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 6
|
|
:cond_0
|
|
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 7
|
|
:cond_1
|
|
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
|
|
.locals 3
|
|
|
|
.line 1
|
|
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_1
|
|
|
|
sget-object v2, Lorg/apache/commons/lang3/time/StopWatch$State;->SUSPENDED:Lorg/apache/commons/lang3/time/StopWatch$State;
|
|
|
|
if-ne v0, v2, :cond_0
|
|
|
|
goto :goto_0
|
|
|
|
.line 2
|
|
:cond_0
|
|
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
|
|
|
|
:cond_1
|
|
:goto_0
|
|
if-ne v0, v1, :cond_2
|
|
|
|
.line 3
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v0
|
|
|
|
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
|
|
|
|
.line 4
|
|
:cond_2
|
|
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
|
|
.locals 2
|
|
|
|
.line 1
|
|
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_0
|
|
|
|
.line 2
|
|
invoke-static {}, Ljava/lang/System;->nanoTime()J
|
|
|
|
move-result-wide v0
|
|
|
|
iput-wide v0, p0, Lorg/apache/commons/lang3/time/StopWatch;->stopTime:J
|
|
|
|
.line 3
|
|
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 4
|
|
:cond_0
|
|
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;
|
|
.locals 2
|
|
|
|
.line 1
|
|
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;
|
|
.locals 2
|
|
|
|
.line 1
|
|
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
|
|
.locals 2
|
|
|
|
.line 1
|
|
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_0
|
|
|
|
.line 2
|
|
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 3
|
|
:cond_0
|
|
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
|