lyng/docs/time.md

4.2 KiB

Lyng time functions

Lyng date and time support requires importing lyng.time packages. Lyng uses simple yet modern time object models:

  • Instant class for time stamps with platform-dependent resolution
  • Duration to represent amount of time not depending on the calendar, e.g. in absolute units (milliseconds, seconds, hours, days)

Time instant: Instant

Represent some moment of time not depending on the calendar (calendar for example may b e changed, daylight saving time can be for example introduced or dropped). It is similar to TIMESTAMP in SQL or Instant in Kotlin. Some moment of time; not the calendar date.

Instant is comparable to other Instant. Subtracting instants produce Duration, period in time that is not dependent on the calendar, e.g. absolute time period.

It is possible to add or subtract Duration to and from Instant, that gives another Instant.

Instants are converted to and from Real number of seconds before or after Unix Epoch, 01.01.1970. Constructor with single number parameter constructs from such number of seconds, and any instance provide .epochSeconds member:

import lyng.time

// default constructor returns time now:
val t1 = Instant()
val t2 = Instant()
assert( t2 - t1 < 1.millisecond )
assert( t2.epochSeconds - t1.epochSeconds < 0.001 )
>>> void

Constructing

import lyng.time

// empty constructor gives current time instant using system clock:
val now = Instant()

// constructor with Instant instance makes a copy:
assertEquals( now, Instant(now) )

// constructing from a number is trated as seconds since unix epoch:
val copyOfNow = Instant( now.epochSeconds )

// note that instant resolution is higher that Real can hold
// so reconstructed from real slightly differs:
assert( abs( (copyOfNow - now).milliseconds ) < 0.01 )
>>> void

The resolution of system clock could be more precise and double precision real number of Real, keep it in mind.

Comparing and calculating periods

import lyng.time

val now = Instant()

// you cam add or subtract periods, and compare
assert( now - 5.minutes < now )
val oneHourAgo = now - 1.hour
assertEquals( now, oneHourAgo + 1.hour)

>>> void

Instant members

member description
epochSeconds: Real positive or negative offset in seconds since Unix epoch
isDistantFuture: Bool true if it Instant.distantFuture
isDistantPast: Bool true if it Instant.distantPast

Class members

member description
Instant.distantPast: Instant most distant instant in past
Instant.distantFuture: Instant most distant instant in future

Duraion class

Represent absolute time distance between two Instant.

import lyng.time
val t1 = Instant()

// yes we can delay to period, and it is not blocking. is suspends!
delay(1.millisecond)

val t2 = Instant()
// be suspend, so actual time may vary:
assert( t2 - t1 >= 1.millisecond)
assert( t2 - t1 < 100.millisecond)
>>> void

Duration can be converted from numbers, like 5.minutes and so on. Extensions are created for Int and Real, so for n as Real or Int it is possible to create durations::

  • n.millisecond, n.milliseconds
  • n.second, n.seconds
  • n.minute, n.minutes
  • n.hour, n.hours
  • n.day, n.days

The bigger time units like months or years are calendar-dependent and can't be used with Duration.

Each duration instance can be converted to number of any of these time units, as Real number, if d is a Duration instance:

  • d.milliseconds
  • d.seconds
  • d.minutes
  • d.hours
  • d.days

for example

import lyng.time
assertEquals( 60, 1.minute.seconds )
>>> void

Utility functions

delay(duration: Duration)

Suspends current coroutine for at least the specified duration.