Time¶
Usage
use Time;
or
import Time;
Support for routines related to measuring the passing of time.
This module provides support for querying wall time in the local
timezone and implements a record Timer
that provides basic
stopwatch behavior. The stopwatch has the potential for microsecond
resolution and is intended to be useful for performance testing.
- enum TimeUnits { microseconds, milliseconds, seconds, minutes, hours }¶
Specifies the units to be used when certain functions return a time
- enum Day { sunday = 0, monday, tuesday, wednesday, thursday, friday, saturday }¶
Specifies the day of the week
- enum DayOfWeek { Monday = 0, Tuesday = 1, Wednesday = 2, Thursday = 3, Friday = 4, Saturday = 5, Sunday = 6 }¶
Days in the week, starting with Monday = 0
- enum ISODayOfWeek { Monday = 1, Tuesday = 2, Wednesday = 3, Thursday = 4, Friday = 5, Saturday = 6, Sunday = 7 }¶
Days in the week, starting with Monday = 1
- param MINYEAR = 1¶
The minimum year allowed in date objects
- param MAXYEAR = 9999¶
The maximum year allowed in date objects
- const unixEpoch = new datetime(1970, 1, 1)¶
The Unix Epoch date and time
- proc timeSinceEpoch(): timedelta¶
Get the time since Unix Epoch in seconds
- proc isLeapYear(year: int)¶
Return true if year is a leap year
- proc daysInMonth(year: int, month: int) throws¶
Return the number of days in month month during the year year. The number for a month can change from year to year due to leap years.
- Throws
IllegalArgumentError – Thrown if month is out of range.
- record date¶
A record representing a date
- proc year¶
The year represented by this date value
- proc month¶
The month represented by this date value
- proc day¶
The day represented by this date value
- proc type min¶
The minimum representable date
- proc type max¶
The maximum representable date
- proc type resolution¶
The minimum non-zero difference between two dates
- proc date.init(year, month, day)¶
Initialize a new date value from a year, month, and day. All three arguments are required and must be in valid ranges. The valid ranges are:
1 <= year <= 9999
1 <= month <= 12
1 <= day <= the number of days in the given month and year
- proc type date.today()¶
A date object representing the current day
- proc type date.fromTimestamp(timestamp)¶
The date that is timestamp seconds from the epoch
- proc type date.fromOrdinal(ord)¶
The date that is ord days from 1-1-0001
- proc date.replace(year = 0, month = 0, day = 0)¶
Replace the year, month and/or day in a date to create a new date
- proc date.timetuple()¶
Return a filled record matching the C struct tm type for the given date
- proc date.toOrdinal()¶
Return the number of days since 1-1-0001 this date represents
- proc date.weekday()¶
Return the day of the week as a DayOfWeek. Monday == 0, Sunday == 6
- proc date.isoWeekday()¶
Return the day of the week as an ISODayOfWeek. Monday == 1, Sunday == 7
- proc date.isoCalendar()¶
Return the ISO date as a tuple containing the ISO year, ISO week number, and ISO day of the week
- proc date.isoFormat()¶
Return the date as a string in ISO 8601 format: “YYYY-MM-DD”
- proc date.ctime()¶
Return a string representing the date
- proc date.strftime(fmt: string)¶
Return a formatted string matching the format argument and the date
- proc date.writeThis(f) throws¶
Writes this date in ISO 8601 format: YYYY-MM-DD
- proc date.readThis(f) throws¶
Reads this date from ISO 8601 format: YYYY-MM-DD
- record time¶
A record representing a time
- proc hour¶
The hour represented by this time value
- proc minute¶
The minute represented by this time value
- proc second¶
The second represented by this time value
- proc microsecond¶
The microsecond represented by this time value
- proc tzinfo¶
The timezone represented by this time value
- proc type min¶
The minimum representable time
- proc type max¶
The maximum representable time
- proc type resolution¶
The minimum non-zero difference between two times
- proc time.init(hour = 0, minute = 0, second = 0, microsecond = 0, in tzinfo: shared TZInfo?)¶
Initialize a new time value from the given hour, minute, second, microsecond, and timezone. All arguments are optional
Warning
tzinfo is unstable; its type may change in the future
- proc time.init(hour = 0, minute = 0, second = 0, microsecond = 0)
Initialize a new time value from the given hour, minute, second, microsecond. All arguments are optional
- proc time.replace(hour = -1, minute = -1, second = -1, microsecond = -1)¶
Replace the hour, minute, second, microsecond in a time to create a new time. All arguments are optional.
- proc time.replace(hour = -1, minute = -1, second = -1, microsecond = -1, in tzinfo)
Replace the hour, minute, second, microsecond and tzinfo in a time to create a new time. All arguments are optional.
Warning
tzinfo is unstable; its type may change in the future
- proc time.isoFormat()¶
Return a string representing the time in ISO format
- proc time.utcOffset()¶
Return the offset from UTC
- proc time.dst()¶
Return the daylight saving time offset
- proc time.tzname()¶
Return the name of the timezone for this time value
- proc time.strftime(fmt: string)¶
Return a string matching the format argument for this time
- proc time.writeThis(f) throws¶
Writes this time in ISO format: hh:mm:ss.sss
- proc time.readThis(f) throws¶
Reads this time from ISO format: hh:mm:ss.sss
- record datetime¶
A record representing a combined date and time
- proc type min¶
The minimum representable date and time
- proc type max¶
The maximum representable date and time
- proc type resolution¶
The minimum non-zero difference between two datetimes
- proc year¶
The year represented by this datetime value
- proc month¶
The month represented by this datetime value
- proc day¶
The day represented by this datetime value
- proc hour¶
The hour represented by this datetime value
- proc minute¶
The minute represented by this datetime value
- proc second¶
The second represented by this datetime value
- proc microsecond¶
The microsecond represented by this datetime value
- proc tzinfo¶
The timezone represented by this datetime value
- proc datetime.init(year, month, day, hour = 0, minute = 0, second = 0, microsecond = 0, in tzinfo)¶
Initialize a new datetime value from the given year, month, day, hour, minute, second, microsecond and timezone. The year, month, and day arguments are required, the rest are optional.
Warning
tzinfo is unstable; its type may change in the future
- proc datetime.init(year, month, day, hour = 0, minute = 0, second = 0, microsecond = 0)
Initialize a new datetime value from the given year, month, day, hour, minute, second, microsecond and timezone. The year, month, and day arguments are required, the rest are optional.
- proc datetime.init(d: date, t: time)
Initialize a new datetime value from the given date and time
- proc type datetime.now()¶
Return a datetime value representing the current time and date
- proc type datetime.now(in tz: shared TZInfo?)
Return a datetime value representing the current time and date
- proc type datetime.utcNow()¶
Return a datetime value representing the current time and date in UTC
- proc type datetime.fromTimestamp(timestamp: real)¶
The datetime that is timestamp seconds from the epoch
- proc type datetime.fromTimestamp(timestamp: real, in tz: shared TZInfo?)
The datetime that is timestamp seconds from the epoch
Warning
tzinfo is unstable; its type may change in the future
- proc type datetime.utcFromTimestamp(timestamp)¶
The datetime that is timestamp seconds from the epoch in UTC
- proc type datetime.fromOrdinal(ordinal)¶
The datetime that is ordinal days from 1-1-0001
- proc type datetime.combine(d: date, t: time)¶
Form a datetime value from a given date and time
- proc datetime.getdate()¶
Get the date portion of the datetime value
- proc datetime.gettime()¶
Get the time portion of the datetime value, with tzinfo = nil
- proc datetime.timetz()¶
Get the time portion of the datetime value including the tzinfo field
- proc datetime.replace(year = -1, month = -1, day = -1, hour = -1, minute = -1, second = -1, microsecond = -1, in tzinfo = this.tzinfo)¶
Replace the year, month, day, hour, minute, second, microsecond, or tzinfo to form a new datetime object. All arguments are optional.
- proc datetime.astimezone(in tz: shared TZInfo)¶
Return the date and time converted into the timezone in the argument
Warning
tzinfo is unstable; its type may change in the future
- proc datetime.utcOffset()¶
Return the offset from UTC
- proc datetime.dst()¶
Return the daylight saving time offset
- proc datetime.tzname()¶
Return the name of the timezone for this datetime value
- proc datetime.timetuple()¶
Return a filled record matching the C struct tm type for the given datetime
- proc datetime.utctimetuple()¶
Return a filled record matching the C struct tm type for the given datetime in UTC
- proc datetime.toOrdinal()¶
Return the number of days since 1-1-0001 this datetime represents
- proc datetime.weekday()¶
Return the day of the week as a DayOfWeek. Monday == 0, Sunday == 6
- proc datetime.isoweekday()¶
Return the day of the week as an ISODayOfWeek. Monday == 1, Sunday == 7
- proc datetime.isocalendar()¶
Return the ISO date as a tuple containing the ISO year, ISO week number, and ISO day of the week
- proc datetime.isoFormat(sep = "T")¶
Return the datetime as a string in ISO format
- proc type datetime.strptime(date_string: string, format: string)¶
Create a datetime as described by the date_string and format string. Note that this routine currently only supports the format strings of C’s strptime().
- proc datetime.strftime(fmt: string)¶
Create a string from a datetime matching the format string
- proc datetime.ctime()¶
Return a string from a datetime in the form: Wed Dec 4 20:30:40 2002
- proc datetime.writeThis(f) throws¶
Writes this datetime in ISO format: YYYY-MM-DDThh:mm:ss.sss
- proc datetime.readThis(f) throws¶
Reads this datetime from ISO format: YYYY-MM-DDThh:mm:ss.sss
- record timedelta¶
A record representing an amount of time. A timedelta has fields representing days, seconds, and microseconds. These fields are always kept within the following ranges:
0 <= microseconds < 1000000
0 <= seconds < 60*60*24
-999999999 <= days <= 999999999
It is an overflow error if days is outside the given range.
- proc days¶
The number of days this timedelta represents
- proc seconds¶
The number of seconds this timedelta represents
- proc microseconds¶
The number of microseconds this timedelta represents
- proc type min¶
Return the minimum representable timedelta object.
- proc type max¶
Return the maximum representable timedelta object.
- proc type resolution¶
Return the smallest positive value representable by a timedelta object.
- proc timedelta.init(days = 0, seconds = 0, microseconds = 0, milliseconds = 0, minutes = 0, hours = 0, weeks = 0)¶
Initialize a timedelta object. All arguments are optional and default to 0. Since only days, seconds and microseconds are stored, the other arguments are converted to days, seconds and microseconds.
- proc timedelta.init(timestamp: real)
Create a timedelta from a given number of seconds
- proc timedelta.totalSeconds(): real¶
Return the total number of seconds represented by this object
- proc abs(t: timedelta)¶
Return the absolute value of t. If t is negative, then returns -t, else returns t.
- class TZInfo¶
Abstract base class for time zones. This class should not be used directly, but concrete implementations of time zones should be derived from it.
- proc utcOffset(dt: datetime): timedelta¶
The offset from UTC this class represents
- proc dst(dt: datetime): timedelta¶
The timedelta for daylight saving time
- proc tzname(dt: datetime): string¶
The name of this time zone
- proc fromUtc(dt: datetime): datetime¶
Convert a time in UTC to this time zone
- proc getCurrentTime(unit: TimeUnits = TimeUnits.seconds): real(64)¶
- Arguments
unit :
TimeUnits
– The units for the returned value- Returns
The elapsed time since midnight, local time, in the units specified
- Return type
real(64)
- proc getCurrentDate()¶
- Returns
(year, month, day) as a tuple of 3 ints
The month is in the range 1 to 12. The day is in the range 1 to 31
- proc sleep(t: real, unit: TimeUnits = TimeUnits.seconds): void¶
Delay a task for a duration in the units specified. This function will return without sleeping and emit a warning if the duration is negative.
- Arguments
t : real – The duration for the time to sleep
unit :
TimeUnits
– The units for the duration
- record Timer¶
Implements basic stopwatch behavior with a potential resolution of microseconds if supported by the runtime platform.
The
Timer
can be started, stopped, and cleared. ATimer
is either running or stopped.- proc clear(): void¶
Clears the elapsed time. If the timer is running then it is restarted otherwise it remains in the stopped state.
- proc start(): void¶
Starts the timer. A warning is emitted if the timer is already running.
- proc stop(): void¶
Stops the timer. A warning is emitted if the timer is not running.
- proc elapsed(unit: TimeUnits = TimeUnits.seconds): real¶
Returns the cumulative elapsed time, in the units specified, between all pairs of calls to
start
andstop
since the timer was created or the last call toclear
. If the timer is running, the elapsed time since the last call tostart
is added to the return value.- Arguments
unit :
TimeUnits
– The units for the returned value- Returns
The elapsed time in the units specified
- Return type
real(64)