Skip to content

Commit

Permalink
Merge pull request #1694 from michaelhkay/1632-add-xsl-map-select
Browse files Browse the repository at this point in the history
1632 Add xsl:map/@select
  • Loading branch information
ndw authored Jan 14, 2025
2 parents 4659586 + 56bc6f4 commit 972ce90
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 15 deletions.
3 changes: 3 additions & 0 deletions specifications/xslt-40/src/element-catalog.xml
Original file line number Diff line number Diff line change
Expand Up @@ -1659,6 +1659,9 @@

<e:element-syntax name="map">
<e:in-category name="instruction"/>
<e:attribute name="select">
<e:data-type name="expression"/>
</e:attribute>
<e:attribute name="on-duplicates" required="no" default="error(xs:QName(err:XTDE3365))">
<e:data-type name="expression"/>
</e:attribute>
Expand Down
61 changes: 46 additions & 15 deletions specifications/xslt-40/src/xslt.xml
Original file line number Diff line number Diff line change
Expand Up @@ -22006,7 +22006,8 @@ and <code>version="1.0"</code> otherwise.</p>
<p>For the elements <elcode>xsl:sequence</elcode>, <elcode>xsl:on-empty</elcode>,
<elcode>xsl:on-non-empty</elcode>, <elcode>xsl:when</elcode>,
<elcode>xsl:otherwise</elcode>, <elcode>xsl:matching-substring</elcode>,
<elcode>xsl:non-matching-substring</elcode>, <elcode>xsl:array</elcode>,
<elcode>xsl:non-matching-substring</elcode>, <elcode>xsl:map</elcode>,
<elcode>xsl:map-entry</elcode>, <elcode>xsl:array</elcode>,
<elcode>xsl:array-member</elcode>, and <elcode>xsl:result-document</elcode>,
it is a <termref def="dt-static-error">static error</termref> if the
<code>select</code> attribute is present
Expand Down Expand Up @@ -35549,16 +35550,34 @@ the same group, and the-->

<div2 id="map-instructions">
<head>Map Instructions</head>
<changes>
<change issue="1632">
The <elcode>xsl:map</elcode> instruction allows a <code>select</code> attribute
as an alternative to the contained sequence constructor.
</change>
<change issue="1632">
The <elcode>xsl:map-entry</elcode> instruction, in common with other instructions,
now raises error XTSE3185 (rather than XTSE3280) if both a <code>select</code>
attribute and a sequence constructor are present.
</change>

</changes>
<p>Two instructions are added to XSLT to facilitate the construction of maps.</p>

<?element xsl:map?>


<p>The instruction <elcode>xsl:map</elcode> constructs and returns a new map.</p>

<p>The <code>select</code> attribute and the contained sequence constructor are mutually
exclusive: if a <code>select</code> attribute is present, then the content
<rfc2119>must</rfc2119> be empty except optionally for
<elcode>xsl:fallback</elcode> instructions. <errorref spec="XT" class="SE" code="3185"/></p>

<p>The result of evaluating the <code>select</code> expression or the contained
sequence constructor is referred to as the <term>input sequence</term>.</p>

<p>The contained sequence constructor <rfc2119>must</rfc2119> evaluate to a sequence of
<p>The input sequence <rfc2119>must</rfc2119> be a sequence of
maps: call this <code>$maps</code>.</p>

<p><phrase diff="chg" at="2022-01-01">In the absense of duplicate keys,</phrase> the result of the instruction
Expand All @@ -35575,7 +35594,7 @@ the same group, and the-->



<p>There is no requirement that the supplied input maps should have the same or
<p>There is no requirement that the maps in the input sequence should have the same or
compatible types. The type of a map (for example <code>map(xs:integer,
xs:string)</code>) is descriptive of the entries it currently contains, but is not
a constraint on how the map may be combined with other maps.</p>
Expand All @@ -35589,22 +35608,30 @@ the same group, and the-->
</note>

<p><error spec="XT" class="TE" code="3375" type="type">
<p>A type error occurs if the result of evaluating the sequence constructor
<error.extra>within an <elcode>xsl:map</elcode> instruction</error.extra> is
<p>A type error occurs if the result of the input sequence
<error.extra>of an <elcode>xsl:map</elcode> instruction</error.extra> is
not an instance of the required type <code>map(*)*</code>.</p>
</error></p>



