author | wenzelm |
Mon, 11 Sep 2023 19:30:48 +0200 | |
changeset 78659 | b5f3d1051b13 |
parent 78357 | 0cecb7236298 |
child 78888 | 95bbf9a576b3 |
permissions | -rw-r--r-- |
45674 | 1 |
/* Title: Pure/General/time.scala |
40393 | 2 |
Author: Makarius |
3 |
||
45674 | 4 |
Time based on milliseconds. |
40393 | 5 |
*/ |
6 |
||
7 |
package isabelle |
|
8 |
||
45664 | 9 |
|
50298 | 10 |
import java.util.Locale |
64056 | 11 |
import java.time.Instant |
50298 | 12 |
|
13 |
||
75393 | 14 |
object Time { |
47993 | 15 |
def seconds(s: Double): Time = new Time((s * 1000.0).round) |
74158 | 16 |
def minutes(m: Double): Time = new Time((m * 60000.0).round) |
17 |
def ms(ms: Long): Time = new Time(ms) |
|
63700 | 18 |
def hms(h: Int, m: Int, s: Double): Time = seconds(s + 60 * m + 3600 * h) |
63686 | 19 |
|
61528 | 20 |
def now(): Time = ms(System.currentTimeMillis()) |
21 |
||
51587 | 22 |
val zero: Time = ms(0) |
78357 | 23 |
val min: Time = ms(Long.MinValue) |
24 |
val max: Time = ms(Long.MaxValue) |
|
51533 | 25 |
|
26 |
def print_seconds(s: Double): String = |
|
27 |
String.format(Locale.ROOT, "%.3f", s.asInstanceOf[AnyRef]) |
|
64056 | 28 |
|
64058 | 29 |
def instant(t: Instant): Time = ms(t.getEpochSecond * 1000L + t.getNano / 1000000L) |
40393 | 30 |
} |
31 |
||
75393 | 32 |
final class Time private(val ms: Long) extends AnyVal { |
65616 | 33 |
def proper_ms: Option[Long] = if (ms == 0) None else Some(ms) |
34 |
||
40848
8662b9b1f123
more abstract/uniform handling of time, preferring seconds as Double;
wenzelm
parents:
40393
diff
changeset
|
35 |
def seconds: Double = ms / 1000.0 |
63688
cc57255bf6ae
gnuplot presentation similar to former isatest-statistics;
wenzelm
parents:
63686
diff
changeset
|
36 |
def minutes: Double = ms / 60000.0 |
40852 | 37 |
|
56691 | 38 |
def + (t: Time): Time = new Time(ms + t.ms) |
39 |
def - (t: Time): Time = new Time(ms - t.ms) |
|
40 |
||
61602 | 41 |
def compare(t: Time): Int = ms compare t.ms |
56691 | 42 |
def < (t: Time): Boolean = ms < t.ms |
43 |
def <= (t: Time): Boolean = ms <= t.ms |
|
44 |
def > (t: Time): Boolean = ms > t.ms |
|
45 |
def >= (t: Time): Boolean = ms >= t.ms |
|
46 |
||
47 |
def min(t: Time): Time = if (this < t) this else t |
|
48 |
def max(t: Time): Time = if (this > t) this else t |
|
40852 | 49 |
|
53292
f567c1c7b180
option to insert unique completion immediately into buffer;
wenzelm
parents:
51587
diff
changeset
|
50 |
def is_zero: Boolean = ms == 0 |
46768 | 51 |
def is_relevant: Boolean = ms >= 1 |
52 |
||
57912 | 53 |
override def toString: String = Time.print_seconds(seconds) |
46768 | 54 |
|
40848
8662b9b1f123
more abstract/uniform handling of time, preferring seconds as Double;
wenzelm
parents:
40393
diff
changeset
|
55 |
def message: String = toString + "s" |
62571 | 56 |
|
75393 | 57 |
def message_hms: String = { |
62571 | 58 |
val s = ms / 1000 |
59 |
String.format(Locale.ROOT, "%d:%02d:%02d", |
|
71163 | 60 |
java.lang.Long.valueOf(s / 3600), |
61 |
java.lang.Long.valueOf((s / 60) % 60), |
|
62 |
java.lang.Long.valueOf(s % 60)) |
|
62571 | 63 |
} |
64056 | 64 |
|
65 |
def instant: Instant = Instant.ofEpochMilli(ms) |
|
71684 | 66 |
|
73702
7202e12cb324
tuned signature --- following hints by IntelliJ IDEA;
wenzelm
parents:
73385
diff
changeset
|
67 |
def sleep(): Unit = Thread.sleep(ms) |
40848
8662b9b1f123
more abstract/uniform handling of time, preferring seconds as Double;
wenzelm
parents:
40393
diff
changeset
|
68 |
} |