|
21 | 21 | */
|
22 | 22 | package org.exist.xquery;
|
23 | 23 |
|
| 24 | +import org.exist.dom.INode; |
24 | 25 | import org.exist.dom.persistent.DocumentSet;
|
25 | 26 | import org.exist.dom.persistent.NodeProxy;
|
26 | 27 | import org.exist.dom.QName;
|
27 | 28 | import org.exist.xquery.util.ExpressionDumper;
|
28 | 29 | import org.exist.xquery.value.*;
|
| 30 | +import org.w3c.dom.Document; |
| 31 | +import org.w3c.dom.Element; |
29 | 32 | import org.w3c.dom.Node;
|
30 | 33 |
|
31 | 34 | /**
|
@@ -77,56 +80,52 @@ public Sequence eval(Sequence contextSequence, Item contextItem) throws XPathExc
|
77 | 80 | }
|
78 | 81 | }
|
79 | 82 | if (!Type.subTypeOf(itemType, test.getType())) {
|
80 |
| - throw new XPathException(expression, "Type error in expression" + |
| 83 | + throw new XPathException(expression, ErrorCodes.XPTY0004, "Type error in expression" + |
81 | 84 | ": required type is " + Type.getTypeName(test.getType()) +
|
82 | 85 | "; got: " + Type.getTypeName(item.getType()) + ": " + item.getStringValue());
|
83 | 86 | }
|
84 | 87 | final Node node = ((NodeValue) item).getNode();
|
85 |
| - if (!test.matchesName(node)) |
86 |
| - {throw new XPathException(expression, "Type error in expression: " + |
87 |
| - "required node name is " + getPrefixedNodeName(test.getName()) + |
88 |
| - "; got: " + getPrefixedNodeName(node));} |
| 88 | + if (!test.matchesName(node)) { |
| 89 | + throw new XPathException(expression, ErrorCodes.XPTY0004, "Type error in expression: " + |
| 90 | + "required node name is " + getPrefixedNodeName(test) + |
| 91 | + "; got: " + getPrefixedNodeName((INode) node)); |
89 | 92 | }
|
90 |
| - if (context.getProfiler().isEnabled()) { |
91 |
| - context.getProfiler().end(this, "", seq); |
92 |
| - } |
93 |
| - return seq; |
94 |
| - } catch(final IllegalArgumentException iae) { |
95 |
| - throw new XPathException(expression, iae); |
96 | 93 | }
|
| 94 | + if (context.getProfiler().isEnabled()) { |
| 95 | + context.getProfiler().end(this, "", seq); |
| 96 | + } |
| 97 | + return seq; |
| 98 | + } catch(final IllegalArgumentException iae) { |
| 99 | + throw new XPathException(expression, iae); |
| 100 | + } |
97 | 101 | }
|
98 | 102 |
|
99 |
| - private String getPrefixedNodeName(Node node) { |
100 |
| - final String prefix = node.getPrefix(); |
101 |
| - if (prefix == null) { |
102 |
| - final String nameSpace = node.getNamespaceURI(); |
103 |
| - if (nameSpace == null) { |
104 |
| - return node.getNodeName(); |
105 |
| - } else { |
106 |
| - return "{'" + nameSpace + "'}:" + node.getNodeName(); |
| 103 | + private String getPrefixedNodeName(final INode iNode) { |
| 104 | + if (iNode instanceof Document) { |
| 105 | + final Element documentElement = ((Document) iNode).getDocumentElement(); |
| 106 | + if (documentElement != null) { |
| 107 | + return getPrefixedNodeName(true, ((INode) documentElement).getQName()); |
107 | 108 | }
|
108 |
| - } else if (prefix.isEmpty()) { |
109 |
| - return "{''}:" + node.getNodeName(); |
110 |
| - } else { |
111 |
| - return prefix + ":" + node.getLocalName(); |
112 | 109 | }
|
| 110 | + return getPrefixedNodeName(false, iNode.getQName()); |
113 | 111 | }
|
114 | 112 |
|
115 |
| - // TODO should be moved to QName |
116 |
| - private String getPrefixedNodeName(QName name) { |
117 |
| - final String prefix = name.getPrefix(); |
118 |
| - final String localName = name.getLocalPart(); |
119 |
| - if (prefix == null) { |
120 |
| - final String namespaceURI = name.getNamespaceURI(); |
121 |
| - if (namespaceURI == null) { |
122 |
| - return localName; |
123 |
| - } else { |
124 |
| - return "{'" + namespaceURI + "'}:" + localName; |
125 |
| - } |
126 |
| - } else if (prefix.isEmpty()) { |
127 |
| - return "{''}:" + localName; |
| 113 | + private String getPrefixedNodeName(final NameTest nameTest) { |
| 114 | + return getPrefixedNodeName(nameTest.isOfType(Node.DOCUMENT_NODE), nameTest.getName()); |
| 115 | + } |
| 116 | + |
| 117 | + private String getPrefixedNodeName(final boolean wasDocumentNodeWithNamedElementTest, final QName name) { |
| 118 | + final String prefixedName; |
| 119 | + if (name.getPrefix() == null && name.hasNamespace()) { |
| 120 | + prefixedName = name.toURIQualifiedName(); |
| 121 | + } else { |
| 122 | + prefixedName = name.getStringValue(); |
| 123 | + } |
| 124 | + |
| 125 | + if (wasDocumentNodeWithNamedElementTest) { |
| 126 | + return "document-node(" + prefixedName + ")"; |
128 | 127 | } else {
|
129 |
| - return prefix + ":" + localName; |
| 128 | + return prefixedName; |
130 | 129 | }
|
131 | 130 | }
|
132 | 131 |
|
|
0 commit comments