Additions for Kotlin's date & time library kotlinx-datetime.
kotlinx-datetime is very early stage and not as actively developed as other official libraries. This library keeps adding missing pieces until the official
library catches up.
build.gradle.kts:
dependencies {
implementation("io.fluidsonic.time:fluid-time:0.18.0")
}Clock.toJavaClock(TimeZone)– wraps aClockinto ajava.time.Clock(JVM only)Duration(days, hours, minutes, seconds, nanoseconds)–Durationfactory function using componentsDurationSerializer-kotlinx-serializationserializer forDurationLocalDateOrNull(year, month, day)- likeLocalDate()but returnsnullinstead of throwingLocalTime.max-23:59:59.999999999LocalTime.midnight-00:00LocalTime.min-00:00Timestamp- alias ofInstantfor those who prefer that name (Discussion)(LocalDate|LocalDateTime|LocalTime|Timestamp).parseOrNull(String)- likeparse()but returnsnullinstead of throwingTimeZone.ofOrNull(String)- likeof()but returnsnullinstead of throwingTimestamp.durationSince(Timestamp)/.durationUntil(Timestamp)- getDurationbetween two timestampsTimestamp.toLocalDate(TimeZone)- shortcut for.toLocalDateTime(timeZone).dateTimestamp.toLocalTime(TimeZone)- shortcut for.toLocalDateTime(timeZone).timeTimestamp.toJavaDate(): Date- converts aTimestamptojava.util.Date(JVM only)Month.daysIn(year)- number of days in a given month and yearYear.isLeap(year)- whether a year is a leap yearManualClock- aClockimplementation suitable for unit testing- JVM, JS and Darwin are supported.
linuxX64andmingwX64are not supported.
Before kotlinx-datetime was released this library has provided its own date & time implementations for JVM and Darwin. That work has been discontinued in
favor of using the new official library, even if experimental, with additions provided by this reworked library. Bugfix releases will still be provided if
needed.
You can still use the last previous library version 0.10.5.
Apache 2.0