From 6cf421bb1e662d1923ce087ff5ae550cc4c8125d Mon Sep 17 00:00:00 2001 From: Philip Chimento Date: Thu, 13 Jan 2022 09:43:17 -0800 Subject: [PATCH] Normative: Fix sign in PlainYearMonth.subtract The duration has to be negated up front, otherwise the _sign_ < 0 test is wrong. No change in functionality in the polyfill, which already handled this correctly. This is already covered by tests. Closes: #1863 --- spec/plainyearmonth.html | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/spec/plainyearmonth.html b/spec/plainyearmonth.html index 3dca1aef20..f46bcd5151 100644 --- a/spec/plainyearmonth.html +++ b/spec/plainyearmonth.html @@ -284,6 +284,7 @@

Temporal.PlainYearMonth.prototype.subtract ( _temporalDurationLike_ [ , _opt 1. Let _yearMonth_ be the *this* value. 1. Perform ? RequireInternalSlot(_yearMonth_, [[InitializedTemporalYearMonth]]). 1. Let _duration_ be ? ToTemporalDurationRecord(_temporalDurationLike_). + 1. Set _duration_ to ! CreateNegatedTemporalDuration(_duration_). 1. Let _balanceResult_ be ? BalanceDuration(_duration_.[[Days]], _duration_.[[Hours]], _duration_.[[Minutes]], _duration_.[[Seconds]], _duration_.[[Milliseconds]], _duration_.[[Microseconds]], _duration_.[[Nanoseconds]], *"day"*). 1. Set _options_ to ? GetOptionsObject(_options_). 1. Let _calendar_ be _yearMonth_.[[Calendar]]. @@ -295,7 +296,7 @@

Temporal.PlainYearMonth.prototype.subtract ( _temporalDurationLike_ [ , _opt 1. Else, 1. Let _day_ be 1. 1. Let _date_ be ? CreateTemporalDate(_yearMonth_.[[ISOYear]], _yearMonth_.[[ISOMonth]], _day_, _calendar_). - 1. Let _durationToAdd_ be ! CreateTemporalDuration(−_duration_.[[Years]], −_duration_.[[Months]], −_duration_.[[Weeks]], −_balanceResult_.[[Days]], 0, 0, 0, 0, 0, 0). + 1. Let _durationToAdd_ be ! CreateTemporalDuration(_duration_.[[Years]], _duration_.[[Months]], _duration_.[[Weeks]], _balanceResult_.[[Days]], 0, 0, 0, 0, 0, 0). 1. Let _optionsCopy_ be OrdinaryObjectCreate(%Object.prototype%). 1. Let _entries_ be ? EnumerableOwnPropertyNames(_options_, ~key+value~). 1. For each element _nextEntry_ of _entries_, do