Represents a date and time with components for Year, Month, Day, Hour, Minute, Second, and Nanosecond.
Instances For
- Std.Time.PlainDateTime.instHAddDuration
- Std.Time.PlainDateTime.instHAddOffset
- Std.Time.PlainDateTime.instHAddOffset_1
- Std.Time.PlainDateTime.instHAddOffset_2
- Std.Time.PlainDateTime.instHAddOffset_3
- Std.Time.PlainDateTime.instHAddOffset_4
- Std.Time.PlainDateTime.instHAddOffset_5
- Std.Time.PlainDateTime.instHAddOffset_6
- Std.Time.PlainDateTime.instHSubDuration
- Std.Time.PlainDateTime.instHSubOffset
- Std.Time.PlainDateTime.instHSubOffset_1
- Std.Time.PlainDateTime.instHSubOffset_2
- Std.Time.PlainDateTime.instHSubOffset_3
- Std.Time.PlainDateTime.instHSubOffset_4
- Std.Time.PlainDateTime.instHSubOffset_5
- Std.Time.PlainDateTime.instHSubOffset_6
- Std.Time.PlainDateTime.instRepr
- Std.Time.PlainDateTime.instToString
- Std.Time.instInhabitedPlainDateTime
- Std.Time.instLawfulEqOrdPlainDateTime
- Std.Time.instOrdPlainDateTime
- Std.Time.instReprPlainDateTime
- Std.Time.instTransOrdPlainDateTime
Equations
- Std.Time.instInhabitedPlainDateTime = { default := { date := default, time := default } }
Equations
- Std.Time.instReprPlainDateTime = { reprPrec := Std.Time.reprPlainDateTime✝ }
Equations
- Std.Time.instOrdPlainDateTime = { compare := compareLex (compareOn fun (x : Std.Time.PlainDateTime) => x.date) (compareOn fun (x : Std.Time.PlainDateTime) => x.time) }
Converts a PlainDateTime
to a Timestamp
Equations
- One or more equations did not get rendered due to their size.
Converts a Timestamp
to a PlainDateTime
.
Equations
- One or more equations did not get rendered due to their size.
Converts a PlainDateTime
to the number of days since the UNIX epoch.
Equations
- Std.Time.PlainDateTime.ofDaysSinceUNIXEpoch days time = { date := Std.Time.PlainDate.ofDaysSinceUNIXEpoch days, time := time }
Sets the PlainDateTime
to the specified desiredWeekday
.
Equations
- dt.withWeekday desiredWeekday = { date := dt.date.withWeekday desiredWeekday, time := dt.time }
Creates a new PlainDateTime
by adjusting the day of the month to the given days
value, with any
out-of-range days clipped to the nearest valid date.
Equations
- dt.withDaysClip days = { date := Std.Time.PlainDate.ofYearMonthDayClip dt.date.year dt.date.month days, time := dt.time }
Creates a new PlainDateTime
by adjusting the day of the month to the given days
value, with any
out-of-range days rolled over to the next month or year as needed.
Equations
- dt.withDaysRollOver days = { date := Std.Time.PlainDate.rollOver dt.date.year dt.date.month days, time := dt.time }
Creates a new PlainDateTime
by adjusting the month to the given month
value, with any
out-of-range days clipped to the nearest valid date.
Equations
- dt.withMonthClip month = { date := Std.Time.PlainDate.ofYearMonthDayClip dt.date.year month dt.date.day, time := dt.time }
Creates a new PlainDateTime
by adjusting the month to the given month
value.
The day is rolled over to the next valid month if necessary.
Equations
- dt.withMonthRollOver month = { date := Std.Time.PlainDate.rollOver dt.date.year month dt.date.day, time := dt.time }
Creates a new PlainDateTime
by adjusting the year to the given year
value. The month and day
remain unchanged, with any out-of-range days clipped to the nearest valid date.
Equations
- dt.withYearClip year = { date := Std.Time.PlainDate.ofYearMonthDayClip year dt.date.month dt.date.day, time := dt.time }
Creates a new PlainDateTime
by adjusting the year to the given year
value. The month and day are rolled
over to the next valid month and day if necessary.
Equations
- dt.withYearRollOver year = { date := Std.Time.PlainDate.rollOver year dt.date.month dt.date.day, time := dt.time }
Creates a new PlainDateTime
by adjusting the hour
component of its time
to the given value.
Creates a new PlainDateTime
by adjusting the minute
component of its time
to the given value.
Equations
- dt.withMinutes minute = { date := dt.date, time := let __src := dt.time; { hour := __src.hour, minute := minute, second := __src.second, nanosecond := __src.nanosecond } }
Creates a new PlainDateTime
by adjusting the second
component of its time
to the given value.
Equations
- dt.withSeconds second = { date := dt.date, time := let __src := dt.time; { hour := __src.hour, minute := __src.minute, second := second, nanosecond := __src.nanosecond } }
Creates a new PlainDateTime
by adjusting the milliseconds component inside the nano
component of its time
to the given value.
Equations
- dt.withMilliseconds millis = { date := dt.date, time := dt.time.withMilliseconds millis }
Creates a new PlainDateTime
by adjusting the nano
component of its time
to the given value.
Equations
- dt.withNanoseconds nano = { date := dt.date, time := dt.time.withNanoseconds nano }
Adds a Day.Offset
to a PlainDateTime
.
Subtracts a Day.Offset
from a PlainDateTime
.
Adds a Week.Offset
to a PlainDateTime
.
Subtracts a Week.Offset
from a PlainDateTime
.
Adds a Month.Offset
to a PlainDateTime
, adjusting the day to the last valid day of the resulting
month.
Equations
- dt.addMonthsClip months = { date := dt.date.addMonthsClip months, time := dt.time }
Subtracts Month.Offset
from a PlainDateTime
, it clips the day to the last valid day of that month.
Equations
- dt.subMonthsClip months = { date := dt.date.subMonthsClip months, time := dt.time }
Adds a Month.Offset
to a PlainDateTime
, rolling over excess days to the following month if needed.
Equations
- dt.addMonthsRollOver months = { date := dt.date.addMonthsRollOver months, time := dt.time }
Subtracts a Month.Offset
from a PlainDateTime
, adjusting the day to the last valid day of the
resulting month.
Equations
- dt.subMonthsRollOver months = { date := dt.date.subMonthsRollOver months, time := dt.time }
Adds a Month.Offset
to a PlainDateTime
, rolling over excess days to the following month if needed.
Equations
- dt.addYearsRollOver years = { date := dt.date.addYearsRollOver years, time := dt.time }
Subtracts a Month.Offset
from a PlainDateTime
, rolling over excess days to the following month if
needed.
Equations
- dt.addYearsClip years = { date := dt.date.addYearsClip years, time := dt.time }
Subtracts a Year.Offset
from a PlainDateTime
, this function rolls over any excess days into the
following month.
Equations
- dt.subYearsRollOver years = { date := dt.date.subYearsRollOver years, time := dt.time }
Subtracts a Year.Offset
from a PlainDateTime
, adjusting the day to the last valid day of the
resulting month.
Equations
- dt.subYearsClip years = { date := dt.date.subYearsClip years, time := dt.time }
Adds a Nanosecond.Offset
to a PlainDateTime
, adjusting the seconds, minutes, hours, and date if the nanoseconds overflow.
Equations
- dt.addNanoseconds nanos = Std.Time.PlainDateTime.ofTimestampAssumingUTC (dt.toTimestampAssumingUTC + nanos)
Subtracts a Nanosecond.Offset
from a PlainDateTime
, adjusting the seconds, minutes, hours, and date if the nanoseconds underflow.
Equations
- dt.subNanoseconds nanos = dt.addNanoseconds (-nanos)
Adds an Hour.Offset
to a PlainDateTime
, adjusting the date if the hour overflows.
Equations
- dt.addHours hours = dt.addNanoseconds hours.toNanoseconds
Subtracts an Hour.Offset
from a PlainDateTime
, adjusting the date if the hour underflows.
Adds a Minute.Offset
to a PlainDateTime
, adjusting the hour and date if the minutes overflow.
Equations
- dt.addMinutes minutes = dt.addNanoseconds minutes.toNanoseconds
Subtracts a Minute.Offset
from a PlainDateTime
, adjusting the hour and date if the minutes underflow.
Equations
- dt.subMinutes minutes = dt.addMinutes (-minutes)
Adds a Second.Offset
to a PlainDateTime
, adjusting the minute, hour, and date if the seconds overflow.
Equations
- dt.addSeconds seconds = dt.addNanoseconds seconds.toNanoseconds
Subtracts a Second.Offset
from a PlainDateTime
, adjusting the minute, hour, and date if the seconds underflow.
Equations
- dt.subSeconds seconds = dt.addSeconds (-seconds)
Adds a Millisecond.Offset
to a PlainDateTime
, adjusting the second, minute, hour, and date if the milliseconds overflow.
Equations
- dt.addMilliseconds milliseconds = dt.addNanoseconds milliseconds.toNanoseconds
Subtracts a Millisecond.Offset
from a PlainDateTime
, adjusting the second, minute, hour, and date if the milliseconds underflow.
Equations
- dt.subMilliseconds milliseconds = dt.addMilliseconds (-milliseconds)
Getter for the Year
inside of a PlainDateTime
.
Getter for the Month
inside of a PlainDateTime
.
Getter for the Day
inside of a PlainDateTime
.
Getter for the Weekday
inside of a PlainDateTime
.
Getter for the Hour
inside of a PlainDateTime
.
Getter for the Minute
inside of a PlainDateTime
.
Getter for the Millisecond
inside of a PlainDateTime
.
Equations
- dt.millisecond = dt.time.millisecond
Getter for the Second
inside of a PlainDateTime
.
Getter for the Nanosecond.Ordinal
inside of a PlainDateTime
.
Equations
- dt.nanosecond = dt.time.nanosecond
Determines the era of the given PlainDateTime
based on its year.
Determines the week of the year for the given PlainDateTime
.
Equations
- date.weekOfYear = date.date.weekOfYear
Returns the unaligned week of the month for a PlainDateTime
(day divided by 7, plus 1).
Equations
- date.weekOfMonth = date.date.weekOfMonth
Determines the week of the month for the given PlainDateTime
. The week of the month is calculated based
on the day of the month and the weekday. Each week starts on Monday because the entire library is
based on the Gregorian Calendar.
Equations
- date.alignedWeekOfMonth = date.date.alignedWeekOfMonth
Transforms a tuple of a PlainDateTime
into a Day.Ordinal.OfYear
.
Determines the quarter of the year for the given PlainDateTime
.
Combines a PlainDate
and PlainTime
into a PlainDateTime
.
Combines a PlainTime
and PlainDate
into a PlainDateTime
.
Equations
- Std.Time.PlainDateTime.atDate time date = { date := date, time := time }
Equations
- Std.Time.PlainDateTime.instHAddDuration = { hAdd := fun (x : Std.Time.PlainDateTime) (y : Std.Time.Duration) => x.addNanoseconds y.toNanoseconds }
Combines a PlainDate
and PlainTime
into a PlainDateTime
.
Combines a PlainTime
and PlainDate
into a PlainDateTime
.