- From: <bugzilla@jessica.w3.org>
- Date: Mon, 03 Oct 2016 09:55:08 +0000
- To: public-qt-comments@w3.org
https://www.w3.org/Bugs/Public/show_bug.cgi?id=29890 Bug ID: 29890 Summary: [SER31] Arrays in sequence normalization Product: XPath / XQuery / XSLT Version: Candidate Recommendation Hardware: PC OS: Windows NT Status: NEW Severity: normal Priority: P2 Component: Serialization 3.1 Assignee: cmsmcq@blackmesatech.com Reporter: tim@cbcl.co.uk QA Contact: public-qt-comments@w3.org Target Milestone: --- Consider document { [1] } The content expression of a document node constructor is processed in exactly the same way as an enclosed expression in the content of a direct element constructor, as described in Step 1e of 3.9.1.3 Content. In XQ31 3.9.1.3 Content, point 1.e.i. we read: "Each array returned by the enclosed expression is flattened by calling the function array:flatten() before the steps that follow." So this is equivalent to document { 1 } which can be serialized. Now compare with [1] In SER31, 2 Sequence Normalization, we read: "Where the process of converting the input sequence to a normalized sequence indicates that a value MUST be cast to xs:string, that operation is defined in Section 19.1.1 Casting to xs:string and xs:untypedAtomic FO31 of [XQuery and XPath Functions and Operators 3.1]. Where a step in the sequence normalization process indicates that a node should be copied, the copy is performed in the same way as an XSLT xsl:copy-of instruction that has a validation attribute whose value is preserve and has a select attribute whose effective value is the node, as described in Section 11.9.2 Deep Copy XT30 of [XSL Transformations (XSLT) Version 3.0], or equivalently in the same way as an XQuery content expression as described in Step 1e of Section 3.9.1.3 Content XQ31 of [XQuery 3.1: An XML Query Language], where the construction mode is preserve." This refers to Step 1e, but this is only invoked when copying nodes, not function items. So it would appear that [1] cannot be serialized, because the array flattening doesn't occur. If I'm correct, I think this marks the first time that serialization of document { E } and E behave differently under serialization (other than in error code). Was this intentional? -- You are receiving this mail because: You are the QA Contact for the bug.
Received on Monday, 3 October 2016 09:55:17 UTC