Project

Profile

Help

xsl:result-document inside of an xsl:function?

Added by Martin Honnen about 1 month ago

https://www.w3.org/TR/xslt-30/#result-document-restrictions says (emphasis added by me):

There are restrictions on the use of the xsl:result-document instruction, designed to ensure that the results are fully interoperable even when processors optimize the sequence in which instructions are evaluated. Informally, the restriction is that the xsl:result-document instruction can only be used while writing a final result tree, not while writing to a temporary tree or a sequence. This restriction is defined formally as follows.

[Definition: Each instruction in the stylesheet is evaluated in one of two possible output states: final output state or temporary output state ].

[Definition: The first of the two output states is called final output state. This state applies when instructions are writing to a final result tree.]

[Definition: The second of the two output states is called temporary output state. This state applies when instructions are writing to a temporary tree or any other non-final destination.]

The instructions in the initial named template are evaluated in final output state. An instruction is evaluated in the same output state as its calling instruction, except that xsl:variable, xsl:param, xsl:with-param, xsl:function, xsl:key, xsl:sort, xsl:accumulator-rule, and xsl:merge-key always evaluate the instructions in their contained sequence constructor in temporary output state .

[ERR XTDE1480] It is a dynamic error to evaluate the xsl:result-document instruction in temporary output state .

However, when reading through the SaxonJS 3 documentation about many ixsl extension functions like https://www.saxonica.com/saxonjs/documentation3/index.html#!ixsl-extension/functions/doc, I find usages like

Asynchronously fetch an XML document, proceeding when the document is available:

  <xsl:template name="xsl:initial-template">
    <ixsl:promise select="ixsl:doc($href)"
      on-completion="f:go#1"/>
  </xsl:template>
  
  <xsl:function name="f:go" ixsl:updating="true">
    <xsl:param name="doc" as="document-node()"/>
    <xsl:result-document href="{$output-file}">
      <xsl:copy-of select="$doc"/>
    </xsl:result-document>
  </xsl:function>

Is the ixsl:updating decisive here to allow the use of xsl:result-document in an xsl:function with SaxonJS 3?


Replies (1)

RE: xsl:result-document inside of an xsl:function? - Added by Michael Kay about 1 month ago

Yes, that's correct. As stated in various places in the documentation:

A common requirement is for the handler function to have updating side-effects, for example by calling xsl:result-document. For this to be allowed, the function must be declared with ixsl:updating="yes".

    (1-1/1)

    Please register to reply