| // Copyright (C) 2021 Igalia, S.L. All rights reserved. |
| // This code is governed by the BSD license found in the LICENSE file. |
| |
| /*--- |
| esid: sec-temporal.duration.prototype.add |
| description: Negative time fields in relativeTo are balanced upwards |
| info: | |
| sec-temporal-balancetime steps 3–14: |
| 3. Set _microsecond_ to _microsecond_ + floor(_nanosecond_ / 1000). |
| 4. Set _nanosecond_ to _nanosecond_ modulo 1000. |
| 5. Set _millisecond_ to _millisecond_ + floor(_microsecond_ / 1000). |
| 6. Set _microsecond_ to _microsecond_ modulo 1000. |
| 7. Set _second_ to _second_ + floor(_millisecond_ / 1000). |
| 8. Set _millisecond_ to _millisecond_ modulo 1000. |
| 9. Set _minute_ to _minute_ + floor(_second_ / 60). |
| 10. Set _second_ to _second_ modulo 60. |
| 11. Set _hour_ to _hour_ + floor(_minute_ / 60). |
| 12. Set _minute_ to _minute_ modulo 60. |
| 13. Let _days_ be floor(_hour_ / 24). |
| 14. Set _hour_ to _hour_ modulo 24. |
| sec-temporal-differencetime step 8: |
| 8. Let _bt_ be ? BalanceTime(_hours_, _minutes_, _seconds_, _milliseconds_, _microseconds_, _nanoseconds_). |
| sec-temporal-differenceisodatetime step 2: |
| 2. Let _timeDifference_ be ? DifferenceTime(_h1_, _min1_, _s1_, _ms1_, _mus1_, _ns1_, _h2_, _min2_, _s2_, _ms2_, _mus2_, _ns2_). |
| sec-temporal-differencezoneddatetime step 7: |
| 7. Let _dateDifference_ be ? DifferenceISODateTime(_startDateTime_.[[ISOYear]], _startDateTime_.[[ISOMonth]], _startDateTime_.[[ISODay]], _startDateTime_.[[ISOHour]], _startDateTime_.[[ISOMinute]], _startDateTime_.[[ISOSecond]], _startDateTime_.[[ISOMillisecond]], _startDateTime_.[[ISOMicrosecond]], _startDateTime_.[[ISONanosecond]], _endDateTime_.[[ISOYear]], _endDateTime_.[[ISOMonth]], _endDateTime_.[[ISODay]], _endDateTime_.[[ISOHour]], _endDateTime_.[[ISOMinute]], _endDateTime_.[[ISOSecond]], _endDateTime_.[[ISOMillisecond]], _endDateTime_.[[ISOMicrosecond]], _endDateTime_.[[ISONanosecond]], _calendar_, _largestUnit_, _options_). |
| sec-temporal-addduration step 7.g.i: |
| i. Let _result_ be ? DifferenceZonedDateTime(_relativeTo_.[[Nanoseconds]], _endNs_, _timeZone_, _calendar_, _largestUnit_). |
| sec-temporal.duration.prototype.add step 6: |
| 6. Let _result_ be ? AddDuration(_duration_.[[Years]], _duration_.[[Months]], _duration_.[[Weeks]], _duration_.[[Days]], _duration_.[[Hours]], _duration_.[[Minutes]], _duration_.[[Seconds]], _duration_.[[Milliseconds]], _duration_.[[Microseconds]], _duration_.[[Nanoseconds]], _other_.[[Years]], _other_.[[Months]], _other_.[[Weeks]], _other_.[[Days]], _other_.[[Hours]], _other_.[[Minutes]], _other_.[[Seconds]], _other_.[[Milliseconds]], _other_.[[Microseconds]], _other_.[[Nanoseconds]], _relativeTo_). |
| includes: [temporalHelpers.js] |
| features: [Temporal] |
| ---*/ |
| |
| const duration = new Temporal.Duration(0, 0, 0, 0, 1, 1, 1, 1, 1, 1); |
| |
| const timeZone = new Temporal.TimeZone("UTC"); |
| const relativeTo = new Temporal.ZonedDateTime(830998861_000_000_000n, timeZone); |
| // This code path is encountered if largestUnit is years, months, weeks, or days |
| // and relativeTo is a ZonedDateTime |
| const options = { largestUnit: "days", relativeTo }; |
| |
| const result1 = duration.add(new Temporal.Duration(0, 0, 0, 0, 0, 0, 0, 0, 0, -2), options); |
| TemporalHelpers.assertDuration(result1, 0, 0, 0, 0, 1, 1, 1, 1, 0, 999, "nanoseconds balance"); |
| |
| const result2 = duration.add(new Temporal.Duration(0, 0, 0, 0, 0, 0, 0, 0, -2), options); |
| TemporalHelpers.assertDuration(result2, 0, 0, 0, 0, 1, 1, 1, 0, 999, 1, "microseconds balance"); |
| |
| const result3 = duration.add(new Temporal.Duration(0, 0, 0, 0, 0, 0, 0, -2), options); |
| TemporalHelpers.assertDuration(result3, 0, 0, 0, 0, 1, 1, 0, 999, 1, 1, "milliseconds balance"); |
| |
| const result4 = duration.add(new Temporal.Duration(0, 0, 0, 0, 0, 0, -2), options); |
| TemporalHelpers.assertDuration(result4, 0, 0, 0, 0, 1, 0, 59, 1, 1, 1, "seconds balance"); |
| |
| const result5 = duration.add(new Temporal.Duration(0, 0, 0, 0, 0, -2), options); |
| TemporalHelpers.assertDuration(result5, 0, 0, 0, 0, 0, 59, 1, 1, 1, 1, "minutes balance"); |
| |
| // This one is different because hours are later balanced again in BalanceDuration |
| const result6 = duration.add(new Temporal.Duration(0, 0, 0, 0, -2), options); |
| TemporalHelpers.assertDuration(result6, 0, 0, 0, 0, 0, -58, -58, -998, -998, -999, "hours balance"); |