<note>
<p>In practice, the effect of this rule is that the sequence
<p>In practice, the effect of this rule is that the result of the
<code>select</code> expression or sequence
constructor contained in the <elcode>xsl:map</elcode> instruction is severely
constrained: it doesn’t make sense, for example, for it to contain
instructions such as <elcode>xsl:element</elcode> that create new nodes. As with
other type errors, processors are free to raise the error statically if they are
able to determine that the sequence constructor would always fail when
evaluated.</p>
</note>

<note>
<p>It is legitimate to construct a map using an instruction such as
<code>&lt;xsl:map select="{'a':1, 'b':2}"/></code>. In this situation
<elcode>xsl:map</elcode> has exactly the same effect as <elcode>xsl:sequence</elcode>,
but users may feel that it improves readability.</p>
</note>

<?element xsl:map-entry?>

Expand All @@ -35616,16 +35643,16 @@ the same group, and the-->
<p>The <code>select</code> attribute and the contained sequence constructor are mutually
exclusive: if a <code>select</code> attribute is present, then the content
<rfc2119>must</rfc2119> be empty except optionally for
<elcode>xsl:fallback</elcode> instructions.</p>
<elcode>xsl:fallback</elcode> instructions. <errorref spec="XT" class="SE" code="3185"/></p>

<p>
<!--<p>
<error spec="XT" type="static" class="SE" code="3280">
<p>It is a <termref def="dt-static-error">static error</termref> if the
<code>select</code> attribute of the <elcode>xsl:map-entry</elcode> element
is present unless the element has no children other than
<elcode>xsl:fallback</elcode> elements.</p>
</error>
</p>
</p>-->



Expand Down Expand Up @@ -35699,6 +35726,10 @@ the same group, and the-->
&lt;/xsl:for-each&gt;
&lt;/xsl:map&gt;
</eg>
<p>This could also be written:</p>
<eg role="xslt-declaration" xml:space="preserve"><![CDATA[<xsl:map select="
map:key-value-pairs($map) ! { ?key : array{ ?value } }"/>
]]></eg>
</example>

<div3 id="duplicate-keys" diff="add" at="2022-01-01">
Expand All @@ -35712,16 +35743,16 @@ the same group, and the-->
</change>
</changes>

<p>This section describes what happens when two or more maps returned by the sequence constructor
<p>This section describes what happens when two or more maps in the input sequence of
within an <elcode>xsl:map</elcode> instruction contain duplicate keys: that is, when one of these
maps contains an entry with key <var>K</var>, and another contains an entry with key <var>L</var>,
and <code diff="chg" at="2023-01-25">fn:atomic-equal(K, L)</code> returns <code>true</code>.</p>

<p><error spec="XT" class="DE" code="3365" type="dynamic">
<p>In the absence of the <code>on-duplicates</code> attribute,
a <termref def="dt-dynamic-error">dynamic error</termref> occurs if the set of
keys in the maps resulting from evaluating the sequence constructor
<error.extra>within an <elcode>xsl:map</elcode> instruction</error.extra>
keys in the maps making up the input sequence
<error.extra>of an <elcode>xsl:map</elcode> instruction</error.extra>
contains duplicates.</p>
</error></p>

Expand All @@ -35733,12 +35764,12 @@ the same group, and the-->

<p>The order of the arguments passed to the function reflects the order of the maps in which
the duplicate entries appear: if map <var>M</var> and map <var>N</var> contain values <var>V/M</var>
and <var>V/N</var> for the same key, and <var>M</var> precedes <var>N</var> in the sequence
of maps returned by the sequence constructor, then the callback function is called with arguments
and <var>V/N</var> for the same key, and <var>M</var> precedes <var>N</var> in the input sequence,
then the callback function is called with arguments
<var>V/M</var> and <var>V/N</var> in that order.
</p>

<p>If more than two maps contain values for the same key, then the callback function is invoked repeatedly.
<p>If more than two maps in the input sequence contain values for the same key, then the callback function is invoked repeatedly.
Let <var>F</var> be the callback function.
Then if (for example) four maps supply the values <var>A</var>, <var>B</var>, <var>C</var>, and <var>D</var>
for a given key <var>K</var>, in that order, the evaluation is as follows:</p>
Expand Down

0 comments on commit 972ce90

Please sign in to comment.