Bug #4829
closedStatic variable initialised to node values cause run-time failure
100%
Description
When compiling with the XJ compiler a static variable initialised to a node such as:
<xsl:variable name="t" static="yes" select="doc('testStatic.xml')"/>
where testStatic.xml
is:
<foo a="1" xmlns:b="BBB" b:attribute="" xmlns="Flibbertygibbet">
<bar/>
</foo>
the generated package contains a component definition:
<co id='0' binds=''>
<globalVariable name='Q{}t' as='1ND' line='7' .... visibility='PRIVATE' flags='s'>
<node kind='9' content='<foo xmlns="Flibbertygibbet" xmlns:b="BBB" a="1" b:attribute="">
 <bar/>
</foo>' baseUri='....testStatic.xml'/>
</globalVariable>
</co>
that is the serialization of the document is held as the content
property of a node
instruction, with the kind
of the node indicated.
If the selection is doc('testStatic.xml')/(*,*/@*)
the compilation becomes:
<globalVariable name='Q{}t' as='*N' line='7' ....visibility='PRIVATE' flags='s'>
<literal count='3'>
<node kind='1' content='<foo xmlns="Flibbertygibbet" xmlns:b="BBB" a="1" b:attribute="">
 <bar/>
</foo>' baseUri='..../testStatic.xml'/>
<node kind='2' localName='a' content='1'/>
<node kind='2' localName='attribute' prefix='b' ns='BBB' content=''/>
</literal>
</globalVariable>
Execution of a reference to this variable in SaxonJS2
throws an error as there is currently no support for a node
instruction.
There appear to be two routes to solution:
- Converting the export to a nested set of aleady supported node construction instructions
elem
,att
,text
etc, which will be very costly and increase the export size considerably. - Add support for a
node
instruction, using the implementation code forparse-xml()
when necessary
The latter seems much more sensible.
Related issues
Updated by Michael Kay about 4 years ago
I thought we had an open issue on this, but I can't find it.
I think we should probably ban it. While we can handle some simple cases by putting a serialization of the node into the SEF file, it doesn't handle the general case, where for example $x
is bound to a document node, and $y
is bound to $x/*
. We then get to the kind of problem that Java serialization faces, of serializing a general graph with arbitrary relationships between the nodes. Unless we're going to do that properly, I don't think we should do it at all.
A simple rule (you can't export a stylesheet if there are static variables bound to nodes) is easier to understand than a more complex set of restrictions.
Updated by Michael Kay almost 4 years ago
- Related to Bug #4035: Exporting a stylesheet containing node-valued static variables added
Updated by Michael Kay almost 4 years ago
This was actually covered on the Saxon-J side by bug #4035. To resolve that bug (on the Java side) we added capability to export node-valued static variables to a SEF file in Saxon-J, but we didn't add the corresponding code to import them in Saxon-JS.
Updated by Community Admin almost 4 years ago
- Applies to JS Branch 2 added
- Applies to JS Branch deleted (
2.0)
Updated by Norm Tovey-Walsh over 2 years ago
- Priority changed from Normal to High
- Sprint/Milestone set to SaxonJS 3.0
Updated by Debbie Lockett over 2 years ago
- Applies to JS Branch Trunk added
The nodejs unit test iss4829 was added on the main branch a while ago (2022-05-27).
The test passes when the test stylesheet is XX-compiled, but fails when XJ-compiled. E.g. when compiled with SaxonJ 11.4, we get the following error at run-time:
Internal error: Unknown expr: node parent=undefined
Updated by Debbie Lockett 2 months ago
See also xslt30 tests static-028, -029, -030
which currently fail with xjcompile
.
Updated by Debbie Lockett 2 months ago
- Category set to XSLT Conformance
- Status changed from New to Resolved
- Priority changed from High to Normal
- Fix Committed on JS Branch Trunk added
I added another xslt30 test static-032
which tests a static variable which is a sequence of different kinds of nodes (including processing instruction, and comment nodes).
SaxonJS code fix committed in Expr.js to handle "node"
expressions in an SEF, as used for such node-valued static variables. The relevant xslt30 tests static-028, -029, -030, -32
now pass with xjcompile
.
The nodejs unit test iss4829 also now passes with XJ compile, so I have updated the compiler.json
configuration file to run with XJ compile too.
Updated by Debbie Lockett 21 days ago
- Status changed from Resolved to Closed
- % Done changed from 0 to 100
- Fixed in JS Release set to SaxonJS 3.0
Bug fix applied in the SaxonJS 3.0.0-beta1 preview release.
Please register to edit this issue
Also available in: Atom PDF Tracking page