From 5ca5247ab3db834e1518c466131b771a3d5d5fc6 Mon Sep 17 00:00:00 2001 From: Eemeli Aro Date: Mon, 18 Nov 2024 17:58:10 +0000 Subject: [PATCH] Always apply isolation when `u:dir` is set (#942) * Always apply isolation when u:dir is set * Add explicit default "inherit" value * Update spec/u-namespace.md Co-authored-by: Addison Phillips --------- Co-authored-by: Addison Phillips --- spec/formatting.md | 8 ++++++-- spec/u-namespace.md | 7 ++++++- test/tests/u-options.json | 26 ++++++++++++++++++++++++-- 3 files changed, 36 insertions(+), 5 deletions(-) diff --git a/spec/formatting.md b/spec/formatting.md index 4ac0ca295..5aaafb96e 100644 --- a/spec/formatting.md +++ b/spec/formatting.md @@ -938,9 +938,13 @@ The _Default Bidi Strategy_ is defined as follows: 1. Let `fmt` be the formatted string representation of the _resolved value_ of `exp`. 1. Let `dir` be the directionality of `fmt`, one of « `'LTR'`, `'RTL'`, `'unknown'` », with the same meanings as for `msgdir`. + 1. Let the boolean value `isolate` be + True if the `u:dir` _option_ of the _resolved value_ of `exp` has a value other than `'inherit'`, + or False otherwise. 1. If `dir` is `'LTR'`: - 1. If `msgdir` is `'LTR'` - in the formatted output, let `fmt` be itself + 1. If `msgdir` is `'LTR'` in the formatted output + and `isolate` is False, + let `fmt` be itself 1. Else, in the formatted output, prefix `fmt` with U+2066 LEFT-TO-RIGHT ISOLATE and postfix it with U+2069 POP DIRECTIONAL ISOLATE. diff --git a/spec/u-namespace.md b/spec/u-namespace.md index dabbcc70f..03a713431 100644 --- a/spec/u-namespace.md +++ b/spec/u-namespace.md @@ -68,7 +68,8 @@ not valid, or some other reason. ### `u:dir` Replaces the base directionality defined in -the _function context_ for this _expression_. +the _function context_ for this _expression_ +and applies bidirectional isolation to it. If this option is set on _markup_, a _Bad Option_ error is emitted and the value of the `u:dir` option is ignored. @@ -76,12 +77,16 @@ and the value of the `u:dir` option is ignored. During processing, the `u:dir` option MUST be removed from the resolved mapping of _options_ before calling the _function handler_. +Its value is retained in the _resolved value_ of the _expression_. The value of the `u:dir` _option_ MUST be one of the following _literal_ values or a _variable_ whose _resolved value_ is one of these _literals_: - `ltr`: left-to-right directionality - `rtl`: right-to-left directionality - `auto`: directionality determined from _expression_ contents +- `inherit` (default): directionality inherited from the _message_ + or from the _resolved value_ of the _operand_ without + requiring isolation of the _expression_ value. For other values, a _Bad Option_ error is emitted and the value of the `u:dir` option is ignored. diff --git a/test/tests/u-options.json b/test/tests/u-options.json index de0fb0891..ee4276588 100644 --- a/test/tests/u-options.json +++ b/test/tests/u-options.json @@ -56,19 +56,22 @@ }, { "src": "hello {world :string u:dir=ltr u:id=foo}", - "exp": "hello world", + "exp": "hello \u2066world\u2069", "expParts": [ { "type": "literal", "value": "hello " }, + { "type": "bidiIsolation", "value": "\u2066" }, { "type": "string", "source": "|world|", "dir": "ltr", "id": "foo", "value": "world" - } + }, + { "type": "bidiIsolation", "value": "\u2069" } + ] }, { @@ -102,6 +105,25 @@ { "type": "bidiIsolation", "value": "\u2069" } ] }, + { + "src": ".local $world = {world :string u:dir=ltr u:id=foo} {{hello {$world}}}", + "exp": "hello \u2066world\u2069", + "expParts": [ + { + "type": "literal", + "value": "hello " + }, + { "type": "bidiIsolation", "value": "\u2066" }, + { + "type": "string", + "source": "|world|", + "dir": "ltr", + "id": "foo", + "value": "world" + }, + { "type": "bidiIsolation", "value": "\u2069" } + ] + }, { "locale": "ar", "src": "أهلاً {بالعالم :string u:dir=rtl}",