From b88cfcaafb4177b33ef8896ab0944e6830ba32c6 Mon Sep 17 00:00:00 2001
From: Michael Kay
Date: Sun, 5 Jan 2025 14:27:30 +0000
Subject: [PATCH] Fix issue 1678
---
specifications/xquery-40/src/expressions.xml | 123 ++++++++++---------
1 file changed, 66 insertions(+), 57 deletions(-)
diff --git a/specifications/xquery-40/src/expressions.xml b/specifications/xquery-40/src/expressions.xml
index ca9a5cde2..11b12388e 100644
--- a/specifications/xquery-40/src/expressions.xml
+++ b/specifications/xquery-40/src/expressions.xml
@@ -3848,7 +3848,7 @@ the schema type named us:address
.
xs:decimal
value is expected, the value retains its type
as xs:integer
.
- The definition of The definition of SequenceType matching relies
on a pseudo-function named derives-from(
AT,
@@ -3910,7 +3910,7 @@ the schema type named us:address
.
-
+ -->
The rules for SequenceType
@@ -3970,6 +3970,36 @@ the schema type named us:address
.
value that is an empty sequence.
+
+ Schema Type Relationships
+
+ Some item types are defined in terms
+ of schema types, and the matching
+ rules for such item types depend on the rules defining relationships between
+ schema types in the XSD specification.
+
+ A
+ S1 is said to derive from
+ S2 if any of the following
+ conditions is true:
+
+
+ S1 is the same type as S2.
+ S2 is the base type of S1.
+ S2 is a
+ of which S1 is a member type.
+ There is a M such that
+ S1 M
+ and M S2.
+
+
+
+ The XML Schema specification does not completely specify the circumstances
+ under which S1 and S2 are considered to be the same
+ type. For example, if both are anonymous union types with the same member types,
+ but defined in different places in the schema, then schema processors have
+ discretion whether to treat them as the same type.
+
Item Types
@@ -4137,7 +4167,7 @@ the schema type named us:address
.
An atomic item A matches the
GAT
if the type annotation of A
- (call it T) satisfies the condition derives-from(T, GAT)
.
+ GAT.
Example: The ItemType
xs:decimal
matches any value of type
@@ -4645,10 +4675,9 @@ declare variable $orange-fruit as my:fruit := "orange";
NT is an EQName
equal to N.
- If ET includes a TypeName,
+ If ET includes a TypeName T,
then the of the element node E
- is either the schema type identified by that type name, or a type derived from that
- type by restriction.
+ T.
If E has the nilled
property, then ET
either includes no TypeName,
or includes a TypeName followed by the symbol ?
.
@@ -4814,11 +4843,11 @@ matches any nilled or non-nilled element node whose type annotation is
Either:
-
-
The name N of the candidate node matches the specified The name N of the candidate node matches the specified ElementName, or
-
-
The name N of the candidate node matches the name of an element declaration that is a member of the actual substitution group headed by the declaration of element The name N of the candidate node matches the name of an element declaration that is a member of the actual substitution group headed by the declaration of element ElementName.
@@ -4827,21 +4856,31 @@ matches any nilled or non-nilled element node whose type annotation is
The term “actual substitution group” is defined in . The actual substitution group of an element declaration H includes those element declarations P that are declared to have H as their direct or indirect substitution group head, provided that P is not declared as abstract, and that P is validly substitutable for H, which means that there must be no blocking constraints that prevent substitution.
+ />. The actual substitution group of an element declaration
+ H includes those element declarations
+ P that are declared to have H as their
+ direct or indirect substitution group head, provided that
+ P is not declared as abstract, and that P
+ is validly substitutable for H, which means that
+ there must be no blocking constraints that prevent substitution.
-
-
The schema element declaration named N is not abstract.
+ The schema element declaration named N is not abstract.
-
-
- derives-from( AT, ET )
is true, where AT is the type annotation of the candidate node and ET is the schema type declared in the schema element declaration named N.
+ AT ET,
+ where AT is the type annotation of the candidate node
+ and ET is the schema type declared in the schema element
+ declaration named N.
-
-
If the schema element declaration named N is not nillable, then the nilled property of the candidate node is false
.
+ If the schema element declaration named N
+ is not nillable, then the nilled
property of the candidate node
+ is false
.
@@ -4868,7 +4907,7 @@ in the following two situations:
considerations apply:
- In applying the test derives-from( AT, ET )
,
+ In applying the test AT derives-from ET
,
note that AT will necessarily be present in X,
but not necessarily in Y. However, ET will
necessarily be present in both; and because the two schemas
@@ -4954,10 +4993,9 @@ in the following two situations:
NT is an EQName
equal to N.
- If AT includes a TypeName,
+ If AT includes a TypeName T,
then the of the attribute node A
- is either the schema type identified by that type name, or a type derived from that
- type by restriction.
+ T.
Here are some examples of AttributeTests:
@@ -5099,10 +5137,9 @@ name.
-
-
- derives-from(
- AT, ET
- )
is true
, where AT is the type annotation of the candidate node and ET is the schema type declared for attribute AT ET,
+ where AT is the type annotation of the candidate node and
+ ET is the schema type declared for attribute AttributeName in the in-scope attribute declarations.
@@ -6206,8 +6243,7 @@ declare record Particle (
-
A and B are generalized atomic types,
- and derives-from(A, B)
returns true
.
- The derives-from
relationship is defined in .
+ and A B.
Examples:
@@ -6357,10 +6393,10 @@ declare record Particle (
-
All the following are true:
- A is element(A/n, A/t)
- B is element(B/n, B/t)
- A/n B/n
- derives-from(A/t, B/t)
.
+ A is element(A/n, A/t)
.
+ B is element(B/n, B/t)
.
+ A/n B/n.
+ A/t B/t.
Examples:
@@ -6381,7 +6417,7 @@ declare record Particle (
element(A/n, A/t?)
B is element(B/n, B/t?)
A/n B/n
- derives-from(A/t, B/t)
.
+ A/t B/t.
Examples:
@@ -6394,25 +6430,7 @@ declare record Particle (
-
-
-
All the following are true:
@@ -6490,8 +6508,7 @@ declare record Particle (
A is attribute(A/n, A/t)
B is attribute(B/n, B/t)
A/n B/n
-
- derives-from(A/t, B/t)
.
+ A/t B/t.
@@ -6507,15 +6524,7 @@ declare record Particle (
-
+
-
All the following are true: