diff --git a/README.md b/README.md index a30126eeb..6f912dc33 100644 --- a/README.md +++ b/README.md @@ -108,7 +108,7 @@ val datetimeInSystemZone: LocalDateTime = currentMoment.toLocalDateTime(TimeZone ``` A `LocalDateTime` instance exposes familiar components of the Gregorian calendar: -`year`, `month`, `dayOfMonth`, `hour`, and so on up to `nanosecond`. +`year`, `month`, `day`, `hour`, and so on up to `nanosecond`. The property `dayOfWeek` shows what weekday that date is, and `dayOfYear` shows the day number since the beginning of a year. @@ -210,7 +210,7 @@ can define their own format or use some of the predefined ones: val dateFormat = LocalDate.Format { monthNumber(padding = Padding.SPACE) char('/') - dayOfMonth() + day() char(' ') year() } diff --git a/core/common/src/LocalDate.kt b/core/common/src/LocalDate.kt index 0146d6f95..c6f4edbfb 100644 --- a/core/common/src/LocalDate.kt +++ b/core/common/src/LocalDate.kt @@ -8,6 +8,7 @@ package kotlinx.datetime import kotlinx.datetime.format.* import kotlinx.datetime.serializers.* import kotlinx.serialization.Serializable +import kotlin.internal.* /** * The date part of [LocalDateTime]. @@ -96,7 +97,7 @@ public expect class LocalDate : Comparable { * Creates a new format for parsing and formatting [LocalDate] values. * * Only parsing and formatting of well-formed values is supported. If the input does not fit the boundaries - * (for example, [dayOfMonth] is 31 for February), consider using [DateTimeComponents.Format] instead. + * (for example, [day] is 31 for February), consider using [DateTimeComponents.Format] instead. * * There is a collection of predefined formats in [LocalDate.Formats]. * @@ -157,19 +158,19 @@ public expect class LocalDate : Comparable { /** * Constructs a [LocalDate] instance from the given date components. * - * The components [monthNumber] and [dayOfMonth] are 1-based. + * The components [month] and [day] are 1-based. * * The supported ranges of components: * - [year] the range is platform-dependent, but at least is enough to represent dates of all instants between * [Instant.DISTANT_PAST] and [Instant.DISTANT_FUTURE] - * - [monthNumber] `1..12` - * - [dayOfMonth] `1..31`, the upper bound can be less, depending on the month + * - [month] `1..12` + * - [day] `1..31`, the upper bound can be less, depending on the month * - * @throws IllegalArgumentException if any parameter is out of range or if [dayOfMonth] is invalid for the + * @throws IllegalArgumentException if any parameter is out of range or if [day] is invalid for the * given [monthNumber] and [year]. * @sample kotlinx.datetime.test.samples.LocalDateSamples.constructorFunctionMonthNumber */ - public constructor(year: Int, monthNumber: Int, dayOfMonth: Int) + public constructor(year: Int, month: Int, day: Int) /** * Constructs a [LocalDate] instance from the given date components. @@ -178,13 +179,13 @@ public expect class LocalDate : Comparable { * - [year] the range is platform-dependent, but at least is enough to represent dates of all instants between * [Instant.DISTANT_PAST] and [Instant.DISTANT_FUTURE] * - [month] all values of the [Month] enum - * - [dayOfMonth] `1..31`, the upper bound can be less, depending on the month + * - [day] `1..31`, the upper bound can be less, depending on the month * - * @throws IllegalArgumentException if any parameter is out of range or if [dayOfMonth] is invalid for the + * @throws IllegalArgumentException if any parameter is out of range or if [day] is invalid for the * given [month] and [year]. * @sample kotlinx.datetime.test.samples.LocalDateSamples.constructorFunction */ - public constructor(year: Int, month: Month, dayOfMonth: Int) + public constructor(year: Int, month: Month, day: Int) /** * Returns the year component of the date. @@ -193,11 +194,8 @@ public expect class LocalDate : Comparable { */ public val year: Int - /** - * Returns the number-of-the-month (1..12) component of the date. - * - * Shortcut for `month.number`. - */ + /** @suppress */ + @Deprecated("Use the 'month' property instead", ReplaceWith("this.month.number"), level = DeprecationLevel.WARNING) public val monthNumber: Int /** @@ -210,8 +208,12 @@ public expect class LocalDate : Comparable { /** * Returns the day-of-month (`1..31`) component of the date. * - * @sample kotlinx.datetime.test.samples.LocalDateSamples.dayOfMonth + * @sample kotlinx.datetime.test.samples.LocalDateSamples.day */ + public val day: Int + + /** @suppress */ + @Deprecated("Use the 'day' property instead", ReplaceWith("this.day"), level = DeprecationLevel.WARNING) public val dayOfMonth: Int /** @@ -259,6 +261,32 @@ public expect class LocalDate : Comparable { public override fun toString(): String } +/** + * @suppress + */ +@Deprecated( + "Use the constructor that accepts a 'month' and a 'day'", + ReplaceWith("LocalDate(year = year, month = monthNumber, day = dayOfMonth)"), + level = DeprecationLevel.WARNING +) +@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE") +@LowPriorityInOverloadResolution +public fun LocalDate(year: Int, monthNumber: Int, dayOfMonth: Int): LocalDate = + LocalDate(year = year, month = monthNumber, day = dayOfMonth) + +/** + * @suppress + */ +@Deprecated( + "Use the constructor that accepts a 'day'", + ReplaceWith("LocalDate(year = year, month = month, day = dayOfMonth)"), + level = DeprecationLevel.WARNING +) +@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE") +@LowPriorityInOverloadResolution +public fun LocalDate(year: Int, month: Month, dayOfMonth: Int): LocalDate = + LocalDate(year = year, month = month, day = dayOfMonth) + /** * Formats this value using the given [format]. * Equivalent to calling [DateTimeFormat.format] on [format] with `this`. @@ -287,7 +315,7 @@ public fun String.toLocalDate(): LocalDate = LocalDate.parse(this) * @sample kotlinx.datetime.test.samples.LocalDateSamples.atTimeInline */ public fun LocalDate.atTime(hour: Int, minute: Int, second: Int = 0, nanosecond: Int = 0): LocalDateTime = - LocalDateTime(year, monthNumber, dayOfMonth, hour, minute, second, nanosecond) + LocalDateTime(year, month.number, day, hour, minute, second, nanosecond) /** * Combines this date's components with the specified [LocalTime] components into a [LocalDateTime] value. diff --git a/core/common/src/LocalDateTime.kt b/core/common/src/LocalDateTime.kt index dad1a2c28..664d83d82 100644 --- a/core/common/src/LocalDateTime.kt +++ b/core/common/src/LocalDateTime.kt @@ -9,6 +9,7 @@ import kotlinx.datetime.format.* import kotlinx.datetime.serializers.LocalDateTimeIso8601Serializer import kotlinx.datetime.serializers.LocalDateTimeComponentSerializer import kotlinx.serialization.Serializable +import kotlin.internal.* /** * The representation of a specific civil date and time without a reference to a particular time zone. @@ -137,7 +138,7 @@ public expect class LocalDateTime : Comparable { * * // `08/30 18:43:13`, using a custom format: * LocalDateTime.Format { - * monthNumber(); char('/'); dayOfMonth() + * monthNumber(); char('/'); day() * char(' ') * hour(); char(':'); minute() * optional { char(':'); second() } @@ -145,7 +146,7 @@ public expect class LocalDateTime : Comparable { * ``` * * Only parsing and formatting of well-formed values is supported. If the input does not fit the boundaries - * (for example, [dayOfMonth] is 31 for February), consider using [DateTimeComponents.Format] instead. + * (for example, [day] is 31 for February), consider using [DateTimeComponents.Format] instead. * * There is a collection of predefined formats in [LocalDateTime.Formats]. * @@ -194,27 +195,27 @@ public expect class LocalDateTime : Comparable { /** * Constructs a [LocalDateTime] instance from the given date and time components. * - * The components [monthNumber] and [dayOfMonth] are 1-based. + * The components [month] and [day] are 1-based. * * The supported ranges of components: * - [year] the range is platform-dependent, but at least is enough to represent dates of all instants between * [Instant.DISTANT_PAST] and [Instant.DISTANT_FUTURE] - * - [monthNumber] `1..12` - * - [dayOfMonth] `1..31`, the upper bound can be less, depending on the month + * - [month] `1..12` + * - [day] `1..31`, the upper bound can be less, depending on the month * - [hour] `0..23` * - [minute] `0..59` * - [second] `0..59` * - [nanosecond] `0..999_999_999` * * @throws IllegalArgumentException if any parameter is out of range, - * or if [dayOfMonth] is invalid for the given [monthNumber] and [year]. + * or if [day] is invalid for the given [month] and [year]. * * @sample kotlinx.datetime.test.samples.LocalDateTimeSamples.constructorFunctionWithMonthNumber */ public constructor( year: Int, - monthNumber: Int, - dayOfMonth: Int, + month: Int, + day: Int, hour: Int, minute: Int, second: Int = 0, @@ -228,21 +229,21 @@ public expect class LocalDateTime : Comparable { * - [year] the range is platform-dependent, but at least is enough to represent dates of all instants between * [Instant.DISTANT_PAST] and [Instant.DISTANT_FUTURE] * - [month] all values of the [Month] enum - * - [dayOfMonth] `1..31`, the upper bound can be less, depending on the month + * - [day] `1..31`, the upper bound can be less, depending on the month * - [hour] `0..23` * - [minute] `0..59` * - [second] `0..59` * - [nanosecond] `0..999_999_999` * * @throws IllegalArgumentException if any parameter is out of range, - * or if [dayOfMonth] is invalid for the given [month] and [year]. + * or if [day] is invalid for the given [month] and [year]. * * @sample kotlinx.datetime.test.samples.LocalDateTimeSamples.constructorFunction */ public constructor( year: Int, month: Month, - dayOfMonth: Int, + day: Int, hour: Int, minute: Int, second: Int = 0, @@ -263,11 +264,8 @@ public expect class LocalDateTime : Comparable { */ public val year: Int - /** - * Returns the number-of-the-month (1..12) component of the [date]. - * - * @sample kotlinx.datetime.test.samples.LocalDateTimeSamples.dateComponents - */ + /** @suppress */ + @Deprecated("Use the 'month' property instead", ReplaceWith("month.number"), level = DeprecationLevel.WARNING) public val monthNumber: Int /** @@ -282,6 +280,10 @@ public expect class LocalDateTime : Comparable { * * @sample kotlinx.datetime.test.samples.LocalDateTimeSamples.dateComponents */ + public val day: Int + + /** @suppress */ + @Deprecated("Use the 'day' property instead", ReplaceWith("day"), level = DeprecationLevel.WARNING) public val dayOfMonth: Int /** @@ -383,6 +385,52 @@ public expect class LocalDateTime : Comparable { public override fun toString(): String } +/** + * @suppress + */ +@Deprecated( + "Use the constructor that accepts a 'month' and a 'day'", + ReplaceWith("LocalDateTime(year = year, month = monthNumber, day = dayOfMonth, hour = hour, minute = minute, second = second, nanosecond = nanosecond)"), + level = DeprecationLevel.WARNING +) +@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE") +@LowPriorityInOverloadResolution +public fun LocalDateTime( + year: Int, + monthNumber: Int, + dayOfMonth: Int, + hour: Int, + minute: Int, + second: Int = 0, + nanosecond: Int = 0, +): LocalDateTime = LocalDateTime( + year = year, month = monthNumber, day = dayOfMonth, + hour = hour, minute = minute, second = second, nanosecond = nanosecond +) + +/** + * @suppress + */ +@Deprecated( + "Use the constructor that accepts a 'day'", + ReplaceWith("LocalDateTime(year = year, month = month, day = dayOfMonth, hour = hour, minute = minute, second = second, nanosecond = nanosecond)"), + level = DeprecationLevel.WARNING +) +@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE") +@LowPriorityInOverloadResolution +public fun LocalDateTime( + year: Int, + month: Month, + dayOfMonth: Int, + hour: Int, + minute: Int, + second: Int = 0, + nanosecond: Int = 0, +): LocalDateTime = LocalDateTime( + year = year, month = month, day = dayOfMonth, + hour = hour, minute = minute, second = second, nanosecond = nanosecond +) + /** * Formats this value using the given [format]. * Equivalent to calling [DateTimeFormat.format] on [format] with `this`. diff --git a/core/common/src/LocalTime.kt b/core/common/src/LocalTime.kt index 79c61793d..5fe862dcc 100644 --- a/core/common/src/LocalTime.kt +++ b/core/common/src/LocalTime.kt @@ -10,6 +10,7 @@ import kotlinx.datetime.format.* import kotlinx.datetime.serializers.LocalTimeIso8601Serializer import kotlinx.datetime.serializers.LocalTimeComponentSerializer import kotlinx.serialization.Serializable +import kotlin.internal.* /** @@ -364,8 +365,21 @@ public fun String.toLocalTime(): LocalTime = LocalTime.parse(this) * * @sample kotlinx.datetime.test.samples.LocalTimeSamples.atDateComponentWiseMonthNumber */ -public fun LocalTime.atDate(year: Int, monthNumber: Int, dayOfMonth: Int = 0): LocalDateTime = - LocalDateTime(year, monthNumber, dayOfMonth, hour, minute, second, nanosecond) +public fun LocalTime.atDate(year: Int, month: Int, day: Int = 0): LocalDateTime = + LocalDateTime(year, month, day, hour, minute, second, nanosecond) + +/** @suppress */ +@Deprecated( + "Use the overload that accepts a 'month' and a 'day' instead", + ReplaceWith("this.atDate(year = year, month = monthNumber, day = dayOfMonth)"), + DeprecationLevel.WARNING +) +@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE") +@LowPriorityInOverloadResolution +public fun LocalTime.atDate(year: Int, monthNumber: Int, dayOfMonth: Int, fakeArgument: Unit = Unit): LocalDateTime = + fakeArgument.let { + LocalDateTime(year, monthNumber, dayOfMonth, hour, minute, second, nanosecond) + } /** * Combines this time's components with the specified date components into a [LocalDateTime] value. @@ -375,8 +389,21 @@ public fun LocalTime.atDate(year: Int, monthNumber: Int, dayOfMonth: Int = 0): L * * @sample kotlinx.datetime.test.samples.LocalTimeSamples.atDateComponentWise */ -public fun LocalTime.atDate(year: Int, month: Month, dayOfMonth: Int = 0): LocalDateTime = - LocalDateTime(year, month, dayOfMonth, hour, minute, second, nanosecond) +public fun LocalTime.atDate(year: Int, month: Month, day: Int = 0): LocalDateTime = + LocalDateTime(year, month, day, hour, minute, second, nanosecond) + +/** @suppress */ +@Deprecated( + "Use the overload that accepts a 'month' and a 'day' instead", + ReplaceWith("this.atDate(year = year, month = month, day = dayOfMonth)"), + DeprecationLevel.WARNING +) +@Suppress("INVISIBLE_MEMBER", "INVISIBLE_REFERENCE") +@LowPriorityInOverloadResolution +public fun LocalTime.atDate(year: Int, month: Month, dayOfMonth: Int, fakeArgument: Unit = Unit): LocalDateTime = + fakeArgument.let { + LocalDateTime(year, month, dayOfMonth, hour, minute, second, nanosecond) + } /** * Combines this time's components with the specified [LocalDate] components into a [LocalDateTime] value. diff --git a/core/common/src/format/DateTimeComponents.kt b/core/common/src/format/DateTimeComponents.kt index 5d5fd2b1f..54c80a5e1 100644 --- a/core/common/src/format/DateTimeComponents.kt +++ b/core/common/src/format/DateTimeComponents.kt @@ -143,7 +143,7 @@ public class DateTimeComponents internal constructor(internal val contents: Date dayOfWeek(DayOfWeekNames.ENGLISH_ABBREVIATED) chars(", ") } - dayOfMonth(Padding.NONE) + day(Padding.NONE) char(' ') monthName(MonthNames.ENGLISH_ABBREVIATED) char(' ') @@ -183,7 +183,7 @@ public class DateTimeComponents internal constructor(internal val contents: Date /** * Writes the contents of the specified [localDate] to this [DateTimeComponents]. - * The [localDate] is written to the [year], [monthNumber], [dayOfMonth], and [dayOfWeek] fields. + * The [localDate] is written to the [year], [monthNumber], [day], and [dayOfWeek] fields. * * If any of the fields are already set, they will be overwritten. * @@ -196,7 +196,7 @@ public class DateTimeComponents internal constructor(internal val contents: Date /** * Writes the contents of the specified [localDateTime] to this [DateTimeComponents]. * The [localDateTime] is written to the - * [year], [monthNumber], [dayOfMonth], [dayOfWeek], + * [year], [monthNumber], [day], [dayOfWeek], * [hour], [hourOfAmPm], [amPm], [minute], [second] and [nanosecond] fields. * * If any of the fields are already set, they will be overwritten. @@ -294,7 +294,11 @@ public class DateTimeComponents internal constructor(internal val contents: Date * @throws IllegalArgumentException during assignment if the value is outside the `0..99` range. * @sample kotlinx.datetime.test.samples.format.DateTimeComponentsSamples.date */ - public var dayOfMonth: Int? by TwoDigitNumber(contents.date::dayOfMonth) + public var day: Int? by TwoDigitNumber(contents.date::day) + + /** @suppress */ + @Deprecated("Use 'day' instead", ReplaceWith("day")) + public var dayOfMonth: Int? by TwoDigitNumber(contents.date::day) /** * The day-of-week component of the date. @@ -411,7 +415,7 @@ public class DateTimeComponents internal constructor(internal val contents: Date * This method uses the following fields: * * [year] * * [monthNumber] - * * [dayOfMonth] + * * [day] * * Also, [dayOfWeek] is checked for consistency with the other fields. * @@ -441,7 +445,7 @@ public class DateTimeComponents internal constructor(internal val contents: Date * This method uses the following fields: * * [year] * * [monthNumber] - * * [dayOfMonth] + * * [day] * * [hour], [hourOfAmPm], and [amPm] * * [minute] * * [second] (default value is 0) diff --git a/core/common/src/format/DateTimeFormatBuilder.kt b/core/common/src/format/DateTimeFormatBuilder.kt index 3c92bfbfd..15b42bfcc 100644 --- a/core/common/src/format/DateTimeFormatBuilder.kt +++ b/core/common/src/format/DateTimeFormatBuilder.kt @@ -74,6 +74,10 @@ public sealed interface DateTimeFormatBuilder { */ public fun monthName(names: MonthNames) + /** @suppress */ + @Deprecated("Use 'day' instead", ReplaceWith("day(padding = padding)")) + public fun dayOfMonth(padding: Padding = Padding.ZERO) { day(padding) } + /** * A day-of-month number, from 1 to 31. * @@ -81,7 +85,7 @@ public sealed interface DateTimeFormatBuilder { * * @sample kotlinx.datetime.test.samples.format.LocalDateFormatSamples.dayOfMonth */ - public fun dayOfMonth(padding: Padding = Padding.ZERO) + public fun day(padding: Padding = Padding.ZERO) /** * A day-of-week name (for example, "Thursday"). @@ -334,9 +338,9 @@ internal fun DateTimeFormatBuilder.WithTime.secondFractionInternal( * Example: * ``` * alternativeParsing( - * { dayOfMonth(); char('-'); monthNumber() }, - * { monthNumber(); char(' '); dayOfMonth() }, - * ) { monthNumber(); char('/'); dayOfMonth() } + * { day(); char('-'); monthNumber() }, + * { monthNumber(); char(' '); day() }, + * ) { monthNumber(); char('/'); day() } * ``` * * This will always format a date as `MM/DD`, but will also accept `DD-MM` and `MM DD`. diff --git a/core/common/src/format/LocalDateFormat.kt b/core/common/src/format/LocalDateFormat.kt index c94a24040..582fade08 100644 --- a/core/common/src/format/LocalDateFormat.kt +++ b/core/common/src/format/LocalDateFormat.kt @@ -199,14 +199,14 @@ internal fun requireParsedField(field: T?, name: String): T { internal interface DateFieldContainer { var year: Int? var monthNumber: Int? - var dayOfMonth: Int? + var day: Int? var isoDayOfWeek: Int? } private object DateFields { val year = GenericFieldSpec(PropertyAccessor(DateFieldContainer::year)) val month = UnsignedFieldSpec(PropertyAccessor(DateFieldContainer::monthNumber), minValue = 1, maxValue = 12) - val dayOfMonth = UnsignedFieldSpec(PropertyAccessor(DateFieldContainer::dayOfMonth), minValue = 1, maxValue = 31) + val day = UnsignedFieldSpec(PropertyAccessor(DateFieldContainer::day), minValue = 1, maxValue = 31) val isoDayOfWeek = UnsignedFieldSpec(PropertyAccessor(DateFieldContainer::isoDayOfWeek), minValue = 1, maxValue = 7) } @@ -216,14 +216,14 @@ private object DateFields { internal class IncompleteLocalDate( override var year: Int? = null, override var monthNumber: Int? = null, - override var dayOfMonth: Int? = null, + override var day: Int? = null, override var isoDayOfWeek: Int? = null ) : DateFieldContainer, Copyable { fun toLocalDate(): LocalDate { val date = LocalDate( requireParsedField(year, "year"), requireParsedField(monthNumber, "monthNumber"), - requireParsedField(dayOfMonth, "dayOfMonth") + requireParsedField(day, "day") ) isoDayOfWeek?.let { if (it != date.dayOfWeek.isoDayNumber) { @@ -238,22 +238,22 @@ internal class IncompleteLocalDate( fun populateFrom(date: LocalDate) { year = date.year - monthNumber = date.monthNumber - dayOfMonth = date.dayOfMonth + monthNumber = date.month.number + day = date.day isoDayOfWeek = date.dayOfWeek.isoDayNumber } - override fun copy(): IncompleteLocalDate = IncompleteLocalDate(year, monthNumber, dayOfMonth, isoDayOfWeek) + override fun copy(): IncompleteLocalDate = IncompleteLocalDate(year, monthNumber, day, isoDayOfWeek) override fun equals(other: Any?): Boolean = other is IncompleteLocalDate && year == other.year && monthNumber == other.monthNumber && - dayOfMonth == other.dayOfMonth && isoDayOfWeek == other.isoDayOfWeek + day == other.day && isoDayOfWeek == other.isoDayOfWeek override fun hashCode(): Int = - year.hashCode() * 31 + monthNumber.hashCode() * 31 + dayOfMonth.hashCode() * 31 + isoDayOfWeek.hashCode() * 31 + year.hashCode() * 31 + monthNumber.hashCode() * 31 + day.hashCode() * 31 + isoDayOfWeek.hashCode() * 31 override fun toString(): String = - "${year ?: "??"}-${monthNumber ?: "??"}-${dayOfMonth ?: "??"} (day of week is ${isoDayOfWeek ?: "??"})" + "${year ?: "??"}-${monthNumber ?: "??"}-${day ?: "??"} (day of week is ${isoDayOfWeek ?: "??"})" } private class YearDirective(private val padding: Padding, private val isYearOfEra: Boolean = false) : @@ -361,14 +361,14 @@ private class MonthNameDirective(private val names: MonthNames) : private class DayDirective(private val padding: Padding) : UnsignedIntFieldFormatDirective( - DateFields.dayOfMonth, + DateFields.day, minDigits = padding.minDigits(2), spacePadding = padding.spaces(2), ) { override val builderRepresentation: String get() = when (padding) { - Padding.ZERO -> "${DateTimeFormatBuilder.WithDate::dayOfMonth.name}()" - else -> "${DateTimeFormatBuilder.WithDate::dayOfMonth.name}(${padding.toKotlinCode()})" + Padding.ZERO -> "${DateTimeFormatBuilder.WithDate::day.name}()" + else -> "${DateTimeFormatBuilder.WithDate::day.name}(${padding.toKotlinCode()})" } override fun equals(other: Any?): Boolean = other is DayDirective && padding == other.padding @@ -428,7 +428,9 @@ internal interface AbstractWithDateBuilder : DateTimeFormatBuilder.WithDate { override fun monthName(names: MonthNames) = addFormatStructureForDate(BasicFormatStructure(MonthNameDirective(names))) - override fun dayOfMonth(padding: Padding) = addFormatStructureForDate(BasicFormatStructure(DayDirective(padding))) + override fun day(padding: Padding) = + addFormatStructureForDate(BasicFormatStructure(DayDirective(padding))) + override fun dayOfWeek(names: DayOfWeekNames) = addFormatStructureForDate(BasicFormatStructure(DayOfWeekDirective(names))) @@ -440,10 +442,10 @@ internal interface AbstractWithDateBuilder : DateTimeFormatBuilder.WithDate { // these are constants so that the formats are not recreated every time they are used internal val ISO_DATE by lazy { - LocalDateFormat.build { year(); char('-'); monthNumber(); char('-'); dayOfMonth() } + LocalDateFormat.build { year(); char('-'); monthNumber(); char('-'); day() } } internal val ISO_DATE_BASIC by lazy { - LocalDateFormat.build { year(); monthNumber(); dayOfMonth() } + LocalDateFormat.build { year(); monthNumber(); day() } } private val emptyIncompleteLocalDate = IncompleteLocalDate() diff --git a/core/common/src/format/Unicode.kt b/core/common/src/format/Unicode.kt index 2a27b4346..207081a2b 100644 --- a/core/common/src/format/Unicode.kt +++ b/core/common/src/format/Unicode.kt @@ -323,8 +323,8 @@ internal sealed interface UnicodeFormat { class DayOfMonth(override val formatLength: Int) : DateBased() { override val formatLetter = 'd' override fun addToFormat(builder: DateTimeFormatBuilder.WithDate) = when (formatLength) { - 1 -> builder.dayOfMonth(Padding.NONE) - 2 -> builder.dayOfMonth(Padding.ZERO) + 1 -> builder.day(Padding.NONE) + 2 -> builder.day(Padding.ZERO) else -> unknownLength() } } diff --git a/core/common/src/serializers/LocalDateSerializers.kt b/core/common/src/serializers/LocalDateSerializers.kt index e1c1c5e96..824ce518d 100644 --- a/core/common/src/serializers/LocalDateSerializers.kt +++ b/core/common/src/serializers/LocalDateSerializers.kt @@ -5,7 +5,7 @@ package kotlinx.datetime.serializers -import kotlinx.datetime.LocalDate +import kotlinx.datetime.* import kotlinx.serialization.* import kotlinx.serialization.descriptors.* import kotlinx.serialization.encoding.* @@ -70,8 +70,8 @@ public object LocalDateComponentSerializer: KSerializer { override fun serialize(encoder: Encoder, value: LocalDate) { encoder.encodeStructure(descriptor) { encodeIntElement(descriptor, 0, value.year) - encodeShortElement(descriptor, 1, value.monthNumber.toShort()) - encodeShortElement(descriptor, 2, value.dayOfMonth.toShort()) + encodeShortElement(descriptor, 1, value.month.number.toShort()) + encodeShortElement(descriptor, 2, value.day.toShort()) } } diff --git a/core/common/src/serializers/LocalDateTimeSerializers.kt b/core/common/src/serializers/LocalDateTimeSerializers.kt index 73f291155..f9a455531 100644 --- a/core/common/src/serializers/LocalDateTimeSerializers.kt +++ b/core/common/src/serializers/LocalDateTimeSerializers.kt @@ -84,8 +84,8 @@ public object LocalDateTimeComponentSerializer: KSerializer { override fun serialize(encoder: Encoder, value: LocalDateTime) { encoder.encodeStructure(descriptor) { encodeIntElement(descriptor, 0, value.year) - encodeShortElement(descriptor, 1, value.monthNumber.toShort()) - encodeShortElement(descriptor, 2, value.dayOfMonth.toShort()) + encodeShortElement(descriptor, 1, value.month.number.toShort()) + encodeShortElement(descriptor, 2, value.day.toShort()) encodeShortElement(descriptor, 3, value.hour.toShort()) encodeShortElement(descriptor, 4, value.minute.toShort()) if (value.second != 0 || value.nanosecond != 0) { diff --git a/core/common/test/LocalDateTest.kt b/core/common/test/LocalDateTest.kt index a0f2a5ecf..54b942f49 100644 --- a/core/common/test/LocalDateTest.kt +++ b/core/common/test/LocalDateTest.kt @@ -20,9 +20,9 @@ class LocalDateTest { private fun checkComponents(value: LocalDate, year: Int, month: Int, day: Int, dayOfWeek: Int? = null, dayOfYear: Int? = null) { assertEquals(year, value.year) - assertEquals(month, value.monthNumber) + assertEquals(month, value.month.number) assertEquals(Month(month), value.month) - assertEquals(day, value.dayOfMonth) + assertEquals(day, value.day) if (dayOfWeek != null) assertEquals(dayOfWeek, value.dayOfWeek.isoDayNumber) if (dayOfYear != null) assertEquals(dayOfYear, value.dayOfYear) @@ -32,7 +32,7 @@ class LocalDateTest { private fun checkLocalDateTimePart(date: LocalDate, datetime: LocalDateTime) { checkEquals(date, datetime.date) - checkComponents(date, datetime.year, datetime.monthNumber, datetime.dayOfMonth, datetime.dayOfWeek.isoDayNumber, datetime.dayOfYear) + checkComponents(date, datetime.year, datetime.month.number, datetime.day, datetime.dayOfWeek.isoDayNumber, datetime.dayOfYear) } @Test @@ -292,7 +292,7 @@ class LocalDateTest { fun checkInvalidDate(constructor: (year: Int, month: Int, day: Int) -> LocalDate) { assertFailsWith { constructor(2007, 2, 29) } - assertEquals(29, constructor(2008, 2, 29).dayOfMonth) + assertEquals(29, constructor(2008, 2, 29).day) assertFailsWith { constructor(2007, 4, 31) } assertFailsWith { constructor(2007, 1, 0) } assertFailsWith { constructor(2007,1, 32) } @@ -303,19 +303,19 @@ fun checkInvalidDate(constructor: (year: Int, month: Int, day: Int) -> LocalDate } private val LocalDate.next: LocalDate get() = - if (dayOfMonth != monthNumber.monthLength(isLeapYear(year))) { - LocalDate(year, monthNumber, dayOfMonth + 1) - } else if (monthNumber != 12) { - LocalDate(year, monthNumber + 1, 1) + if (day != month.number.monthLength(isLeapYear(year))) { + LocalDate(year, month.number, day + 1) + } else if (month.number != 12) { + LocalDate(year, month.number + 1, 1) } else { LocalDate(year + 1, 1, 1) } private val LocalDate.previous: LocalDate get() = - if (dayOfMonth != 1) { - LocalDate(year, monthNumber, dayOfMonth - 1) - } else if (monthNumber != 1) { - val newMonthNumber = monthNumber - 1 + if (day != 1) { + LocalDate(year, month.number, day - 1) + } else if (month.number != 1) { + val newMonthNumber = month.number - 1 LocalDate(year, newMonthNumber, newMonthNumber.monthLength(isLeapYear(year))) } else { LocalDate(year - 1, 12, 31) diff --git a/core/common/test/LocalDateTimeTest.kt b/core/common/test/LocalDateTimeTest.kt index 55bc907a5..373b1c485 100644 --- a/core/common/test/LocalDateTimeTest.kt +++ b/core/common/test/LocalDateTimeTest.kt @@ -129,9 +129,9 @@ class LocalDateTimeTest { fun checkComponents(value: LocalDateTime, year: Int, month: Int, day: Int, hour: Int, minute: Int, second: Int = 0, nanosecond: Int = 0, dayOfWeek: Int? = null, dayOfYear: Int? = null) { assertEquals(year, value.year, "years") - assertEquals(month, value.monthNumber, "months") + assertEquals(month, value.month.number, "months") assertEquals(Month(month), value.month) - assertEquals(day, value.dayOfMonth, "days") + assertEquals(day, value.day, "days") assertEquals(hour, value.hour, "hours") assertEquals(minute, value.minute, "minutes") assertEquals(second, value.second, "seconds") diff --git a/core/common/test/ReadmeTest.kt b/core/common/test/ReadmeTest.kt index 696ff1510..a6d8636a1 100644 --- a/core/common/test/ReadmeTest.kt +++ b/core/common/test/ReadmeTest.kt @@ -77,7 +77,7 @@ class ReadmeTest { val dateFormat = LocalDate.Format { monthNumber(padding = Padding.SPACE) char('/') - dayOfMonth() + day() char(' ') year() } diff --git a/core/common/test/TimeZoneTest.kt b/core/common/test/TimeZoneTest.kt index 97d4e3269..6c52fa19e 100644 --- a/core/common/test/TimeZoneTest.kt +++ b/core/common/test/TimeZoneTest.kt @@ -245,7 +245,7 @@ class TimeZoneTest { } } - private fun LocalDateTime(year: Int, monthNumber: Int, dayOfMonth: Int) = LocalDateTime(year, monthNumber, dayOfMonth, 0, 0) + private fun LocalDateTime(year: Int, month: Int, day: Int) = LocalDateTime(year, month, day, 0, 0) } diff --git a/core/common/test/format/DateTimeComponentsFormatTest.kt b/core/common/test/format/DateTimeComponentsFormatTest.kt index 07973d757..be995e320 100644 --- a/core/common/test/format/DateTimeComponentsFormatTest.kt +++ b/core/common/test/format/DateTimeComponentsFormatTest.kt @@ -20,14 +20,14 @@ class DateTimeComponentsFormatTest { // the same date, but with an incorrect day-of-week: assertDateTimeComponentsEqual( DateTimeComponents().apply { - year = 2008; monthNumber = 6; dayOfMonth = 3; dayOfWeek = DayOfWeek.MONDAY + year = 2008; monthNumber = 6; day = 3; dayOfWeek = DayOfWeek.MONDAY setTime(LocalTime(11, 5, 30)) setOffset(UtcOffset.ZERO) }, format.parse("Mon, 3 Jun 2008 11:05:30 GMT")) assertDateTimeComponentsEqual( DateTimeComponents().apply { - year = 2008; monthNumber = 6; dayOfMonth = 40; dayOfWeek = DayOfWeek.TUESDAY + year = 2008; monthNumber = 6; day = 40; dayOfWeek = DayOfWeek.TUESDAY setTime(LocalTime(11, 5, 30)) setOffset(UtcOffset.ZERO) }, @@ -124,7 +124,7 @@ class DateTimeComponentsFormatTest { private fun assertDateTimeComponentsEqual(a: DateTimeComponents, b: DateTimeComponents, message: String? = null) { assertEquals(a.year, b.year, message) assertEquals(a.monthNumber, b.monthNumber, message) - assertEquals(a.dayOfMonth, b.dayOfMonth, message) + assertEquals(a.day, b.day, message) if (a.dayOfWeek != null && b.dayOfWeek != null) assertEquals(a.dayOfWeek, b.dayOfWeek, message) assertEquals(a.hour, b.hour, message) diff --git a/core/common/test/format/DateTimeComponentsTest.kt b/core/common/test/format/DateTimeComponentsTest.kt index c61841265..8575c601b 100644 --- a/core/common/test/format/DateTimeComponentsTest.kt +++ b/core/common/test/format/DateTimeComponentsTest.kt @@ -53,7 +53,7 @@ class DateTimeComponentsTest { val twoDigitFields = listOf( DateTimeComponents::monthNumber, - DateTimeComponents::dayOfMonth, + DateTimeComponents::day, DateTimeComponents::hour, DateTimeComponents::minute, DateTimeComponents::second, diff --git a/core/common/test/format/DateTimeFormatTest.kt b/core/common/test/format/DateTimeFormatTest.kt index d3e90f9ac..1430398de 100644 --- a/core/common/test/format/DateTimeFormatTest.kt +++ b/core/common/test/format/DateTimeFormatTest.kt @@ -19,7 +19,7 @@ class DateTimeFormatTest { dayOfWeek(DayOfWeekNames.ENGLISH_ABBREVIATED) chars(", ") } - dayOfMonth(Padding.NONE) + day(Padding.NONE) char(' ') monthName(MonthNames("Jan.", "Feb.", "Mar.", "Apr.", "May", "Jun.", "Jul.", "Aug.", "Sep.", "Oct.", "Nov.", "Dec.")) char(' ') @@ -50,7 +50,7 @@ class DateTimeFormatTest { dayOfWeek(DayOfWeekNames.ENGLISH_ABBREVIATED) chars(", ") } - dayOfMonth(Padding.NONE) + day(Padding.NONE) char(' ') monthName(MonthNames("Jan.", "Feb.", "Mar.", "Apr.", "May", "Jun.", "Jul.", "Aug.", "Sep.", "Oct.", "Nov.", "Dec.")) char(' ') @@ -133,7 +133,7 @@ class DateTimeFormatTest { assertFailsWith { DateTimeComponents.Format { monthNumber(Padding.NONE) - dayOfMonth(Padding.NONE) + day(Padding.NONE) } } } diff --git a/core/common/test/format/LocalDateFormatTest.kt b/core/common/test/format/LocalDateFormatTest.kt index d1363253b..8fda04b13 100644 --- a/core/common/test/format/LocalDateFormatTest.kt +++ b/core/common/test/format/LocalDateFormatTest.kt @@ -46,7 +46,7 @@ class LocalDateFormatTest { char(s) monthNumber() char(s) - dayOfMonth() + day() }) } } @@ -71,7 +71,7 @@ class LocalDateFormatTest { year() }) test(dates, LocalDate.Format { - dayOfMonth() + day() char(s) monthNumber() char(s) @@ -101,7 +101,7 @@ class LocalDateFormatTest { test(dates, LocalDate.Format { year() monthNumber() - dayOfMonth() + day() }) } @@ -120,7 +120,7 @@ class LocalDateFormatTest { put(LocalDate(-123456, 5, 1), ("01 May -123456" to setOf())) } val format = LocalDate.Format { - dayOfMonth() + day() char(' ') monthName(MonthNames.ENGLISH_FULL) char(' ') @@ -144,7 +144,7 @@ class LocalDateFormatTest { put(LocalDate(-123456, 5, 1), ("01 V -123456" to setOf())) } val format = LocalDate.Format { - dayOfMonth() + day() char(' ') monthName(MonthNames("I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX", "X", "XI", "XII")) char(' ') @@ -170,7 +170,7 @@ class LocalDateFormatTest { val format = LocalDate.Format { yearTwoDigits(baseYear = 1960) monthNumber() - dayOfMonth() + day() } test(dates, format) } @@ -216,7 +216,7 @@ class LocalDateFormatTest { char(' ') monthName(MonthNames.ENGLISH_ABBREVIATED) char(' ') - dayOfMonth() + day() } assertEquals("2020 Jan 05", format.format(LocalDate(2020, 1, 5))) } diff --git a/core/common/test/format/LocalDateTimeFormatTest.kt b/core/common/test/format/LocalDateTimeFormatTest.kt index 15a8bfa04..32ab5596e 100644 --- a/core/common/test/format/LocalDateTimeFormatTest.kt +++ b/core/common/test/format/LocalDateTimeFormatTest.kt @@ -45,7 +45,7 @@ class LocalDateTimeFormatTest { char('-') monthNumber() char('-') - dayOfMonth() + day() char(' ') hour() char(':') @@ -78,7 +78,7 @@ class LocalDateTimeFormatTest { char('-') monthNumber() char('-') - dayOfMonth() + day() char(' ') hour() char(':') @@ -107,7 +107,7 @@ class LocalDateTimeFormatTest { test(dateTimes, LocalDateTime.Format { year() monthNumber() - dayOfMonth() + day() hour() minute() second() @@ -137,7 +137,7 @@ class LocalDateTimeFormatTest { char('-') monthNumber(Padding.NONE) char('-') - dayOfMonth(Padding.NONE) + day(Padding.NONE) char(' ') hour(Padding.NONE) char(':') @@ -168,7 +168,7 @@ class LocalDateTimeFormatTest { char('-') monthNumber(Padding.SPACE) char('-') - dayOfMonth(Padding.SPACE) + day(Padding.SPACE) char(' ') hour(Padding.SPACE) char(':') @@ -230,7 +230,7 @@ class LocalDateTimeFormatTest { val format1 = LocalDateTime.Format { date(LocalDate.Formats.ISO); char(' '); time(LocalTime.Formats.ISO) } assertEquals("2020-08-30 18:43:13", dateTime.format(format1)) val format2 = LocalDateTime.Format { - monthNumber(); char('/'); dayOfMonth() + monthNumber(); char('/'); day() char(' ') hour(); char(':'); minute() optional { char(':'); second() } diff --git a/core/common/test/samples/format/DateTimeFormatSamples.kt b/core/common/test/samples/format/DateTimeFormatSamples.kt index aabd28bbb..b42f0e7f1 100644 --- a/core/common/test/samples/format/DateTimeFormatSamples.kt +++ b/core/common/test/samples/format/DateTimeFormatSamples.kt @@ -70,7 +70,7 @@ class DateTimeFormatSamples { customFormatAsKotlinCode.contains(""" monthNumber() char('/') - dayOfMonth() + day() char(' ') year() """.trimIndent()) diff --git a/core/common/test/samples/format/UnicodeSamples.kt b/core/common/test/samples/format/UnicodeSamples.kt index 26d9a16f0..ad9438e0e 100644 --- a/core/common/test/samples/format/UnicodeSamples.kt +++ b/core/common/test/samples/format/UnicodeSamples.kt @@ -22,7 +22,7 @@ class UnicodeSamples { DateTimeFormat.formatAsKotlinBuilderDsl(customFormat) == """ monthNumber() char('/') - dayOfMonth() + day() char(' ') year() """.trimIndent() diff --git a/core/commonJs/src/LocalDate.kt b/core/commonJs/src/LocalDate.kt index a650665d7..41846ad54 100644 --- a/core/commonJs/src/LocalDate.kt +++ b/core/commonJs/src/LocalDate.kt @@ -53,20 +53,23 @@ public actual class LocalDate internal constructor(internal val value: jtLocalDa public actual val ISO_BASIC: DateTimeFormat = ISO_DATE_BASIC } - public actual constructor(year: Int, monthNumber: Int, dayOfMonth: Int) : + public actual constructor(year: Int, month: Int, day: Int) : this(try { - jsTry { jtLocalDate.of(year, monthNumber, dayOfMonth) } + jsTry { jtLocalDate.of(year, month, day) } } catch (e: Throwable) { if (e.isJodaDateTimeException()) throw IllegalArgumentException(e) throw e }) - public actual constructor(year: Int, month: Month, dayOfMonth: Int) : this(year, month.number, dayOfMonth) + public actual constructor(year: Int, month: Month, day: Int) : this(year, month.number, day) public actual val year: Int get() = value.year() + @Deprecated("Use the 'month' property instead", ReplaceWith("this.month.number"), level = DeprecationLevel.WARNING) public actual val monthNumber: Int get() = value.monthValue() public actual val month: Month get() = value.month().toMonth() + @Deprecated("Use the 'day' property instead", ReplaceWith("this.day"), level = DeprecationLevel.WARNING) public actual val dayOfMonth: Int get() = value.dayOfMonth() + public actual val day: Int get() = value.dayOfMonth() public actual val dayOfWeek: DayOfWeek get() = value.dayOfWeek().toDayOfWeek() public actual val dayOfYear: Int get() = value.dayOfYear() diff --git a/core/commonJs/src/LocalDateTime.kt b/core/commonJs/src/LocalDateTime.kt index c85e772a4..4cdb091f1 100644 --- a/core/commonJs/src/LocalDateTime.kt +++ b/core/commonJs/src/LocalDateTime.kt @@ -14,24 +14,27 @@ import kotlinx.datetime.internal.JSJoda.LocalDateTime as jtLocalDateTime @Serializable(with = LocalDateTimeIso8601Serializer::class) public actual class LocalDateTime internal constructor(internal val value: jtLocalDateTime) : Comparable { - public actual constructor(year: Int, monthNumber: Int, dayOfMonth: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : + public actual constructor(year: Int, month: Int, day: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : this(try { - jsTry { jtLocalDateTime.of(year, monthNumber, dayOfMonth, hour, minute, second, nanosecond) } + jsTry { jtLocalDateTime.of(year, month, day, hour, minute, second, nanosecond) } } catch (e: Throwable) { if (e.isJodaDateTimeException()) throw IllegalArgumentException(e) throw e }) - public actual constructor(year: Int, month: Month, dayOfMonth: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : - this(year, month.number, dayOfMonth, hour, minute, second, nanosecond) + public actual constructor(year: Int, month: Month, day: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : + this(year, month.number, day, hour, minute, second, nanosecond) public actual constructor(date: LocalDate, time: LocalTime) : this(jsTry { jtLocalDateTime.of(date.value, time.value) }) public actual val year: Int get() = value.year() + @Deprecated("Use the 'month' property instead", ReplaceWith("this.month.number"), level = DeprecationLevel.WARNING) public actual val monthNumber: Int get() = value.monthValue() public actual val month: Month get() = value.month().toMonth() + @Deprecated("Use the 'day' property instead", ReplaceWith("this.day"), level = DeprecationLevel.WARNING) public actual val dayOfMonth: Int get() = value.dayOfMonth() + public actual val day: Int get() = value.dayOfMonth() public actual val dayOfWeek: DayOfWeek get() = value.dayOfWeek().toDayOfWeek() public actual val dayOfYear: Int get() = value.dayOfYear() diff --git a/core/darwin/src/Converters.kt b/core/darwin/src/Converters.kt index 3c1c3999b..f2eafb14e 100644 --- a/core/darwin/src/Converters.kt +++ b/core/darwin/src/Converters.kt @@ -71,8 +71,8 @@ public fun NSTimeZone.toKotlinTimeZone(): TimeZone = TimeZone.of(name) public fun LocalDate.toNSDateComponents(): NSDateComponents { val components = NSDateComponents() components.year = year.convert() - components.month = monthNumber.convert() - components.day = dayOfMonth.convert() + components.month = month.number.convert() + components.day = day.convert() return components } diff --git a/core/jvm/src/LocalDate.kt b/core/jvm/src/LocalDate.kt index fe3b9ae1a..9a3a6c638 100644 --- a/core/jvm/src/LocalDate.kt +++ b/core/jvm/src/LocalDate.kt @@ -50,19 +50,22 @@ public actual class LocalDate internal constructor(internal val value: jtLocalDa public actual val ISO_BASIC: DateTimeFormat = ISO_DATE_BASIC } - public actual constructor(year: Int, monthNumber: Int, dayOfMonth: Int) : + public actual constructor(year: Int, month: Int, day: Int) : this(try { - jtLocalDate.of(year, monthNumber, dayOfMonth) + jtLocalDate.of(year, month, day) } catch (e: DateTimeException) { throw IllegalArgumentException(e) }) - public actual constructor(year: Int, month: Month, dayOfMonth: Int) : this(year, month.number, dayOfMonth) + public actual constructor(year: Int, month: Month, day: Int) : this(year, month.number, day) public actual val year: Int get() = value.year + @Deprecated("Use the 'month' property instead", ReplaceWith("this.month.number"), level = DeprecationLevel.WARNING) public actual val monthNumber: Int get() = value.monthValue public actual val month: Month get() = value.month + @Deprecated("Use the 'day' property instead", ReplaceWith("this.day"), level = DeprecationLevel.WARNING) public actual val dayOfMonth: Int get() = value.dayOfMonth + public actual val day: Int get() = value.dayOfMonth public actual val dayOfWeek: DayOfWeek get() = value.dayOfWeek public actual val dayOfYear: Int get() = value.dayOfYear diff --git a/core/jvm/src/LocalDateTime.kt b/core/jvm/src/LocalDateTime.kt index 7dc28cdb1..c2326e858 100644 --- a/core/jvm/src/LocalDateTime.kt +++ b/core/jvm/src/LocalDateTime.kt @@ -18,23 +18,26 @@ public actual typealias DayOfWeek = java.time.DayOfWeek @Serializable(with = LocalDateTimeIso8601Serializer::class) public actual class LocalDateTime internal constructor(internal val value: jtLocalDateTime) : Comparable { - public actual constructor(year: Int, monthNumber: Int, dayOfMonth: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : + public actual constructor(year: Int, month: Int, day: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : this(try { - jtLocalDateTime.of(year, monthNumber, dayOfMonth, hour, minute, second, nanosecond) + jtLocalDateTime.of(year, month, day, hour, minute, second, nanosecond) } catch (e: DateTimeException) { throw IllegalArgumentException(e) }) - public actual constructor(year: Int, month: Month, dayOfMonth: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : - this(year, month.number, dayOfMonth, hour, minute, second, nanosecond) + public actual constructor(year: Int, month: Month, day: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : + this(year, month.number, day, hour, minute, second, nanosecond) public actual constructor(date: LocalDate, time: LocalTime) : this(jtLocalDateTime.of(date.value, time.value)) public actual val year: Int get() = value.year + @Deprecated("Use the 'month' property instead", ReplaceWith("this.month.number"), level = DeprecationLevel.WARNING) public actual val monthNumber: Int get() = value.monthValue public actual val month: Month get() = value.month + @Deprecated("Use the 'day' property instead", ReplaceWith("this.day"), level = DeprecationLevel.WARNING) public actual val dayOfMonth: Int get() = value.dayOfMonth + public actual val day: Int get() = value.dayOfMonth public actual val dayOfWeek: DayOfWeek get() = value.dayOfWeek public actual val dayOfYear: Int get() = value.dayOfYear diff --git a/core/jvm/test/ConvertersTest.kt b/core/jvm/test/ConvertersTest.kt index 18d759938..52b8c243a 100644 --- a/core/jvm/test/ConvertersTest.kt +++ b/core/jvm/test/ConvertersTest.kt @@ -61,7 +61,7 @@ class ConvertersTest { @Test fun localDateTime() { fun test(ktDateTime: LocalDateTime) { - val jtDateTime = with(ktDateTime) { JTLocalDateTime.of(year, month, dayOfMonth, hour, minute, second, nanosecond) } + val jtDateTime = with(ktDateTime) { JTLocalDateTime.of(year, month, day, hour, minute, second, nanosecond) } assertEquals(ktDateTime, jtDateTime.toKotlinLocalDateTime()) assertEquals(jtDateTime, ktDateTime.toJavaLocalDateTime()) @@ -95,7 +95,7 @@ class ConvertersTest { @Test fun localDate() { fun test(ktDate: LocalDate) { - val jtDate = with(ktDate) { JTLocalDate.of(year, month, dayOfMonth) } + val jtDate = with(ktDate) { JTLocalDate.of(year, month, day) } assertEquals(ktDate, jtDate.toKotlinLocalDate()) assertEquals(jtDate, ktDate.toJavaLocalDate()) diff --git a/core/jvm/test/UnicodeFormatTest.kt b/core/jvm/test/UnicodeFormatTest.kt index cf51533d4..4d471e64d 100644 --- a/core/jvm/test/UnicodeFormatTest.kt +++ b/core/jvm/test/UnicodeFormatTest.kt @@ -159,7 +159,7 @@ private val dateTimeComponentsTemporalQuery = TemporalQuery { accessor -> ChronoField.YEAR_OF_ERA to { year = it }, ChronoField.YEAR to { year = it }, ChronoField.MONTH_OF_YEAR to { monthNumber = it }, - ChronoField.DAY_OF_MONTH to { dayOfMonth = it }, + ChronoField.DAY_OF_MONTH to { day = it }, ChronoField.DAY_OF_WEEK to { dayOfWeek = DayOfWeek(it) }, ChronoField.AMPM_OF_DAY to { amPm = if (it == 1) AmPmMarker.PM else AmPmMarker.AM }, ChronoField.CLOCK_HOUR_OF_AMPM to { hourOfAmPm = it }, diff --git a/core/native/src/LocalDate.kt b/core/native/src/LocalDate.kt index 14ee3a173..1507cbf45 100644 --- a/core/native/src/LocalDate.kt +++ b/core/native/src/LocalDate.kt @@ -23,23 +23,29 @@ private fun isValidYear(year: Int): Boolean = year >= YEAR_MIN && year <= YEAR_MAX @Serializable(with = LocalDateIso8601Serializer::class) -public actual class LocalDate actual constructor(public actual val year: Int, public actual val monthNumber: Int, public actual val dayOfMonth: Int) : Comparable { +public actual class LocalDate actual constructor(public actual val year: Int, month: Int, public actual val day: Int) : Comparable { + + private val _month: Int = month + @Deprecated("Use the 'month' property instead", ReplaceWith("this.month.number"), level = DeprecationLevel.WARNING) + public actual val monthNumber: Int get() = _month + @Deprecated("Use the 'day' property instead", ReplaceWith("this.day"), level = DeprecationLevel.WARNING) + public actual val dayOfMonth: Int get() = day init { // org.threeten.bp.LocalDate#create require(isValidYear(year)) { "Invalid date: the year is out of range" } - require(monthNumber in 1..12) { "Invalid date: month must be a number between 1 and 12, got $monthNumber" } - require(dayOfMonth in 1..31) { "Invalid date: day of month must be a number between 1 and 31, got $dayOfMonth" } - if (dayOfMonth > 28 && dayOfMonth > monthNumber.monthLength(isLeapYear(year))) { - if (dayOfMonth == 29) { + require(_month in 1..12) { "Invalid date: month must be a number between 1 and 12, got $_month" } + require(day in 1..31) { "Invalid date: day of month must be a number between 1 and 31, got $day" } + if (day > 28 && day > _month.monthLength(isLeapYear(year))) { + if (day == 29) { throw IllegalArgumentException("Invalid date 'February 29' as '$year' is not a leap year") } else { - throw IllegalArgumentException("Invalid date '${month.name} $dayOfMonth'") + throw IllegalArgumentException("Invalid date '${Month(month)} $day'") } } } - public actual constructor(year: Int, month: Month, dayOfMonth: Int) : this(year, month.number, dayOfMonth) + public actual constructor(year: Int, month: Month, day: Int) : this(year, month.number, day) public actual companion object { public actual fun parse(input: CharSequence, format: DateTimeFormat): LocalDate = format.parse(input) @@ -102,7 +108,7 @@ public actual class LocalDate actual constructor(public actual val year: Int, pu // org.threeten.bp.LocalDate#toEpochDay public actual fun toEpochDays(): Int { val y = year - val m = monthNumber + val m = _month var total = 0 total += 365 * y if (y >= 0) { @@ -111,7 +117,7 @@ public actual class LocalDate actual constructor(public actual val year: Int, pu total -= y / -4 - y / -100 + y / -400 } total += ((367 * m - 362) / 12) - total += dayOfMonth - 1 + total += day - 1 if (m > 2) { total-- if (!isLeapYear(year)) { @@ -122,7 +128,7 @@ public actual class LocalDate actual constructor(public actual val year: Int, pu } public actual val month: Month - get() = Month(monthNumber) + get() = Month(_month) // org.threeten.bp.LocalDate#getDayOfWeek public actual val dayOfWeek: DayOfWeek @@ -133,7 +139,7 @@ public actual class LocalDate actual constructor(public actual val year: Int, pu // org.threeten.bp.LocalDate#getDayOfYear public actual val dayOfYear: Int - get() = month.firstDayOfYear(isLeapYear(year)) + dayOfMonth - 1 + get() = month.firstDayOfYear(isLeapYear(year)) + day - 1 // Several times faster than using `compareBy` actual override fun compareTo(other: LocalDate): Int { @@ -141,11 +147,11 @@ public actual class LocalDate actual constructor(public actual val year: Int, pu if (y != 0) { return y } - val m = monthNumber.compareTo(other.monthNumber) + val m = _month.compareTo(other._month) if (m != 0) { return m } - return dayOfMonth.compareTo(other.dayOfMonth) + return day.compareTo(other.day) } // org.threeten.bp.LocalDate#resolvePreviousValid @@ -166,11 +172,11 @@ public actual class LocalDate actual constructor(public actual val year: Int, pu if (monthsToAdd == 0) { return this } - val monthCount = year * 12 + (monthNumber - 1) + val monthCount = year * 12 + (_month - 1) val calcMonths = safeAdd(monthCount, monthsToAdd) val newYear = calcMonths.floorDiv(12) val newMonth = calcMonths.mod(12) + 1 - return resolvePreviousValid(newYear, newMonth, dayOfMonth) + return resolvePreviousValid(newYear, newMonth, day) } // org.threeten.bp.LocalDate#plusDays @@ -188,8 +194,8 @@ public actual class LocalDate actual constructor(public actual val year: Int, pu // org.threeten.bp.LocalDate#hashCode override fun hashCode(): Int { val yearValue = year - val monthValue: Int = monthNumber - val dayValue: Int = dayOfMonth + val monthValue: Int = _month + val dayValue: Int = day return yearValue and -0x800 xor (yearValue shl 11) + (monthValue shl 6) + dayValue } @@ -243,12 +249,12 @@ public actual fun LocalDate.daysUntil(other: LocalDate): Int = other.toEpochDays() - this.toEpochDays() // org.threeten.bp.LocalDate#getProlepticMonth -internal val LocalDate.prolepticMonth get() = (year * 12) + (monthNumber - 1) +internal val LocalDate.prolepticMonth get() = (year * 12) + (month.number - 1) // org.threeten.bp.LocalDate#monthsUntil public actual fun LocalDate.monthsUntil(other: LocalDate): Int { - val packed1 = prolepticMonth * 32 + dayOfMonth - val packed2 = other.prolepticMonth * 32 + other.dayOfMonth + val packed1 = prolepticMonth * 32 + day + val packed2 = other.prolepticMonth * 32 + other.day return (packed2 - packed1) / 32 } diff --git a/core/native/src/LocalDateTime.kt b/core/native/src/LocalDateTime.kt index 33187d4a5..d878c7e19 100644 --- a/core/native/src/LocalDateTime.kt +++ b/core/native/src/LocalDateTime.kt @@ -35,16 +35,19 @@ public actual constructor(public actual val date: LocalDate, public actual val t public actual val ISO: DateTimeFormat = ISO_DATETIME } - public actual constructor(year: Int, monthNumber: Int, dayOfMonth: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : - this(LocalDate(year, monthNumber, dayOfMonth), LocalTime.of(hour, minute, second, nanosecond)) + public actual constructor(year: Int, month: Int, day: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : + this(LocalDate(year, month, day), LocalTime.of(hour, minute, second, nanosecond)) - public actual constructor(year: Int, month: Month, dayOfMonth: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : - this(LocalDate(year, month, dayOfMonth), LocalTime.of(hour, minute, second, nanosecond)) + public actual constructor(year: Int, month: Month, day: Int, hour: Int, minute: Int, second: Int, nanosecond: Int) : + this(LocalDate(year, month, day), LocalTime.of(hour, minute, second, nanosecond)) public actual val year: Int get() = date.year - public actual val monthNumber: Int get() = date.monthNumber + @Deprecated("Use the 'month' property instead", ReplaceWith("this.month.number"), level = DeprecationLevel.WARNING) + public actual val monthNumber: Int get() = date.month.number public actual val month: Month get() = date.month - public actual val dayOfMonth: Int get() = date.dayOfMonth + @Deprecated("Use the 'day' property instead", ReplaceWith("this.day"), level = DeprecationLevel.WARNING) + public actual val dayOfMonth: Int get() = date.day + public actual val day: Int get() = date.day public actual val dayOfWeek: DayOfWeek get() = date.dayOfWeek public actual val dayOfYear: Int get() = date.dayOfYear public actual val hour: Int get() = time.hour