Skip to content

Commit

Permalink
Normative: Add timeZoneName: "critical" option to ZonedDateTime.toStr…
Browse files Browse the repository at this point in the history
…ing()

This adds a new recognized value "critical" to the timeZoneName option of
ZonedDateTime.prototype.toString(). timeZoneName: "critical" behaves like
timeZoneName: "always", but it also outputs a "!" flag in the time zone
annotation. This flag is never used by Temporal, but could be consumed by
other programs.

See: #1450
  • Loading branch information
ptomato committed Oct 11, 2022
1 parent 5ab52d4 commit 1a3635d
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 7 deletions.
5 changes: 3 additions & 2 deletions docs/zoneddatetime.md
Original file line number Diff line number Diff line change
Expand Up @@ -1249,7 +1249,7 @@ zdt1.equals(zdt1); // => true
Valid values are `'auto'` and `'never'`.
The default is `'auto'`.
- `timeZoneName` (string): Whether to show the time zone name annotation in the return value.
Valid values are `'auto'` and `'never'`.
Valid values are `'auto'`, `'never'`, and `'critical'`.
The default is `'auto'`.
- `calendarName` (string): Whether to show the calendar annotation in the return value.
Valid values are `'auto'`, `'always'`, `'never'`, and `'critical'`.
Expand Down Expand Up @@ -1288,8 +1288,9 @@ For more information on the calendar annotation, see [ISO string extensions](./s

Likewise, passing `'never'` to the `timeZoneName` or `offset` options controls whether the time zone offset (`+01:00`) or name annotation (`[Europe/Paris]`) are shown.
If the time zone offset is shown, it is always shown rounded to the nearest minute.
The `timeZoneName` option can additionally be `'critical'` which will add an additional `!` to the annotation, similar to `calendarName`.

The string format output by this method can be parsed by [`java.time.ZonedDateTime`](https://docs.oracle.com/javase/8/docs/api/java/time/ZonedDateTime.html) as long as the calendar annotation is not output.
The string format output by this method can be parsed by [`java.time.ZonedDateTime`](https://docs.oracle.com/javase/8/docs/api/java/time/ZonedDateTime.html) as long as the calendar annotation is not output and `'critical'` is not used.
For more information on `Temporal`'s extensions to the ISO 8601 / RFC 3339 string format and the progress towards becoming a published standard, see [String Parsing, Serialization, and Formatting](./strings.md).

Example usage:
Expand Down
7 changes: 5 additions & 2 deletions polyfill/lib/ecmascript.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -710,7 +710,7 @@ export const ES = ObjectAssign({}, ES2022, {
return ES.GetOption(options, 'calendarName', ['auto', 'always', 'never', 'critical'], 'auto');
},
ToShowTimeZoneNameOption: (options) => {
return ES.GetOption(options, 'timeZoneName', ['auto', 'never'], 'auto');
return ES.GetOption(options, 'timeZoneName', ['auto', 'never', 'critical'], 'auto');
},
ToShowOffsetOption: (options) => {
return ES.GetOption(options, 'offset', ['auto', 'never'], 'auto');
Expand Down Expand Up @@ -2151,7 +2151,10 @@ export const ES = ObjectAssign({}, ES2022, {
const offsetNs = ES.GetOffsetNanosecondsFor(tz, instant);
result += ES.FormatISOTimeZoneOffsetString(offsetNs);
}
if (showTimeZone !== 'never') result += `[${tz}]`;
if (showTimeZone !== 'never') {
const flag = showTimeZone === 'critical' ? '!' : '';
result += `[${flag}${tz}]`;
}
result += ES.MaybeFormatCalendarAnnotation(GetSlot(zdt, CALENDAR), showCalendar);
return result;
},
Expand Down
2 changes: 1 addition & 1 deletion spec/abstractops.html
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ <h1>ToShowTimeZoneNameOption ( _normalizedOptions_ )</h1>
It is different from the `timeZone` property passed to `Temporal.ZonedDateTime.from()` and from the `timeZone` property in the options passed to `Temporal.Instant.prototype.toString()`.
</emu-note>
<emu-alg>
1. Return ? GetOption(_normalizedOptions_, *"timeZoneName"*, *"string"*, « *"auto"*, *"never"* », *"auto"*).
1. Return ? GetOption(_normalizedOptions_, *"timeZoneName"*, *"string"*, « *"auto"*, *"never"*, *"critical"* », *"auto"*).
</emu-alg>
</emu-clause>

Expand Down
5 changes: 3 additions & 2 deletions spec/zoneddatetime.html
Original file line number Diff line number Diff line change
Expand Up @@ -1166,7 +1166,7 @@ <h1>
_zonedDateTime_: a Temporal.ZonedDateTime,
_precision_: one of *"auto"*, *"minute"*, or an integer between 0 and 9 inclusive,
_showCalendar_: one of *"auto"*, *"always"*, *"never"*, or *"critical"*,
_showTimeZone_: one of *"auto"* or *"never"*,
_showTimeZone_: one of *"auto"*, *"never"*, or *"critical"*,
_showOffset_: one of *"auto"* or *"never"*,
optional _increment_: an integer,
optional _unit_: one of *"minute"*, *"second"*, *"millisecond"*, *"microsecond"*, or *"nanosecond"*,
Expand Down Expand Up @@ -1198,7 +1198,8 @@ <h1>
1. Let _timeZoneString_ be the empty String.
1. Else,
1. Let _timeZoneID_ be ? ToString(_timeZone_).
1. Let _timeZoneString_ be the string-concatenation of the code unit 0x005B (LEFT SQUARE BRACKET), _timeZoneID_, and the code unit 0x005D (RIGHT SQUARE BRACKET).
1. If _showTimeZone_ is *"critical"*, let _flag_ be *"!"*; else let _flag_ be the empty String.
1. Let _timeZoneString_ be the string-concatenation of the code unit 0x005B (LEFT SQUARE BRACKET), _flag_, _timeZoneID_, and the code unit 0x005D (RIGHT SQUARE BRACKET).
1. Let _calendarString_ be ? MaybeFormatCalendarAnnotation(_zonedDateTime_.[[Calendar]], _showCalendar_).
1. Return the string-concatenation of _dateTimeString_, _offsetString_, _timeZoneString_, and _calendarString_.
</emu-alg>
Expand Down

0 comments on commit 1a3635d

Please sign in to comment.