mirror of
https://github.com/jezhiggins/arabica
synced 2025-01-22 07:27:19 +01:00
1439 lines
No EOL
74 KiB
XML
1439 lines
No EOL
74 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<!DOCTYPE doc SYSTEM "../support/disc.dtd">
|
|
<!--
|
|
Copyright (C) The Organization for the Advancement of
|
|
Structured Information Standards [OASIS] (2001). All Rights
|
|
Reserved.
|
|
|
|
This document and translations of it may be copied and
|
|
furnished to others, and derivative works that comment on
|
|
or otherwise explain it or assist in its implementation may
|
|
be prepared, copied, published and distributed, in whole
|
|
or in part, without restriction of any kind, provided that the
|
|
above copyright notice and this paragraph are included on
|
|
all such copies and derivative works. However, this
|
|
document itself may not be modified in any way, such as by
|
|
removing the copyright notice or references to OASIS,
|
|
except as needed for the purpose of developing OASIS
|
|
specifications, in which case the procedures for copyrights
|
|
defined in the OASIS Intellectual Property Rights document
|
|
must be followed, or as required to translate it into
|
|
languages other than English.
|
|
|
|
The limited permissions granted above are perpetual and
|
|
will not be revoked by OASIS or its successors or assigns.
|
|
|
|
This document and the information contained herein is
|
|
provided on an "AS IS" basis and OASIS DISCLAIMS ALL
|
|
WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
|
|
BUT NOT LIMITED TO ANY WARRANTY THAT THE USE
|
|
OF THE INFORMATION HEREIN WILL NOT INFRINGE
|
|
ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
|
|
MERCHANTABILITY OR FITNESS FOR A PARTICULAR
|
|
PURPOSE.
|
|
-->
|
|
<doc date="$Date: 2001/12/07 20:51:34 $(UTC)" configuration-href="xsltcfg.xml">
|
|
<verbiage>
|
|
<title>Discretionary behavior in '<strong>XSL
|
|
Transformations (XSLT)</strong>' and '<strong>XPath</strong>'</title>
|
|
<intro>
|
|
<p>This document details identified areas of the XSLT and XPath
|
|
Recommendations that describe or allow optionality in the behavior
|
|
of an XSLT processor. The majority of the identified optional or
|
|
discretionary behavior concerns detection or recovery from error
|
|
conditions, but other areas have been identified as well. This
|
|
document is also the foundation for a questionnaire for developers
|
|
of XSLT processors; it asks questions that a test lab would need
|
|
answered in order to administer the test suite to that devloper's
|
|
processor.</p>
|
|
<p>Each area of discretionary behavior is shown as an entry
|
|
comprising at least five items:</p>
|
|
<ul>
|
|
|
|
<li>Unique, descriptive, but somewhat arbitrary identifier (used in
|
|
cataloging test cases)</li>
|
|
|
|
|
|
<li>A simple citation of the XSLT Recommendation section number and
|
|
title of the section containing the description of the discretionary behavior, or
|
|
erratum number</li>
|
|
|
|
|
|
<li>A more complex citation in the form of an XPath for locating the
|
|
excerpt of the XML version of the XSLT or XPath Recommendation or
|
|
Errata document</li>
|
|
|
|
|
|
<li>Excerpt from the XSLT or XPath Recommendation of the paragraph
|
|
or other element located by the XPath and containing the
|
|
description of the discretionary error handling. The description of
|
|
the discretionary behavior is highlighted.</li>
|
|
|
|
|
|
<li>Description of the discretionary behavior recast as a question,
|
|
which can be answered briefly. The questions would be asked of each
|
|
processor developer.</li>
|
|
|
|
<li>Guidance concerning interlocking answers to questions is
|
|
provided when pertinent.</li>
|
|
|
|
</ul>
|
|
<p>Answers to the "testable" questions are expressed as keywords so
|
|
that the cataloging information about the test cases will be
|
|
readable without reference to this document, at least after one has
|
|
attained familiarity with the discretionary areas. The complete set
|
|
of keywords, as of this writing, is: <all-choices/>.
|
|
</p>
|
|
<p>Where longer answers are required depending on the brief answer,
|
|
the "ELABORATE" flag is shown.</p>
|
|
<p>The questions are not all independent. The "INTERLOCK" flag
|
|
appears when answers to two or more questions should be reviewed
|
|
for consistency.</p>
|
|
</intro>
|
|
<group-intro status="Implemented">
|
|
<p>The following items represent statements in the XSLT and XPath
|
|
Recommendations that identify discretionary behavior that are
|
|
controlling test selection in the current version of the test
|
|
suite.</p>
|
|
</group-intro>
|
|
<group-intro status="Active">
|
|
<p>The following items represent statements in the XSLT and XPath
|
|
Recommendations that identify discretionary behavior that are
|
|
proposed for testing in the next deliverable version of the test
|
|
suite.</p>
|
|
</group-intro>
|
|
<group-intro status="Postponed">
|
|
<p>The following items represent statements in the XSLT and XPath
|
|
Recommendations that identify discretionary behavior that is
|
|
proposed to postpone, usually until a "core" test suite is shipped.
|
|
Language-concerned items will be added as soon as we have
|
|
language-specific tests submitted. Each item should be reviewed and
|
|
voted by committee.</p>
|
|
</group-intro>
|
|
<group-intro status="Configuration">
|
|
<p>The following items represent statements in the XSLT and XPath
|
|
Recommendations that identify discretionary behaviors that are
|
|
acknowledged as discretionary but considered as not testable for
|
|
conformance purposes. However, asking the questions is still
|
|
reasonable, as it will help test labs configure and use the suite. Any test
|
|
marked with any of these discretionary items should be excluded
|
|
from the "conformance" suite, but may be useful to distribute. Each
|
|
item should be reviewed and voted by the committee.</p>
|
|
</group-intro>
|
|
<group-intro status="Recognized">
|
|
<p>The following items represent statements in the XSLT and XPath
|
|
Recommendations that identify discretionary behavior that is out of
|
|
scope for XSLT/XPath conformance testing. Items are present here so that the
|
|
catalog recognizes all possible discretionary behavior.</p>
|
|
<p>Since the specification explicitly says that the
|
|
elements/attributes must not affect the behavior of the XSLT
|
|
components, the discretionary alternatives (ignore the foreign
|
|
components or take some XSLT-transparent action directed by the
|
|
foreign components) do not serve to control exclusion of test
|
|
cases.</p>
|
|
<p>The verbiage about setting attribute values specified externally
|
|
as default is mainly a warning to stylesheet writers (if you depend
|
|
on default values being inserted by validation, your stylesheet may
|
|
not work in some scenarios) rather than a grant of discretion to
|
|
the developer. More precisely, a developer of a monolithic
|
|
parser/styler has discretion to not validate, but that applies to
|
|
the parsing phase rather than the transformation phase.</p>
|
|
</group-intro>
|
|
<question-intro>
|
|
<p>Questionnaire for XSLT processor developers</p>
|
|
<p>The XSLT and XPath Recommendations were written in hopes that XML
|
|
data could be transformed as needed by the products of many vendors.
|
|
Builders of Web sites should be able to use tools to create XSLT
|
|
stylesheets regardless of the XSLT processor that will ultimately
|
|
execute the styling. The OASIS XSLT/XPath test suite is the most
|
|
comprehensive measure of the necessary interoperability.</p>
|
|
<p>As a developer trying to meet the W3C Recommendations, you know how
|
|
the verbiage of the Recommendations contains precisely-stated
|
|
provisions that interlock in complex and sometimes surprising ways.
|
|
There are also cases where you have leeway to choose one of two
|
|
allowable behaviors or decide output details. Below is our
|
|
questionnaire about the choices. We want you to specify the choices
|
|
you made when creating your XSLT processor. You are encouraged to
|
|
post the answers on your own Web site as well as sending them to us.
|
|
When you prepare to use our test suite, an XML document containing
|
|
your answers is used to filter out test cases that assume the other
|
|
choice, leaving a rendition that is custom-fit to your processor
|
|
insofar as allowed by the Recommendations.</p>
|
|
<p>Conformance to the Recommendations is tested by running thousands
|
|
of small test cases, each with processor inputs and an expected
|
|
output. Comparison of actual and expected output neutralizes all
|
|
details that have been defined as irrelevant by the XML, InfoSet,
|
|
Namespaces, and XSLT Recommendations. There is no reason to think
|
|
that all tests have equal weight, hence we discourage talk of
|
|
percentages of conformance and the like. If you have some tests
|
|
that you would like to be included in a later edition of our
|
|
suite, see howtosub.htm for submission instructions.</p>
|
|
</question-intro>
|
|
</verbiage>
|
|
<items>
|
|
<item id="unresolved-strip-preserve-conflict" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="3.4 Whitespace Stripping"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('strip')/p[7]"/>
|
|
<choices>
|
|
<choice value="choose-last"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if this leaves more than one match. <span style="COLOR: red">An XSLT processor may signal the error; if it does not
|
|
signal the error, it must recover by choosing, from amongst the
|
|
matches that are left, the one that occurs last in the
|
|
stylesheet.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when there is an
|
|
unresolved conflict between matches to xsl:strip-space and
|
|
xsl:preserve-space elements?</question>
|
|
</item>
|
|
<item id="unresolved-template-rule-conflict" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="5.5 Conflict Resolution for Template Rules"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('conflict')/p[2]"/>
|
|
<choices>
|
|
<choice value="choose-last"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if this leaves more than one matching template
|
|
rule. <span style="COLOR: red">An XSLT processor may signal the
|
|
error; if it does not signal the error, it must recover by
|
|
choosing, from amongst the matching template rules that are left,
|
|
the one that occurs last in the stylesheet.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when there is an
|
|
unresolved conflict between matches to xsl:template elements?</question>
|
|
</item>
|
|
<item id="multiple-alias-same-precedence" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.1 Literal Result Elements"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="anchor" place="literal-result-element"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('literal-result-element')/p[5]"/>
|
|
<choices>
|
|
<choice value="choose-last"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>A stylesheet can use the xsl:namespace-alias element to declare
|
|
that one namespace URI is an alias for another namespace URI. When
|
|
a literal namespace URI has been declared to be an alias for
|
|
another namespace URI, then the namespace URI in the result tree
|
|
will be the namespace URI that the literal namespace URI is an
|
|
alias for, instead of the literal namespace URI itself. The
|
|
xsl:namespace-alias element declares that the namespace URI bound
|
|
to the prefix specified by the stylesheet-prefix attribute is an
|
|
alias for the namespace URI bound to the prefix specified by the
|
|
result-prefix attribute. Thus, the stylesheet-prefix attribute
|
|
specifies the namespace URI that will appear in the stylesheet, and
|
|
the result-prefix attribute specifies the corresponding namespace
|
|
URI that will appear in the result tree. The default namespace (as
|
|
declared by xmlns) may be specified by using #default instead of a
|
|
prefix. If a namespace URI is declared to be an alias for multiple
|
|
different namespace URIs, then the declaration with the highest
|
|
import precedence is used. It is an error if there is more than one
|
|
such declaration. <span style="COLOR: red">An XSLT processor may
|
|
signal the error; if it does not signal the error, it must recover
|
|
by choosing, from amongst the declarations with the highest import
|
|
precedence, the one that occurs last in the stylesheet.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when a namespace URI is
|
|
declared to be an alias for multiple different namespace URIs and
|
|
the declarations share the highest import precedence?</question>
|
|
</item>
|
|
<item id="element-name-not-QName" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.2 Creating Elements with xsl:element"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[7]/div2[1]/div3[2]/p[2]"/>
|
|
<choices>
|
|
<choice value="pass-through"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The name attribute is interpreted as an attribute value
|
|
template. It is an error if the string that results from
|
|
instantiating the attribute value template is not a QName. <span style="COLOR: red">An XSLT processor may signal the error; if it
|
|
does not signal the error, then it must recover by making the the
|
|
result of instantiating the xsl:element element be the sequence of
|
|
nodes created by instantiating the content of the xsl:element
|
|
element, excluding any initial attribute nodes.</span> If the
|
|
namespace attribute is not present then the QName is expanded into
|
|
an expanded-name using the namespace declarations in effect for the
|
|
xsl:element element, including any default namespace
|
|
declaration.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when the result of
|
|
instantiating the name attribute of the xsl:element element is not
|
|
a QName?</question>
|
|
</item>
|
|
<item id="attribute-name-not-QName" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.3 Creating Attributes with xsl:attribute"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('creating-attributes')/p[2]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The name attribute is interpreted as an attribute value
|
|
template. It is an error if the string that results from
|
|
instantiating the attribute value template is not a QName or is the
|
|
string xmlns. <span style="COLOR: red">An XSLT processor may signal
|
|
the error; if it does not signal the error, it must recover by not
|
|
adding the attribute to the result tree.</span> If the namespace
|
|
attribute is not present, then the QName is expanded into an
|
|
expanded-name using the namespace declarations in effect for the
|
|
xsl:attribute element, not including any default namespace
|
|
declaration.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when the result of
|
|
instantiating the name attribute of the xsl:attribute element is
|
|
not a QName?</question>
|
|
</item>
|
|
<item id="add-attribute-after-children" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.3 Creating Attributes with xsl:attribute"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('creating-attributes')/ulist[1]/item[1]/p[1]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>Adding an attribute to an element after children have been added
|
|
to it; <span style="COLOR: red">implementations may either signal
|
|
the error or ignore the attribute.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when an attribute is
|
|
added to an element after children have been added to it?</question>
|
|
</item>
|
|
<item id="add-attribute-to-non-element" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.3 Creating Attributes with xsl:attribute"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('creating-attributes')/ulist[1]/item[2]/p[1]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>Adding an attribute to a node that is not an element; <span style="COLOR: red">implementations may either signal the error or
|
|
ignore the attribute.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when an attribute is
|
|
added to a node that is not an element?</question>
|
|
</item>
|
|
<item id="attribute-non-text-content" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.3 Creating Attributes with xsl:attribute"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('creating-attributes')/ulist[1]/item[3]/p[1]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>Creating nodes other than text nodes during the instantiation of
|
|
the content of the xsl:attribute element; <span style="COLOR: red">
|
|
implementations may either signal the error or ignore the offending
|
|
nodes.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when nodes other than
|
|
text nodes are created when instantiating the content of the
|
|
xsl:attribute element?</question>
|
|
</item>
|
|
<item id="two-attribute-set-same-attribute" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.4 Named Attribute Sets"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('attribute-sets')/p[6]"/>
|
|
<choices>
|
|
<choice value="choose-last"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>Multiple definitions of an attribute set with the same
|
|
expanded-name are merged. An attribute from a definition that has
|
|
higher import precedence takes precedence over an attribute from a
|
|
definition that has lower import precedence. It is an error if
|
|
there are two attribute sets that have the same expanded-name and
|
|
equal import precedence and that both contain the same attribute,
|
|
unless there is a definition of the attribute set with higher
|
|
import precedence that also contains the attribute. <span style="COLOR: red">An XSLT processor may signal the error; if it does not
|
|
signal the error, it must recover by choosing from amongst the
|
|
definitions that specify the attribute that have the highest import
|
|
precedence the one that was specified last in the
|
|
stylesheet.</span> Where the attributes in an attribute set were
|
|
specified is relevant only in merging the attributes into the
|
|
attribute set; it makes no difference when the attribute set is
|
|
used.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when two attribute sets
|
|
that have the same expanded name and share the highest import
|
|
precedence both contain the same attribute?</question>
|
|
</item>
|
|
<item id="PI-name-not-NCName-PItarget" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.3 Creating Processing Instructions"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[7]/div2[3]/p[4]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if the string that results from instantiating the
|
|
name attribute is not both an NCName and a PITarget. <span style="COLOR: red">An XSLT processor may signal the error; if it does not
|
|
signal the error, it must recover by not adding the processing
|
|
instruction to the result tree.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when the result of
|
|
instantiating the name attribute of the xsl:processing-instruction
|
|
element is not an NCName and a PITarget?</question>
|
|
</item>
|
|
<item id="PI-non-text-content" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.3 Creating Processing Instructions"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[7]/div2[3]/p[5]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if instantiating the content of
|
|
xsl:processing-instruction creates nodes other than text nodes.
|
|
<span style="COLOR: red">An XSLT processor may signal the error; if
|
|
it does not signal the error, it must recover by ignoring the
|
|
offending nodes together with their content.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when nodes other than
|
|
text nodes are created when instantiating the content of the
|
|
xsl:processing-instruction element?</question>
|
|
</item>
|
|
<item id="PI-content-contains-delimiter" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.3 Creating Processing Instructions"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[7]/div2[3]/p[6]"/>
|
|
<choices>
|
|
<choice value="add-space"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if the result of instantiating the content of the
|
|
xsl:processing-instruction contains the string ?>. <span style="COLOR: red">An XSLT processor may signal the error; if it does not
|
|
signal the error, it must recover by inserting a space after any
|
|
occurrence of ? that is followed by a >.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when the result of
|
|
instantiating the content of the xsl:processing-instruction element
|
|
contains the string ?>?</question>
|
|
</item>
|
|
<item id="comment-non-text-content" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.4 Creating Comments"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[7]/div2[4]/p[4]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if instantiating the content of xsl:comment creates nodes other than text nodes. An XSLT
|
|
processor may signal the error; if it does not signal the error, it must recover by ignoring the offending
|
|
nodes together with their content.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when nodes other than text nodes are created when instantiating the content of the
|
|
xsl:comment element?</question>
|
|
</item>
|
|
<item id="comment-content-contains-delimiter" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.4 Creating Comments"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[7]/div2[4]/p[5]"/>
|
|
<choices>
|
|
<choice value="add-space"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if the result of instantiating the content of the
|
|
xsl:comment contains the string -- or ends with -. <span style="COLOR: red">An XSLT processor may signal the error; if it does not
|
|
signal the error, it must recover by inserting a space after any
|
|
occurrence of - that is followed by another - or that ends the
|
|
comment.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when the result of
|
|
instantiating the content of the xsl:comment element contains the
|
|
string -- or ends with -?</question>
|
|
</item>
|
|
<item id="RTF-root-attribute-namespace-child" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="11.2 Values of Variables and Parameters"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('variable-values')/ulist[1]/item[2]/p[2]"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error if a member of the sequence of nodes created by
|
|
instantiating the template is an attribute node or a namespace
|
|
node, since a root node cannot have an attribute node or a
|
|
namespace node as a child. <span style="COLOR: red">An XSLT
|
|
processor may signal the error; if it does not signal the error, it
|
|
must recover by not adding the attribute node or namespace
|
|
node.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when instantiating a
|
|
variable-binding element adds an attribute node or namespace node
|
|
as a child of the root of the result tree fragment?</question>
|
|
</item>
|
|
<item id="add-namespace-to-non-element" status="Active">
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="section" place="Erratum E25, affecting 7.5"/>
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="anchor" place="E25"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>When the current node is a namespace node, then copying it adds
|
|
a namespace node to the containing node in the result tree. <span style="COLOR: red">It is an error if this containing node is not an
|
|
element; implementations may either signal the error or ignore the
|
|
namespace node.</span> It is an error to add a namespace node to an
|
|
element after children have been added to it or after attributes
|
|
have been added to it; implementations may either signal an error
|
|
or ignore the namespace node. It is an error to add a namespace
|
|
node to an element if the element already has a namespace node with
|
|
the same name, unless both namespace nodes have the same
|
|
string-value, in which case the duplicate is ignored. It is an
|
|
error to add a namespace node to an element if the namespace node
|
|
has a null name and the element has a null namespace URI.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when a namespace is
|
|
copied to a node that is not an element?</question>
|
|
</item>
|
|
<item id="add-namespace-after-children" status="Active">
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="section" place="Erratum E25, affecting 7.5"/>
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="anchor" place="E25"/>
|
|
<choices>
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>When the current node is a namespace node, then copying it adds
|
|
a namespace node to the containing node in the result tree. It is
|
|
an error if this containing node is not an element; implementations
|
|
may either signal the error or ignore the namespace node. <span style="COLOR: red">It is an error to add a namespace node to an
|
|
element after children have been added to it or after attributes
|
|
have been added to it; implementations may either signal an error
|
|
or ignore the namespace node.</span> It is an error to add a
|
|
namespace node to an element if the element already has a namespace
|
|
node with the same name, unless both namespace nodes have the same
|
|
string-value, in which case the duplicate is ignored. It is an
|
|
error to add a namespace node to an element if the namespace node
|
|
has a null name and the element has a null namespace URI.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when a namespace is
|
|
copied to an element after children have been added to it?</question>
|
|
</item>
|
|
<item id="number-not-positive" status="Implemented">
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="section" place="Erratum E24, affecting 7.7"/>
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="anchor" place="E24"/>
|
|
<choices>
|
|
<choice value="pass-through"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The xsl:number element is used to insert a formatted number into
|
|
the result tree. The number to be inserted may be specified by an
|
|
expression. The value attribute contains an expression. The
|
|
expression is evaluated and the resulting object is converted to a
|
|
number as if by a call to the number function. <span style="COLOR: red">It is an error if the number is NaN, infinite or less than
|
|
0.5; an XSLT processor may signal the error; if it does not signal
|
|
the error, it must recover by converting the number to a string as
|
|
if by a call to the string function and inserting the resulting
|
|
string into the result tree.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when xsl:number is given
|
|
NaN, Infinity, or a non-positive number?</question>
|
|
</item>
|
|
<item id="unretrievable-resource" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="12.1 Multiple Source Documents"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('document')/p[3]"/>
|
|
<choices>
|
|
<choice value="return-empty"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>When the first argument to the document function is not a
|
|
node-set, the first argument is converted to a string as if by a
|
|
call to the string function. This string is treated as a URI
|
|
reference; the resource identified by the URI is retrieved. The
|
|
data resulting from the retrieval action is parsed as an XML
|
|
document and a tree is constructed in accordance with the data
|
|
model (see 3 Data Model). <span style="COLOR: red">If there is an
|
|
error retrieving the resource, then the XSLT processor may signal
|
|
an error; if it does not signal an error, it must recover by
|
|
returning an empty node-set.</span> One possible kind of retrieval
|
|
error is that the XSLT processor does not support the URI scheme
|
|
used by the URI. An XSLT processor is not required to support any
|
|
particular URI schemes. The documentation for an XSLT processor
|
|
should specify which URI schemes the XSLT processor supports.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when there is an error
|
|
retreiving the resouce identified by a URI in an argument to the
|
|
document function?</question>
|
|
</item>
|
|
<item id="unprocessable-fragment-identifier" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="12.1 Multiple Source Documents"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('document')/p[4]"/>
|
|
<choices>
|
|
<choice value="return-empty"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>If the URI reference does not contain a fragment identifier,
|
|
then a node-set containing just the root node of the document is
|
|
returned. If the URI reference does contain a fragment identifier,
|
|
the function returns a node-set containing the nodes in the tree
|
|
identified by the fragment identifier of the URI reference. The
|
|
semantics of the fragment identifier is dependent on the media type
|
|
of the result of retrieving the URI. <span style="COLOR: red">If
|
|
there is an error in processing the fragment identifier, the XSLT
|
|
processor may signal the error; if it does not signal the error, it
|
|
must recover by returning an empty node-set.</span> Possible errors
|
|
include:</p>
|
|
</excerpt>
|
|
<question scope="Filter">What-happens when there is an error
|
|
processing the fragment identifier in a URI in an argument to the
|
|
document function?</question>
|
|
</item>
|
|
<item id="document-unresolvable-URI" status="Active">
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="section" place="Erratum E14, affecting 12.1"/>
|
|
<spec-citation spec="XSLT-Errata" version="1.0" type="anchor" place="E14"/>
|
|
<choices>
|
|
<choice value="return-empty"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The URI reference may be relative. The base URI (see [3.2 Base
|
|
URI]) of the node in the second argument node-set that is first in
|
|
document order is used as the base URI for resolving the relative
|
|
URI into an absolute URI. <span style="COLOR: red">It is an error
|
|
if the second argument node-set is empty and the URI reference is
|
|
relative; the XSLT processor may signal the error; if it does not
|
|
signal an error, it must recover by returning an empty
|
|
node-set.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when the two arguments
|
|
to the document() function do not enable resolution of a relative
|
|
URI reference?</question>
|
|
</item>
|
|
<item id="two-output-same-attribute" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16 Output"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/p[8]"/>
|
|
<choices>
|
|
<choice value="choose-last"/>
|
|
<choice value="raise-error"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>A stylesheet may contain multiple xsl:output elements and may
|
|
include or import stylesheets that also contain xsl:output
|
|
elements. All the xsl:output elements occurring in a stylesheet are
|
|
merged into a single effective xsl:output element. For the
|
|
cdata-section-elements attribute, the effective value is the union
|
|
of the specified values. For other attributes, the effective value
|
|
is the specified value with the highest import precedence. It is an
|
|
error if there is more than one such value for an attribute. <span style="COLOR: red">An XSLT processor may signal the error; if it
|
|
does not signal the error, if should recover by using the value
|
|
that occurs last in the stylesheet.</span> The values of attributes
|
|
are defaulted after the xsl:output elements have been merged;
|
|
different output methods may have different default values for an
|
|
attribute.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when there is more than
|
|
one instantiation of the same attribute on multiple xsl:output
|
|
elements that share the highest import precedence?</question>
|
|
</item>
|
|
<item id="unsupported-encoding-error" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.1 XML Output Method"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/div2[1]/p[5]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The encoding attribute specifies the preferred encoding to use
|
|
for outputting the result tree. XSLT processors are required to
|
|
respect values of UTF-8 and UTF-16. For other values, <span style="COLOR: red">if the XSLT processor does not support the specified
|
|
encoding it may signal an error; if it does not signal an error it
|
|
should use UTF-8 or UTF-16 instead</span>. The XSLT processor must
|
|
not use an encoding whose name does not match the EncName
|
|
production of the XML Recommendation . If no encoding attribute is
|
|
specified, then the XSLT processor should use either UTF-8 or
|
|
UTF-16. It is possible that the result tree will contain a
|
|
character that cannot be represented in the encoding that the XSLT
|
|
processor is using for output. In this case, if the character
|
|
occurs in a context where XML recognizes character references (i.e.
|
|
in the value of an attribute node or text node), then the character
|
|
should be output as a character reference; otherwise (for example
|
|
if the character occurs in the name of an element) the XSLT
|
|
processor should signal an error.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is an error raised when the encoding
|
|
attribute of the xsl:output element specifies an unsupported
|
|
encoding?</question>
|
|
</item>
|
|
|
|
<item id="unsupported-encoding-UTF-8" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.1 XML Output Method"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/div2[1]/p[5]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The encoding attribute specifies the preferred encoding to use
|
|
for outputting the result tree. XSLT processors are required to
|
|
respect values of UTF-8 and UTF-16. For other values, <span style="COLOR: red">if the XSLT processor does not support the specified
|
|
encoding it may signal an error; if it does not signal an error it
|
|
should use UTF-8 or UTF-16 instead</span>. The XSLT processor must
|
|
not use an encoding whose name does not match the EncName
|
|
production of the XML Recommendation . If no encoding attribute is
|
|
specified, then the XSLT processor should use either UTF-8 or
|
|
UTF-16. It is possible that the result tree will contain a
|
|
character that cannot be represented in the encoding that the XSLT
|
|
processor is using for output. In this case, if the character
|
|
occurs in a context where XML recognizes character references (i.e.
|
|
in the value of an attribute node or text node), then the character
|
|
should be output as a character reference; otherwise (for example
|
|
if the character occurs in the name of an element) the XSLT
|
|
processor should signal an error.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is UTF-8 encoding always used when
|
|
the encoding attribute of the xsl:output element specifies an
|
|
unsupported encoding?</question>
|
|
</item>
|
|
<item id="unsupported-encoding-UTF-16" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.1 XML Output Method"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/div2[1]/p[5]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The encoding attribute specifies the preferred encoding to use
|
|
for outputting the result tree. XSLT processors are required to
|
|
respect values of UTF-8 and UTF-16. For other values, <span style="COLOR: red">if the XSLT processor does not support the specified
|
|
encoding it may signal an error; if it does not signal an error it
|
|
should use UTF-8 or UTF-16 instead</span>. The XSLT processor must
|
|
not use an encoding whose name does not match the EncName
|
|
production of the XML Recommendation . If no encoding attribute is
|
|
specified, then the XSLT processor should use either UTF-8 or
|
|
UTF-16. It is possible that the result tree will contain a
|
|
character that cannot be represented in the encoding that the XSLT
|
|
processor is using for output. In this case, if the character
|
|
occurs in a context where XML recognizes character references (i.e.
|
|
in the value of an attribute node or text node), then the character
|
|
should be output as a character reference; otherwise (for example
|
|
if the character occurs in the name of an element) the XSLT
|
|
processor should signal an error.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is UTF-16 encoding always used when
|
|
the encoding attribute of the xsl:output element specifies an
|
|
unsupported encoding?</question>
|
|
</item>
|
|
<item id="default-encoding-UTF-8" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.1 XML Output Method"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/div2[1]/p[5]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The encoding attribute specifies the preferred encoding to use
|
|
for outputting the result tree. XSLT processors are required to
|
|
respect values of UTF-8 and UTF-16. For other values, if the XSLT
|
|
processor does not support the specified encoding it may signal an
|
|
error; if it does not signal an error it should use UTF-8 or UTF-16
|
|
instead. The XSLT processor must not use an encoding whose name
|
|
does not match the EncName production of the XML Recommendation .
|
|
<span style="COLOR: red">If no encoding attribute is specified,
|
|
then the XSLT processor should use either UTF-8 or UTF-16</span>.
|
|
It is possible that the result tree will contain a character that
|
|
cannot be represented in the encoding that the XSLT processor is
|
|
using for output. In this case, if the character occurs in a
|
|
context where XML recognizes character references (i.e. in the
|
|
value of an attribute node or text node), then the character should
|
|
be output as a character reference; otherwise (for example if the
|
|
character occurs in the name of an element) the XSLT processor
|
|
should signal an error.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is UTF-8 encoding used by
|
|
default?</question>
|
|
</item>
|
|
<item id="default-encoding-UTF-16" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.1 XML Output Method"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/div2[1]/p[5]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The encoding attribute specifies the preferred encoding to use
|
|
for outputting the result tree. XSLT processors are required to
|
|
respect values of UTF-8 and UTF-16. For other values, if the XSLT
|
|
processor does not support the specified encoding it may signal an
|
|
error; if it does not signal an error it should use UTF-8 or UTF-16
|
|
instead. The XSLT processor must not use an encoding whose name
|
|
does not match the EncName production of the XML Recommendation .
|
|
<span style="COLOR: red">If no encoding attribute is specified,
|
|
then the XSLT processor should use either UTF-8 or UTF-16</span>.
|
|
It is possible that the result tree will contain a character that
|
|
cannot be represented in the encoding that the XSLT processor is
|
|
using for output. In this case, if the character occurs in a
|
|
context where XML recognizes character references (i.e. in the
|
|
value of an attribute node or text node), then the character should
|
|
be output as a character reference; otherwise (for example if the
|
|
character occurs in the name of an element) the XSLT processor
|
|
should signal an error.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is UTF-16 encoding used by
|
|
default?</question>
|
|
</item>
|
|
<item id="support-disable-output-escaping" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.4 Disabling OutputEscaping"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('disable-output-escaping')/p[5]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
</p>
|
|
<p>An XSLT processor will only be able to disable output escaping
|
|
if it controls how the result tree is output. This may not always
|
|
be the case. For example, the result tree may be used as the source
|
|
tree for another XSLT transformation instead of being output. An
|
|
XSLT processor is not required to support disabling output
|
|
escaping. <span style="COLOR: red">If an xsl:value-of or xsl:text
|
|
specifies that output escaping should be disabled and the XSLT
|
|
processor does not support this, the XSLT processor may signal an
|
|
error; if it does not signal an error, it must recover by not
|
|
disabling output escaping.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">Does the processor support disabling
|
|
output escaping?</question>
|
|
</item>
|
|
<item id="unsupported-disabled-output-escaping" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.4 Disabling OutputEscaping"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('disable-output-escaping')/p[5]"/>
|
|
<choices mootable="yes">
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
<choice value="moot"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>An XSLT processor will only be able to disable output escaping
|
|
if it controls how the result tree is output. This may not always
|
|
be the case. For example, the result tree may be used as the source
|
|
tree for another XSLT transformation instead of being output. An
|
|
XSLT processor is not required to support disabling output
|
|
escaping. <span style="COLOR: red">If an xsl:value-of or xsl:text
|
|
specifies that output escaping should be disabled and the XSLT
|
|
processor does not support this, the XSLT processor may signal an
|
|
error; if it does not signal an error, it must recover by not
|
|
disabling output escaping.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when disabling output
|
|
escaping of an xsl:value-of or xsl:text element is specified but
|
|
disabling of output escaping is unsupported?</question>
|
|
</item>
|
|
<item id="non-text-disabled-output-escaping" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.4 Disabling Output Escaping"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('disable-output-escaping')/p[3]"/>
|
|
<choices mootable="yes">
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
<choice value="moot"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error for output escaping to be disabled for a text
|
|
node that is used for something other than a text node in the
|
|
result tree. Thus, it is an error to disable output escaping for an
|
|
xsl:value-of or xsl:text element that is used to generate the
|
|
string-value of a comment, processing instruction or attribute
|
|
node; it is also an error to convert a result tree fragment to a
|
|
number or a string if the result tree fragment contains a text node
|
|
for which escaping was disabled. In both cases, <span style="COLOR: red">an XSLT processor may signal the error; if it does not signal
|
|
the error, it must recover by ignoring the disable-output-escaping
|
|
attribute</span>.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when output escaping is
|
|
disabled for a text node that is used for something other than a
|
|
text node in the result tree?</question>
|
|
</item>
|
|
<item id="unrepresented-character-disabled-output-escaping" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.4 Disabling Output Escaping"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('disable-output-escaping')/p[6]"/>
|
|
<choices mootable="yes">
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
<choice value="moot"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">If output escaping is disabled for a
|
|
character that is not representable in the encoding that the XSLT
|
|
processor is using for output, then the XSLT processor may signal
|
|
an error; if it does not signal an error, it must recover by not
|
|
disabling output escaping.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when output escaping is
|
|
disabled for a character that is not representable in the encoding
|
|
used for output?</question>
|
|
</item>
|
|
<item id="public-identifier-generate-URI" status="Active">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="3.3 Unparsed Entities"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('unparsed-entities')/p[1]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The root node has a mapping that gives the URI for each unparsed
|
|
entity declared in the document's DTD. The URI is generated from
|
|
the system identifier and public identifier specified in the entity
|
|
declaration. <span style="COLOR: red">The XSLT processor may use
|
|
the public identifier to generate a URI for the entity instead of
|
|
the URI specified in the system identifier.</span> If the XSLT
|
|
processor does not use the public identifier to generate the URI,
|
|
it must use the system identifier; if the system identifier is a
|
|
relative URI, it must be resolved into an absolute URI using the
|
|
URI of the resource containing the entity declaration as the base
|
|
URI .</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is the public identifier of an
|
|
unparsed entity, when present, used to generate the URI for the
|
|
entity instead of the URI specified in the system identifier?</question>
|
|
</item>
|
|
<item id="convert-number-English" expandable="convert-number-[language]" status="Postponed">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.7.1 Number to StringConversion Attributes"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('convert')/note[2]/p[1]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">It is possible for two conforming XSLT
|
|
processors not to convert a number to exactly the same string. Some
|
|
XSLT processors may not support some languages. Furthermore, there
|
|
may be variations possible in the way conversions are performed for
|
|
any particular language that are not specifiable by the attributes
|
|
on xsl:number.</span> Future versions of XSLT may provide
|
|
additional attributes to provide control over these variations.
|
|
Implementations may also use implementation-specific namespaced
|
|
attributes on xsl:number for this.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is the English language supported for xsl:number?</question>
|
|
<question scope="Prototype">For each language in test suite: <em>Is _____ language supported for xsl:number?</em>
|
|
</question>
|
|
<question scope="Prototype">For some specific languages:
|
|
<em>ELABORATE: which number conversion basis is chosen?</em>
|
|
</question>
|
|
</item>
|
|
<item id="sort-English" expandable="sort-[language]" status="Postponed">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="10 Sorting"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('sorting')/note[1]/p[1]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">It is possible for two conforming XSLT
|
|
processors not to sort exactly the same. Some XSLT processors may
|
|
not support some languages. Furthermore, there may be variations
|
|
possible in the sorting of any particular language that are not
|
|
specified by the attributes on xsl:sort, for example, whether
|
|
Hiragana or Katakana is sorted first in Japanese.</span> Future
|
|
versions of XSLT may provide additional attributes to provide
|
|
control over these variations. Implementations may also use
|
|
implementation-specific namespaced attributes on xsl:sort for
|
|
this.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is the English language supported for xsl:sort?</question>
|
|
<question scope="Prototype">For each language in test suite:
|
|
<em>Is _____ language supported for xsl:sort?</em>
|
|
</question>
|
|
<question scope="Prototype">For some specific languages:
|
|
<em>ELABORATE: which sorting algorithm is chosen?</em>
|
|
</question>
|
|
</item>
|
|
<item id="stylesheet-parameter" status="Postponed">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="11.4 Top-level Variables and Parameters"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('top-level-variables')/p[1]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>Both xsl:variable and xsl:param are allowed as top-level
|
|
elements. A top-level variable-binding element declares a global
|
|
variable that is visible everywhere. A top-level xsl:param element
|
|
declares a parameter to the stylesheet; <span style="COLOR: red">
|
|
XSLT does not define the mechanism by which parameters are passed
|
|
to the stylesheet.</span> It is an error if a stylesheet contains
|
|
more than one binding of a top-level variable with the same name
|
|
and same import precedence. At the top-level, the expression or
|
|
template specifying the variable value is evaluated with the same
|
|
context as that used to process the root node of the source
|
|
document: the current node is the root node of the source document
|
|
and the current node list is a list containing just the root node
|
|
of the source document. If the template or expression specifying
|
|
the value of a global variable x references a global variable y,
|
|
then the value for y must be computed before the value of x. It is
|
|
an error if it is impossible to do this for all global variable
|
|
definitions; in other words, it is an error if the definitions are
|
|
circular.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is it possible to pass parameters to the stylesheet?</question>
|
|
<elaborator choice="yes">What is the API?
|
|
What is the command-line syntax?</elaborator>
|
|
</item>
|
|
<item id="result-tree-as-bytes" status="Postponed">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16 Output"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/p[1]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">An XSLT processor may output the result
|
|
tree as a sequence of bytes, although it is not required to be able
|
|
to do so</span> (see 17 Conformance ). The xsl:output element
|
|
allows stylesheet authors to specify how they wish the result tree
|
|
to be output. If an XSLT processor outputs the result tree, it
|
|
should do so as specified by the xsl:output element; however, it is
|
|
not required to do so.</p>
|
|
</excerpt>
|
|
<question scope="Filter">Is the result tree able to be output as a sequence of bytes?</question>
|
|
</item>
|
|
<item id="obey-xsl-output" status="Postponed">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16 Output"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/p[1]"/>
|
|
<choices mootable="yes">
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
<choice value="moot"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>An XSLT processor may output the result tree as a sequence of
|
|
bytes, although it is not required to be able to do so (see 17
|
|
Conformance). The xsl:output element allows stylesheet authors to
|
|
specify how they wish the result tree to be output. <span style="COLOR: red">If an XSLT processor outputs the result tree, it
|
|
should do so as specified by the xsl:output element; however, it is
|
|
not required to do so.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Is the result tree always output as specified by the xsl:output element?</question>
|
|
<elaborator choice="no">What deviations do you implement?</elaborator>
|
|
</item>
|
|
<item id="converted-RTF-disabled-output-escaping" status="Postponed">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.4 Disabling Output Escaping"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('disable-output-escaping')/p[3]"/>
|
|
<choices mootable="yes">
|
|
<choice value="ignore"/>
|
|
<choice value="raise-error"/>
|
|
<choice value="moot"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>It is an error for output escaping to be disabled for a text
|
|
node that is used for something other than a text node in the
|
|
result tree. Thus, it is an error to disable output escaping for an
|
|
xsl:value-of or xsl:text element that is used to generate the
|
|
string-value of a comment, processing instruction or attribute
|
|
node; <span style="COLOR: red">it is also an error to convert a
|
|
result tree fragment to a number or a string if the result tree
|
|
fragment contains a text node for which escaping was disabled. In
|
|
both cases, an XSLT processor may signal the error; if it does not
|
|
signal the error, it must recover by ignoring the
|
|
disable-output-escaping attribute</span>.</p>
|
|
</excerpt>
|
|
<question scope="Filter">What happens when output escaping is
|
|
disabled for a text node that is placed into a result tree fragment
|
|
(RTF), and the RTF is later converted to a number or string?</question>
|
|
</item>
|
|
<item id="detect-infinite-loop" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="5.4 Applying Template Rules"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('rules')/div2[4]/note[2]/p[2]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">Implementations may be able to detect
|
|
such loops in some cases, but the possibility exists that a
|
|
stylesheet may enter a non-terminating loop that an implementation
|
|
is unable to detect.</span> This may present a denial of service
|
|
security risk.</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Are there any non-terminating loops that can be detected?</question>
|
|
<elaborator choice="yes">What loops can be detected?</elaborator>
|
|
</item>
|
|
<item id="element-use-QName-prefix" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.2 Creating Elements with xsl:element"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[7]/div2[1]/div3[2]/p[4]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">XSLT processors may make use of the
|
|
prefix of the QName specified in the name attribute when selecting
|
|
the prefix used for outputting the created element as XML; however,
|
|
they are not required to do so.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Is the prefix of the QName specified
|
|
in the name attribute of xsl:element used as the prefix of the
|
|
created element, when no conflicting use is in scope?</question>
|
|
</item>
|
|
<item id="attribute-use-QName-prefix" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="7.1.3 Creating Attributes with xsl:attribute"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('creating-attributes')/p[4]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">XSLT processors may make use of the
|
|
prefix of the QName specified in the name attribute when selecting
|
|
the prefix used for outputting the created attribute as XML;
|
|
however, they are not required to do so and, if the prefix is
|
|
xmlns, they must not do so.</span> Thus, although it is not an
|
|
error to do:</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Is the prefix of the QName specified
|
|
in the name attribute of xsl:attribute used as the prefix of the
|
|
created attribute, when no conflicting use is in scope?</question>
|
|
</item>
|
|
<item id="different-document-node-document-order" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="12.1 Multiple Source Documents"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('document')/p[8]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The document function gives rise to the possibility that a
|
|
node-set may contain nodes from more than one document. With such a
|
|
node-set, the relative document order of two nodes in the same
|
|
document is the normal document order defined by XPath . <span style="COLOR: red">The relative document order of two nodes in
|
|
different documents is determined by an implementation-dependent
|
|
ordering of the documents containing the two nodes.</span> There
|
|
are no constraints on how the implementation orders documents other
|
|
than that it must do so consistently: an implementation must always
|
|
use the same order for the same set of documents.</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Is the relative document order of two
|
|
nodes in different documents formed by taking all elements in the
|
|
first document before any in the second, and so on?</question>
|
|
<elaborator choice="no">How is the ordering determined?</elaborator>
|
|
</item>
|
|
<item id="generate-id" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="12.4 Miscellaneous Additional Functions"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('misc-func')/p[9]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>The generate-id function returns a string that uniquely
|
|
identifies the node in the argument node-set that is first in
|
|
document order. The unique identifier must consist of ASCII
|
|
alphanumeric characters and must start with an alphabetic
|
|
character. Thus, the string is syntactically an XML name. <span style="COLOR: red">An implementation is free to generate an
|
|
identifier in any convenient way provided that it always generates
|
|
the same identifier for the same node and that different
|
|
identifiers are always generated from different nodes.</span> An
|
|
implementation is under no obligation to generate the same
|
|
identifiers each time a document is transformed. There is no
|
|
guarantee that a generated unique identifier will be distinct from
|
|
any unique IDs specified in the source document. If the argument
|
|
node-set is empty, the empty string is returned. If the argument is
|
|
omitted, it defaults to the context node.</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Is there a reproducible pattern for
|
|
the string generated by the generate-id function?</question>
|
|
<elaborator choice="yes">What is the pattern?</elaborator>
|
|
</item>
|
|
<item id="non-result-tree-namespace-node" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.1 XML Output Method"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/div2[1]/ulist[1]/item[2]/p[1]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">The new tree may contain namespace
|
|
nodes that were not present in the result tree.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Does the XML output ever contain
|
|
namespace nodes that were not present in the result tree?</question>
|
|
<elaborator choice="yes">Under what circumstances are additional namespace nodes generated?</elaborator>
|
|
</item>
|
|
<item id="HTML-character-reference" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="16.2 HTML Output Method"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('output')/div2[2]/p[12]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">The html output method may output a
|
|
character using a character entity reference, if one is defined for
|
|
it in the version of HTML that the output method is
|
|
using.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Does the html output method output a
|
|
character using a character entity reference, if one is defined for
|
|
it in the version of HTML that the output method is using?</question>
|
|
</item>
|
|
<item id="error-recovery" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="17 Conformance"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('conformance')/p[2]"/>
|
|
<excerpt>
|
|
<p>A conforming XSLT processor must signal any errors except for
|
|
those that this document specifically allows an XSLT processor not
|
|
to signal. <span style="COLOR: red">A conforming XSLT processor may
|
|
but need not recover from any errors that it signals.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question>ELABORATE: What form of error
|
|
recovery is performed after any errors are signaled?</question>
|
|
</item>
|
|
<item id="resource-limit" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="17 Conformance"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('conformance')/p[3]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">A conforming XSLT processor may impose
|
|
limits on the processing resources consumed by the processing of a
|
|
stylesheet.</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Are limits imposed on processing
|
|
resources consumed by the processing of a stylesheet?</question>
|
|
<elaborator choice="yes">What limits might be reached in lab testing?</elaborator>
|
|
</item>
|
|
<item id="sort-QName" status="Configuration">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="10 Sorting"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('sorting')/ulist[1]/item[3]/ulist[1]/item[3]/p[1]"/>
|
|
<choices>
|
|
<choice value="yes"/>
|
|
<choice value="no"/>
|
|
</choices>
|
|
<excerpt>
|
|
<p>
|
|
<span style="COLOR: red">a QName with a prefix is expanded into
|
|
an expanded-name as described in 2.4 Qualified Names; the
|
|
expanded-name identifies the data-type; the behavior in this case
|
|
is not specified by this document</span>
|
|
</p>
|
|
</excerpt>
|
|
<question scope="Configuration">Does the XSLT processor support any
|
|
extra data-type for sort?</question>
|
|
<elaborator choice="yes">What additional data types are supported?</elaborator>
|
|
</item>
|
|
<item id="non-XSLT-attribute-URI" status="Recognized">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="2.1 XSLT Namespace"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('xslt-namespace')/p[4]"/>
|
|
<excerpt>
|
|
<p>An element from the XSLT namespace may have any attribute not
|
|
from the XSLT namespace, provided that the expanded-name of the
|
|
attribute has a non-null namespace URI. The presence of such
|
|
attributes must not change the behavior of XSLT elements and
|
|
functions defined in this document. Thus, <span style="COLOR: red">
|
|
an XSLT processor is always free to ignore such attributes, and
|
|
must ignore such attributes without giving an error if it does not
|
|
recognize the namespace URI</span>. Such attributes can provide,
|
|
for example, unique identifiers, optimization hints, or
|
|
documentation.</p>
|
|
</excerpt>
|
|
</item>
|
|
<item id="non-XSLT-top-level-element-URI" status="Recognized">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="2.2 Stylesheet Element"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="id('stylesheet-element')/p[7]"/>
|
|
<excerpt>
|
|
<p>In addition, the xsl:stylesheet element may contain any element
|
|
not from the XSLT namespace, provided that the expanded-name of the
|
|
element has a non-null namespace URI. The presence of such
|
|
top-level elements must not change the behavior of XSLT elements
|
|
and functions defined in this document; for example, it would not
|
|
be permitted for such a top-level element to specify that
|
|
xsl:apply-templates was to use different rules to resolve
|
|
conflicts. Thus, <span style="COLOR: red">an XSLT processor is
|
|
always free to ignore such top-level elements, and must ignore a
|
|
top-level element without giving an error if it does not recognize
|
|
the namespace URI</span>. Such elements can provide, for
|
|
example,</p>
|
|
</excerpt>
|
|
</item>
|
|
<item id="xpath-default-attribute" status="Recognized">
|
|
<spec-citation spec="XSLT" version="1.0" type="section" place="5.3 Attribute Nodes"/>
|
|
<spec-citation spec="XSLT" version="1.0" type="XPointer" place="/spec[1]/body[1]/div1[5]/div2[3]/note[4]/p[1]"/>
|
|
<excerpt>
|
|
<p>It is possible for default attributes to be declared in an
|
|
external DTD or an external parameter entity. The XML
|
|
Recommendation does not require an XML processor to read an
|
|
external DTD or an external parameter unless it is validating.
|
|
<span style="COLOR: red">A stylesheet or other facility that
|
|
assumes that the XPath tree contains default attribute values
|
|
declared in an external DTD or parameter entity may not work with
|
|
some non-validating XML processors.</span>
|
|
</p>
|
|
</excerpt>
|
|
</item>
|
|
</items>
|
|
<interlocks>
|
|
<interlock>
|
|
<p>If the answer to <party idref="add-attribute-to-non-element"/>
|
|
doesn't
|
|
match the answers to <party idref="attribute-non-text-content"/>,
|
|
<party idref="PI-non-text-content"/>, or <party idref="comment-non-text-content"/>, please review the
|
|
behavior. If the inconsistency was intentional, ELABORATE on what
|
|
happens when an attempt is made to add an attribute as content to
|
|
attributes, processing instructions, and comments.</p>
|
|
</interlock>
|
|
<interlock>
|
|
<p>Cannot answer "yes" to more
|
|
than one of <party idref="unsupported-encoding-error"/>,
|
|
<party idref="unsupported-encoding-UTF-8"/>,
|
|
<party idref="unsupported-encoding-UTF-16"/>. Answering, "no" to all is allowed, in which case please
|
|
ELABORATE on what encoding is used.</p>
|
|
</interlock>
|
|
<interlock>
|
|
<p>Cannot answer "yes" to both <party idref="default-encoding-UTF-8"/>and <party idref="default-encoding-UTF-16"/>.
|
|
Answering "no" to both is allowed, in which case please ELABORATE
|
|
on what encoding is used.</p>
|
|
</interlock>
|
|
<interlock>
|
|
<p>Answering "yes" to
|
|
<party idref="support-disable-output-escaping"/> renders
|
|
<party idref="unsupported-disabled-output-escaping"/> moot. </p>
|
|
</interlock>
|
|
<interlock>
|
|
<p>Answering "no" to
|
|
<party idref="support-disable-output-escaping"/> renders
|
|
<party idref="non-text-disabled-output-escaping"/> and
|
|
<party idref="unrepresented-character-disabled-output-escaping"/> moot.</p>
|
|
</interlock>
|
|
<interlock>
|
|
<p>Some xsl:output directives
|
|
will be moot if <party idref="result-tree-as-bytes"/> is "no" and the answer to
|
|
<party idref="obey-xsl-output"/> should be limited accordingly.</p>
|
|
</interlock>
|
|
<interlock>
|
|
<p>Compare to <party idref="converted-RTF-disabled-output-escaping"/>
|
|
to <party idref="non-text-disabled-output-escaping"/>. Separate option?</p>
|
|
</interlock>
|
|
</interlocks>
|
|
<changes>
|
|
<change date="2000-07-06">
|
|
|
|
<p>Initial revision.</p>
|
|
|
|
|
|
</change>
|
|
<change date="2000-08-08">
|
|
|
|
<p>Added discretionary non-error aspects
|
|
identified by David Marston. Removed emphasis on only reporting
|
|
discretionary error handling. Other cosmetic fixes.</p>
|
|
|
|
|
|
</change>
|
|
<change date="2001-01-08">
|
|
|
|
<p>Created and populated "Untestable or
|
|
Out of Scope Discretionary Behavior" section. Added change history.
|
|
Split "disc-result-tree-as-bytes" to create
|
|
"disc-obey-xsl-output".</p>
|
|
|
|
|
|
</change>
|
|
<change date="2001-01-26">
|
|
|
|
<p>Splitted all discretionary items into
|
|
4 categories: "testable", "not testable", "postponed" and "out of
|
|
scope". Split "disc-sort" and "disc-convert-number" into language
|
|
specific questions .</p>
|
|
|
|
|
|
</change>
|
|
<change date="2001-01-29">
|
|
|
|
<p>Adjusted some verbiage. Added
|
|
disc-default-encoding, distinct from discretion surrounding
|
|
requested encoding that is unsupported. Split the UTF-8 and UTF-16
|
|
encoding cases. Fixed a couple references and anchors. Clarified
|
|
that language-specific questions are shown in template form
|
|
only.</p>
|
|
|
|
|
|
</change>
|
|
<change date="2001-03-29">
|
|
|
|
<p>Changed item names, per subcommittee
|
|
decision. Expressed questions in keyword-answer style, which makes
|
|
catalog more readable. Added union list of keywords for answers.
|
|
Added INTERLOCK flags. Added EXPANDABLE flags and patterns. Added
|
|
ELABORATE flags.</p><p>
|
|
Clarified questions regarding disable-output-escaping. Further
|
|
clarified UTF-8/UTF-16 encoding items. Clarified questions
|
|
regarding QNames in created elements and attributes. Instantiated
|
|
English versions of xsl:number and xsl:sort language questions.
|
|
Added questions from 12/12/2000 errata.</p><p>
|
|
Moved xpath-default-attribute to out-of-scope, per subcommittee
|
|
decision.</p>
|
|
|
|
|
|
</change>
|
|
<change date="2001-04-13">
|
|
|
|
<p>Added
|
|
converted-RTF-disabled-output-escaping as a potential split-off
|
|
from non-text-disabled-output-escaping. Added yes/no and ELABORATE
|
|
verbiage where context required it.</p>
|
|
|
|
</change>
|
|
|
|
<change date="2001-05-09 14:00">
|
|
<p>Recast document in XML from HTML</p>
|
|
</change>
|
|
<change date="2001-07-09 13:00">
|
|
<p>Flattened out item space so all are children of <items> and
|
|
status is an attribute. Added structure: spec-citations and readable-cites,
|
|
mootable flag, elaborators for items, scope of questions.</p>
|
|
</change>
|
|
<change date="2001-07-21 01:30">
|
|
<p>Revamped citations to consistent model across all documents.
|
|
Abbreviated XPointer values to nearest ancestral id (when available).
|
|
Changed readable citations to spec citations of type 'Section'.</p>
|
|
</change>
|
|
<change date="2001-08-21 20:20">
|
|
<p>Changed attribute names according to August teleconference.</p>
|
|
</change>
|
|
<change date="2001-12-07 14:14">
|
|
<p>Added questionnaire intro.</p>
|
|
</change>
|
|
</changes>
|
|
</doc> |