InsertCommentBefore (XmlNode function)

From m204wiki
Revision as of 03:57, 7 May 2011 by Goff (talk | contribs) (move footer template to actual end (otherwise subsequent intervening text gets omitted); edits, tags and links)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Insert a Comment before this node (XmlNode class)

[Requires Janus SOAP]

The InsertCommentBefore callable function inserts a Comment node as the immediate sibling preceding the method XmlNode.

Syntax

[%outNod =] nod:InsertCommentBefore( value)

Syntax terms

%outNod If specified, an XmlNode that is set to point to the Comment node that is added.
nod XmlNode pointing to the (non-Root) node before which the Comment node is inserted.
value A Unicode string that is the value of the added Comment node; stored exactly as is, that is, without whitespace normalization.

Usage notes

  • Since the return value of InsertCommentBefore is frequently not needed, you may want to Call it instead of saving its return value.
  • As of "Sirius Mods" Version 7.3, value may include only non-null EBCDIC characters that translate to Unicode. As of "Sirius Mods" Version 7.6, all "Janus Soap" string arguments and results are Unicode or are converted to Unicode. For more information about the effects of this Version 7.6 change, see "Strings and Unicode with the XmlDoc API".
  • There is a very small "one-time" processing cost if certain XPath operations are performed after using this method, because Insert-Before methods are guaranteed to add a node out of document order. In general, processing an XmlDoc is likely to be more efficient if you add nodes in document order (that is, top-to-bottom, left-to-right).
  • To modify the value stored in a Comment node, change the Value property of an XmlNode that points to the Comment node.

Examples

  1. In the following example, a Comment node is inserted before node "a":

    begin %doc is object xmlDoc %doc = new Call %doc:loadXml('<top><a><b>05</b></a></top>') %n1 is object xmlNode %n1 = %doc:selectSingleNode('top/a') call %n1:insertCommentBefore('legacy code follows') call %doc:Print end

    The example results follow:

    <top> <a> <b>05</b> </a> </top>

Request-Cancellation Errors

  • Nod is the Root node.
  • value violates the rules for an XML comment.

See also

  • AddComment also adds a Comment node. InsertCommentBefore adds a Comment as the immediately preceding sibling of the node pointed to by the method object; AddComment adds the Comment as the last child of the node pointed to by the method object.
  • For hints about inserting a node after a sibling node, see the "Examples in InsertElementBefore".