author | wenzelm |
Thu, 03 Mar 2022 17:30:43 +0100 | |
changeset 75206 | 481ad7da73a9 |
parent 74158 | 1cb0ad6f9a2d |
child 75393 | 87ebf5a50283 |
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 |
||
40848
8662b9b1f123
more abstract/uniform handling of time, preferring seconds as Double;
wenzelm
parents:
40393
diff
changeset
|
14 |
object Time |
40393 | 15 |
{ |
47993 | 16 |
def seconds(s: Double): Time = new Time((s * 1000.0).round) |
74158 | 17 |
def minutes(m: Double): Time = new Time((m * 60000.0).round) |
18 |
def ms(ms: Long): Time = new Time(ms) |
|
63700 | 19 |
def hms(h: Int, m: Int, s: Double): Time = seconds(s + 60 * m + 3600 * h) |
63686 | 20 |
|
61528 | 21 |
def now(): Time = ms(System.currentTimeMillis()) |
22 |
||
51587 | 23 |
val zero: Time = ms(0) |
51533 | 24 |
|
25 |
def print_seconds(s: Double): String = |
|
26 |
String.format(Locale.ROOT, "%.3f", s.asInstanceOf[AnyRef]) |
|
64056 | 27 |
|
64058 | 28 |
def instant(t: Instant): Time = ms(t.getEpochSecond * 1000L + t.getNano / 1000000L) |
40393 | 29 |
} |
30 |
||
56351 | 31 |
final class Time private(val ms: Long) extends AnyVal |
40848
8662b9b1f123
more abstract/uniform handling of time, preferring seconds as Double;
wenzelm
parents:
40393
diff
changeset
|
32 |
{ |
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 |
|
57 |
def message_hms: String = |
|
58 |
{ |
|
59 |
val s = ms / 1000 |
|
60 |
String.format(Locale.ROOT, "%d:%02d:%02d", |
|
71163 | 61 |
java.lang.Long.valueOf(s / 3600), |
62 |
java.lang.Long.valueOf((s / 60) % 60), |
|
63 |
java.lang.Long.valueOf(s % 60)) |
|
62571 | 64 |
} |
64056 | 65 |
|
66 |
def instant: Instant = Instant.ofEpochMilli(ms) |
|
71684 | 67 |
|
73702
7202e12cb324
tuned signature --- following hints by IntelliJ IDEA;
wenzelm
parents:
73385
diff
changeset
|
68 |
def sleep(): Unit = Thread.sleep(ms) |
40848
8662b9b1f123
more abstract/uniform handling of time, preferring seconds as Double;
wenzelm
parents:
40393
diff
changeset
|
69 |
} |