DefaultURI (XmlDoc/XmlNode function): Difference between revisions

From m204wiki
Jump to navigation Jump to search
m (1 revision)
mNo edit summary
Line 16: Line 16:
<tr><th>XPath</th>
<tr><th>XPath</th>
<td>A <var>Unicode</var> string that is an XPath expression that results in a nodelist. The head of the nodelist is the node to process. An optional argument, its default is a period (.), that is, the node referenced by the method object (<i>nr</i>).
<td>A <var>Unicode</var> string that is an XPath expression that results in a nodelist. The head of the nodelist is the node to process. An optional argument, its default is a period (.), that is, the node referenced by the method object (<i>nr</i>).
<p class="code">Prior to ''Sirius Mods'' version 7.6, this is an EBCDIC string.</td></tr>
 
</p>
Prior to ''Sirius Mods'' version 7.6, this is an EBCDIC string.</td></tr>
</table>
</table>


==Example==
In the following example, two elements are added along with their namespace
In the following example, two elements are added along with their namespace
URIs, but only the second added element, which has no prefix, has a default
URIs, but only the second added element, which has no prefix, has a default
namespace URI:
namespace URI:
<p class="code">Begin
<p class="code">Begin
%d <var>Object</var> <var>XmlDoc</var> Auto New
%d Object XmlDoc Auto New
%n <var>Object</var> <var>XmlNode</var>
%n Object XmlNode
%n2 <var>Object</var> <var>XmlNode</var>
%n2 Object XmlNode
%n = %d:AddElement('p:top', , 'urn:top')
%n = %d:AddElement('p:top', , 'urn:top')
%n2 = %n:AddElement('inner', , 'urn:default')
%n2 = %n:AddElement('inner', , 'urn:default')
%n:Print
%n:Print
Print 'URI of p:top default namespace =' And %n:<var>DefaultURI</var>
Print 'URI of p:top default namespace =' And %n:DefaultURI
Print 'URI of inner default namespace =' And %n2:<var>DefaultURI</var>
Print 'URI of inner default namespace =' And %n2:DefaultURI
End
End
</p>
</p>
The following lines are printed:
The following lines are printed:
<p class="code"><p:top xmlns:p="urn:top">
<p class="code"><nowiki><p:top xmlns:p="urn:top">
<inner xmlns="urn:default"/>
  <inner xmlns="urn:default"/>
</p>
</p:top>
</p:top>
URI of p:top default namespace =
URI of p:top default namespace =  
URI of inner default namespace = urn:default
URI of inner default namespace = urn:default
</p>
</nowiki></p>
===Request-Cancellation Errors===
==Request-Cancellation Errors==
<ul>
<ul>
<li><var>XmlDoc</var> Namespace property not <tt>On</tt>.
<li><var>XmlDoc</var> Namespace property not <tt>On</tt>.

Revision as of 20:34, 7 February 2011

Default URI in scope at selected node (XmlDoc and XmlNode classes)


This function gets the Uniform Resource Identifier (URI) associated with the default namespace declaration that is in scope at a node that is the head of an XPath result.

The DefaultURI function is new as of version 6.9 of the Sirius Mods.

Syntax

%unicode = nr:DefaultURI[( [xpath])] Throws XPathError

Syntax terms

%uri A string variable for the returned URI.
nr An XmlDoc or XmlNode, used as the context node for the XPath expression. If an XmlDoc, the Root node is the context node.
XPath A Unicode string that is an XPath expression that results in a nodelist. The head of the nodelist is the node to process. An optional argument, its default is a period (.), that is, the node referenced by the method object (nr). Prior to Sirius Mods version 7.6, this is an EBCDIC string.

Example

In the following example, two elements are added along with their namespace URIs, but only the second added element, which has no prefix, has a default namespace URI:

Begin %d Object XmlDoc Auto New %n Object XmlNode %n2 Object XmlNode %n = %d:AddElement('p:top', , 'urn:top') %n2 = %n:AddElement('inner', , 'urn:default') %n:Print Print 'URI of p:top default namespace =' And %n:DefaultURI Print 'URI of inner default namespace =' And %n2:DefaultURI End

The following lines are printed:

<p:top xmlns:p="urn:top"> <inner xmlns="urn:default"/> </p:top> URI of p:top default namespace = URI of inner default namespace = urn:default

Request-Cancellation Errors

  • XmlDoc Namespace property not On.
  • XPath is invalid.
  • Result of (XPath) is empty.
  • Insufficient free space exists in CCATEMP.


See also

  • For more information about using XPath expressions, see XPath.
  • For more information about namespace declarations, see ?? refid=namsp..
  • For more information about URIs, see ?? refid=nsuri..
  • The PrefixURI method (?? refid=prefuri.) returns the URI bound to a node's prefix (or the default URI, if a node has a default namespace declaration). The URI method (?? refid=uri.) returns the URI bound to a node's name, if any.
  • These methods add namespace URIs to XmlDoc nodes: