[Temporal] Sync to PR 1685

Pass undefined for option in calendar monthDayFromFields and
yearMonthFromFields

https://github.com/tc39/proposal-temporal/issues/1685

Bug: v8:11544
Change-Id: I3fd37e176bd83dc0b01d92a3c323d2933291c49b
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3835262
Reviewed-by: Adam Klein <adamk@chromium.org>
Commit-Queue: Frank Tang <ftang@chromium.org>
Cr-Commit-Position: refs/heads/main@{#82544}
This commit is contained in:
Frank Tang 2022-08-16 17:22:20 -07:00 committed by V8 LUCI CQ
parent 50cdbb31ff
commit a9ed44ba39
2 changed files with 29 additions and 30 deletions

View File

@ -2118,6 +2118,12 @@ MaybeHandle<JSTemporalPlainYearMonth> YearMonthFromFields(
isolate->factory()->yearMonthFromFields_string(),
JS_TEMPORAL_PLAIN_YEAR_MONTH_TYPE);
}
MaybeHandle<JSTemporalPlainYearMonth> YearMonthFromFields(
Isolate* isolate, Handle<JSReceiver> calendar, Handle<JSReceiver> fields) {
// 1. If options is not present, set options to undefined.
return YearMonthFromFields(isolate, calendar, fields,
isolate->factory()->undefined_value());
}
// #sec-temporal-monthdayfromfields
MaybeHandle<JSTemporalPlainMonthDay> MonthDayFromFields(
@ -2128,6 +2134,12 @@ MaybeHandle<JSTemporalPlainMonthDay> MonthDayFromFields(
isolate->factory()->monthDayFromFields_string(),
JS_TEMPORAL_PLAIN_MONTH_DAY_TYPE);
}
MaybeHandle<JSTemporalPlainMonthDay> MonthDayFromFields(
Isolate* isolate, Handle<JSReceiver> calendar, Handle<JSReceiver> fields) {
// 1. If options is not present, set options to undefined.
return MonthDayFromFields(isolate, calendar, fields,
isolate->factory()->undefined_value());
}
// #sec-temporal-totemporaloverflow
Maybe<ShowOverflow> ToTemporalOverflow(Isolate* isolate, Handle<Object> options,
@ -13405,31 +13417,31 @@ MaybeHandle<JSTemporalPlainMonthDay> ToTemporalMonthDay(
// j. Return ? MonthDayFromFields(calendar, fields, options).
return MonthDayFromFields(isolate, calendar, fields, options);
}
// 4. Perform ? ToTemporalOverflow(options).
// 5. Perform ? ToTemporalOverflow(options).
MAYBE_RETURN_ON_EXCEPTION_VALUE(
isolate, ToTemporalOverflow(isolate, options, method_name),
Handle<JSTemporalPlainMonthDay>());
// 5. Let string be ? ToString(item).
// 6. Let string be ? ToString(item).
Handle<String> string;
ASSIGN_RETURN_ON_EXCEPTION(isolate, string,
Object::ToString(isolate, item_obj),
JSTemporalPlainMonthDay);
// 6. Let result be ? ParseTemporalMonthDayString(string).
// 7. Let result be ? ParseTemporalMonthDayString(string).
DateRecord result;
MAYBE_ASSIGN_RETURN_ON_EXCEPTION_VALUE(
isolate, result, ParseTemporalMonthDayString(isolate, string),
Handle<JSTemporalPlainMonthDay>());
// 7. Let calendar be ? ToTemporalCalendarWithISODefault(result.[[Calendar]]).
// 8. Let calendar be ? ToTemporalCalendarWithISODefault(result.[[Calendar]]).
Handle<JSReceiver> calendar;
ASSIGN_RETURN_ON_EXCEPTION(
isolate, calendar,
ToTemporalCalendarWithISODefault(isolate, result.calendar, method_name),
JSTemporalPlainMonthDay);
// 8. If result.[[Year]] is undefined, then
// 9. If result.[[Year]] is undefined, then
// We use kMintInt31 to represent undefined
if (result.date.year == kMinInt31) {
// a. Return ? CreateTemporalMonthDay(result.[[Month]], result.[[Day]],
@ -13439,21 +13451,18 @@ MaybeHandle<JSTemporalPlainMonthDay> ToTemporalMonthDay(
}
Handle<JSTemporalPlainMonthDay> created_result;
// 9. Set result to ? CreateTemporalMonthDay(result.[[Month]], result.[[Day]],
// calendar, referenceISOYear).
// 10. Set result to ? CreateTemporalMonthDay(result.[[Month]],
// result.[[Day]], calendar, referenceISOYear).
ASSIGN_RETURN_ON_EXCEPTION(
isolate, created_result,
CreateTemporalMonthDay(isolate, result.date.month, result.date.day,
calendar, kReferenceIsoYear),
JSTemporalPlainMonthDay);
// 10. Let canonicalMonthDayOptions be ! OrdinaryObjectCreate(null).
Handle<JSReceiver> canonical_month_day_options =
factory->NewJSObjectWithNullProto();
// 11. Return ? MonthDayFromFields(calendar, result,
// canonicalMonthDayOptions).
return MonthDayFromFields(isolate, calendar, created_result,
canonical_month_day_options);
// 11. NOTE: The following operation is called without options, in order for
// the calendar to store a canonical value in the [[ISOYear]] internal slot of
// the result.
// 12. Return ? CalendarMonthDayFromFields(calendar, result).
return MonthDayFromFields(isolate, calendar, created_result);
}
MaybeHandle<JSTemporalPlainMonthDay> ToTemporalMonthDay(
@ -13796,7 +13805,6 @@ MaybeHandle<JSTemporalPlainYearMonth> ToTemporalYearMonth(
const char* method_name) {
TEMPORAL_ENTER_FUNC();
Factory* factory = isolate->factory();
// 2. Assert: Type(options) is Object or Undefined.
DCHECK(options->IsJSReceiver() || options->IsUndefined());
// 3. If Type(item) is Object, then
@ -13857,13 +13865,11 @@ MaybeHandle<JSTemporalPlainYearMonth> ToTemporalYearMonth(
CreateTemporalYearMonth(isolate, result.date.year, result.date.month,
calendar, result.date.day),
JSTemporalPlainYearMonth);
// 9. Let canonicalYearMonthOptions be ! OrdinaryObjectCreate(null).
Handle<JSReceiver> canonical_year_month_options =
factory->NewJSObjectWithNullProto();
// 10. Return ? YearMonthFromFields(calendar, result,
// canonicalYearMonthOptions).
return YearMonthFromFields(isolate, calendar, created_result,
canonical_year_month_options);
// 9. NOTE: The following operation is called without options, in order for
// the calendar to store a canonical value in the [[ISODay]] internal slot of
// the result.
// 10. Return ? CalendarYearMonthFromFields(calendar, result).
return YearMonthFromFields(isolate, calendar, created_result);
}
MaybeHandle<JSTemporalPlainYearMonth> ToTemporalYearMonth(

View File

@ -488,21 +488,14 @@
'built-ins/Temporal/PlainDateTime/prototype/until/argument-zoneddatetime-negative-epochnanoseconds': [FAIL],
'built-ins/Temporal/PlainDateTime/prototype/until/balance': [FAIL],
'built-ins/Temporal/PlainDateTime/prototype/until/balance-negative-duration': [FAIL],
'built-ins/Temporal/PlainMonthDay/from/calendar-monthdayfromfields-called-with-options-undefined': [FAIL],
'built-ins/Temporal/PlainMonthDay/prototype/equals/calendar-monthdayfromfields-called-with-options-undefined': [FAIL],
'built-ins/Temporal/PlainMonthDay/prototype/toPlainDate/limits': [FAIL],
'built-ins/Temporal/PlainTime/prototype/add/argument-string-negative-fractional-units': [FAIL],
'built-ins/Temporal/PlainTime/prototype/toZonedDateTime/timezone-string-multiple-offsets': [FAIL],
'built-ins/Temporal/PlainYearMonth/compare/calendar-yearmonthfromfields-called-with-options-undefined': [FAIL],
'built-ins/Temporal/PlainYearMonth/from/calendar-yearmonthfromfields-called-with-options-undefined': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/add/calendar-arguments': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/add/overflow-wrong-type': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/equals/calendar-yearmonthfromfields-called-with-options-undefined': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/since/calendar-yearmonthfromfields-called-with-options-undefined': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/subtract/calendar-arguments': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/subtract/overflow-wrong-type': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/toPlainDate/limits': [FAIL],
'built-ins/Temporal/PlainYearMonth/prototype/until/calendar-yearmonthfromfields-called-with-options-undefined': [FAIL],
'built-ins/Temporal/TimeZone/from/timezone-string-multiple-offsets': [FAIL],
'built-ins/Temporal/ZonedDateTime/compare/zoneddatetime-string': [FAIL],
'built-ins/Temporal/ZonedDateTime/compare/zoneddatetime-string-multiple-offsets': [FAIL],