2021-09-29 21:48:22 +02:00
|
|
|
// 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.plainyearmonth.from
|
|
|
|
description: Fast path for converting other Temporal objects to Temporal.Calendar by reading internal slots
|
|
|
|
info: |
|
|
|
|
sec-temporal.plainyearmonth.from step 3:
|
|
|
|
3. Return ? ToTemporalYearMonth(_item_, _options_).
|
|
|
|
sec-temporal-totemporaldate step 2.b:
|
|
|
|
b. Let _calendar_ be ? GetTemporalCalendarWithISODefault(_item_).
|
|
|
|
sec-temporal-gettemporalcalendarwithisodefault step 2:
|
|
|
|
2. Return ? ToTemporalCalendarWithISODefault(_calendar_).
|
|
|
|
sec-temporal-totemporalcalendarwithisodefault step 2:
|
|
|
|
3. Return ? ToTemporalCalendar(_temporalCalendarLike_).
|
|
|
|
sec-temporal-totemporalcalendar step 1.a:
|
|
|
|
a. If _temporalCalendarLike_ has an [[InitializedTemporalDate]], [[InitializedTemporalDateTime]], [[InitializedTemporalMonthDay]], [[InitializedTemporalYearMonth]], or [[InitializedTemporalZonedDateTime]] internal slot, then
|
|
|
|
i. Return _temporalCalendarLike_.[[Calendar]].
|
|
|
|
includes: [compareArray.js, temporalHelpers.js]
|
|
|
|
features: [Temporal]
|
|
|
|
---*/
|
|
|
|
|
2024-06-04 12:49:30 +02:00
|
|
|
TemporalHelpers.checkToTemporalCalendarFastPath((temporalObject) => {
|
2021-09-29 21:48:22 +02:00
|
|
|
const result = Temporal.PlainYearMonth.from({ year: 2000, month: 5, calendar: temporalObject });
|
2024-06-04 17:35:22 +02:00
|
|
|
assert.sameValue(result.calendarId, "iso8601", "Temporal object coerced to calendar");
|
2021-09-29 21:48:22 +02:00
|
|
|
});
|