Skip to content

Commit

Permalink
Editorial: Replace AnnotatedDateTimeTimeRequired production with para…
Browse files Browse the repository at this point in the history
…meterization

Another place where we can deduplicate parts of the grammar.
  • Loading branch information
ptomato committed Jun 13, 2024
1 parent c68f976 commit 8f65982
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 29 deletions.
32 changes: 15 additions & 17 deletions polyfill/test/validStrings.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -303,7 +303,13 @@ const dateSpec = (extended) =>
validateDayOfMonth
);
const date = choice(dateSpec(true), dateSpec(false));
const dateTime = (z) => seq(date, [dateTimeSeparator, time, [dateTimeUTCOffset(z)]]);
const dateTime = (z, timeRequired) =>
seq(
date,
timeRequired
? seq(dateTimeSeparator, time, [dateTimeUTCOffset(z)])
: [dateTimeSeparator, time, [dateTimeUTCOffset(z)]]
);
const annotatedTime = choice(
seq(timeDesignator, time, [dateTimeUTCOffset(false)], [timeZoneAnnotation], [annotations]),
seq(
Expand All @@ -319,16 +325,8 @@ const annotatedTime = choice(
[annotations]
)
);
const annotatedDateTime = (zoned) =>
seq(dateTime(zoned), zoned ? timeZoneAnnotation : [timeZoneAnnotation], [annotations]);
const annotatedDateTimeTimeRequired = seq(
date,
dateTimeSeparator,
time,
[dateTimeUTCOffset(false)],
[timeZoneAnnotation],
[annotations]
);
const annotatedDateTime = (zoned, timeRequired) =>
seq(dateTime(zoned, timeRequired), zoned ? timeZoneAnnotation : [timeZoneAnnotation], [annotations]);
const annotatedYearMonth = withSyntaxConstraints(
seq(dateSpecYearMonth, [timeZoneAnnotation], [annotations]),
(result, data) => {
Expand Down Expand Up @@ -440,18 +438,18 @@ const duration = withSyntaxConstraints(
);

const instant = seq(date, dateTimeSeparator, time, dateTimeUTCOffset(true), [timeZoneAnnotation], [annotations]);
const zonedDateTime = annotatedDateTime(true);
const zonedDateTime = annotatedDateTime(true, false);

// goal elements
const goals = {
Instant: instant,
Date: annotatedDateTime(false),
DateTime: annotatedDateTime(false),
Date: annotatedDateTime(false, false),
DateTime: annotatedDateTime(false, false),
Duration: duration,
MonthDay: choice(annotatedMonthDay, annotatedDateTime(false)),
Time: choice(annotatedTime, annotatedDateTimeTimeRequired),
MonthDay: choice(annotatedMonthDay, annotatedDateTime(false, false)),
Time: choice(annotatedTime, annotatedDateTime(false, true)),
TimeZone: choice(timeZoneIdentifier, zonedDateTime, instant),
YearMonth: choice(annotatedYearMonth, annotatedDateTime(false)),
YearMonth: choice(annotatedYearMonth, annotatedDateTime(false, false)),
ZonedDateTime: zonedDateTime
};

Expand Down
21 changes: 9 additions & 12 deletions spec/abstractops.html
Original file line number Diff line number Diff line change
Expand Up @@ -1363,20 +1363,17 @@ <h1>ISO 8601 grammar</h1>
TimeSpec[+Extended]
TimeSpec[~Extended]

DateTime[Z] :::
Date
DateTime[Z, TimeRequired] :::
[~TimeRequired] Date
Date DateTimeSeparator Time DateTimeUTCOffset[?Z]?

AnnotatedTime :::
TimeDesignator Time DateTimeUTCOffset[~Z]? TimeZoneAnnotation? Annotations?
Time DateTimeUTCOffset[~Z]? TimeZoneAnnotation? Annotations?

AnnotatedDateTime[Zoned] :::
[~Zoned] DateTime[~Z] TimeZoneAnnotation? Annotations?
[+Zoned] DateTime[+Z] TimeZoneAnnotation Annotations?

AnnotatedDateTimeTimeRequired :::
Date DateTimeSeparator Time DateTimeUTCOffset[~Z]? TimeZoneAnnotation? Annotations?
AnnotatedDateTime[Zoned, TimeRequired] :::
[~Zoned] DateTime[~Z, ?TimeRequired] TimeZoneAnnotation? Annotations?
[+Zoned] DateTime[+Z, ?TimeRequired] TimeZoneAnnotation Annotations?

AnnotatedYearMonth :::
DateSpecYearMonth TimeZoneAnnotation? Annotations?
Expand Down Expand Up @@ -1460,22 +1457,22 @@ <h1>ISO 8601 grammar</h1>
Date DateTimeSeparator Time DateTimeUTCOffset[+Z] TimeZoneAnnotation? Annotations?

TemporalDateTimeString[Zoned] :::
AnnotatedDateTime[?Zoned]
AnnotatedDateTime[?Zoned, ~TimeRequired]

TemporalDurationString :::
Duration

TemporalMonthDayString :::
AnnotatedMonthDay
AnnotatedDateTime[~Zoned]
AnnotatedDateTime[~Zoned, ~TimeRequired]

TemporalTimeString :::
AnnotatedTime
AnnotatedDateTimeTimeRequired
AnnotatedDateTime[~Zoned, +TimeRequired]

TemporalYearMonthString :::
AnnotatedYearMonth
AnnotatedDateTime[~Zoned]
AnnotatedDateTime[~Zoned, ~TimeRequired]
</emu-grammar>

<emu-clause id="sec-temporal-iso8601grammar-static-semantics-isvalidmonthday" type="sdo">
Expand Down

0 comments on commit 8f65982

Please sign in to comment.