sdatetime.md 4.2 KB


id: sdatetime title: SDateTime

sidebar_label: SDateTime

A basic DateTime struct.

Fields

Field year:Int

The year.


Field month:Int

The month, 1-12.


Field day:Int

The day of the month, 1-31.


Field hour:Int

The hour, 0-23.


Field minute:Int

The minute, 0-59.


Field second:Int

The second, 0-59.


Field millisecond:Int

The millisecond, 0-999.


Field utc:Int

True if the date time is in UTC, False if it is in local time.


Field offset:Int

The offset from UTC, in minutes.


Field dst:Int = -1

1 if the date time is observing daylight savings time, 0 if not and -1 if it is not known.

Daylight Saving Time (DST) is the practice of setting the clock ahead by one hour from standard time during the warmer months, and then back again in the fall, in order to extend evening daylight and reduce the need for artificial lighting. This can affect local time calculations, and so it's important to track whether a given datetime object is observing DST. Note that not all regions observe DST, and the start and end dates for DST can vary from one region to another.


Constructors

Method New(year:Int, month:Int, day:Int, hour:Int, minute:Int, second:Int, millisecond:Int = 0, utc:Int = True, offset:Int = 0, dst:Int = -1)

Creates a new SDateTime instance from the given date and time information.


Methods

Method ToString:String()

Returns a string representation of the date time in ISO 8601 format.

Without millisecond precision.


Method ToIso8601:String(showMillis:Int = False)

Returns a string representation in ISO 8601 format.

ISO 8601 is an international standard covering the exchange of date- and time-related data. It was issued by the International Organization for Standardization (ISO) and provides a well-defined method of representing dates and times in a way that avoids ambiguity.

An example of a date in ISO 8601 format is "2023-06-24T18:30:00Z", representing 6:30 pm on June 24, 2023, in Coordinated Universal Time (UTC).

If showMillis is set to True, the output string will include millisecond precision. For instance, "2023-06-24T18:30:00.123Z" where "123" represents milliseconds.


Method ToEpochSecs:Long()

Converts the current date and time to the number of seconds that have elapsed since the Unix Epoch.

The 'epoch' refers to the Unix epoch, which is a system for describing a point in time, defined as the number of seconds that have elapsed since 00:00:00 Coordinated Universal Time (UTC), Thursday, 1 January 1970, minus the number of leap seconds.

Returns

The number of seconds that have elapsed since the Unix Epoch, or -1 if the conversion failed.


Method ToUtc:SDateTime()

Converts the current date time to the equivalent in UTC.

Returns

The equivalent date time in UTC, or the original date time if the conversion failed.


Method DayOfWeek:EWeekday()

Returns the day of the week for the current date.

This method uses Zeller's Congruence algorithm to calculate the day of the week.

Returns

An enumeration representing the day of the week.


Functions

Function FromEpoch:SDateTime(epochSecs:Long, fracNanoSecs:Long = 0, isLocal:Int = False)

Returns an instance of SDateTime representing the date and time corresponding to the given epoch timestamp.

The 'epoch' refers to the Unix epoch, which is a system for describing a point in time, defined as the number of seconds that have elapsed since 00:00:00 Coordinated Universal Time (UTC), Thursday, 1 January 1970, minus the number of leap seconds.

If fracNanoSecs is provided, it will be used to set the 'millisecond' field of the SDateTime instance. The nanosecond fraction is effectively divided by a million to provide millisecond precision. If isLocal is set to True, the epoch timestamp is assumed to be in local time, otherwise it is assumed to be in UTC.