src/Pure/General/time.scala
author wenzelm
Sat, 22 Feb 2014 20:52:43 +0100
changeset 55672 5e25cc741ab9
parent 53292 f567c1c7b180
child 56351 1c735e46acf0
permissions -rw-r--r--
support for completion within the formal context; tuned signature;

/*  Title:      Pure/General/time.scala
    Module:     PIDE
    Author:     Makarius

Time based on milliseconds.
*/

package isabelle


import java.util.Locale


object Time
{
  def seconds(s: Double): Time = new Time((s * 1000.0).round)
  def ms(m: Long): Time = new Time(m)
  val zero: Time = ms(0)

  def print_seconds(s: Double): String =
    String.format(Locale.ROOT, "%.3f", s.asInstanceOf[AnyRef])
}

final class Time private(val ms: Long)
{
  def + (t: Time): Time = new Time(ms + t.ms)

  def seconds: Double = ms / 1000.0

  def min(t: Time): Time = if (ms < t.ms) this else t
  def max(t: Time): Time = if (ms > t.ms) this else t

  def is_zero: Boolean = ms == 0
  def is_relevant: Boolean = ms >= 1

  override def hashCode: Int = ms.hashCode
  override def equals(that: Any): Boolean =
    that match {
      case other: Time => ms == other.ms
      case _ => false
    }

  override def toString = Time.print_seconds(seconds)

  def message: String = toString + "s"
}