Rogue Wave banner
Previous fileTop of DocumentContentsIndex pageNext file
Objective Toolkit User's Guide
Rogue Wave web site:  Home Page  |  Main Documentation Page

30.10 XML Helpers

OTL provides the COtlXMLDocument class to provide a simplified method for creating XML files and editing their content. The class is based on the Microsoft XML parser provided in Internet Explorer. COtlXMLDocument is compatible with recent IE releases. To begin using COtlXMLDocument, create an instance either on the stack or heap, and then read the following section.

30.10.1 Creating an XML Document From Scratch

Use the Create() function to generate an empty XML document. You can specify the root tag name and XML header string as parameters, as shown below:

30.10.2 Opening an Existing XML Document

Existing documents can be loaded directly from a file using the LoadFromFile() function, which specifies a full file path, as shown here:

30.10.3 Adding Tags

The AddTag() and AddTextTag() methods create new document tags as children of the root element, or any other element. AddTag() gives you full control of the type of tag to create. AddTextTag() creates two tags: an outer element with an inner text element. This is essentially a name/value pair. For example, the following code results in the following XML added as a child of the root element:

30.10.4 Saving the XML Document to a File

You can save a document directly to a file using the SaveToFile() function, as shown here:

If the file does not exist, it is created. If it exists, it is overwritten.

30.10.5 Reading Tag Values

You can retrieve the value of a tag by searching on the name of the element. Searching is supported by COtlXMLDocument mapping of tag names to values in an STL map. You specify the level in the hierarchy where the map begins using MapElements() and a flat map of all children is generated. LoadMap() can be used instead of MapElements() when the entire file is mapped. You can disable recursion with a parameter to MapElements(). You can generate maps multiple times during a session. Every time MapElements() or LoadMap() is called, the contained STL map is cleared and populated with new value pairs. Once the map is generated, you can use FindTextTag() to get its associated text as a string or variant. For example, the <Child>1234</Child> tag can be read as a variant of type long integer like this:

If you already have an IXMLElement pointer, its associated text value can be retrieved using GetTextTag() instead.

30.10.6 Trace Output

COtlXMLDocument has debug facilities for dumping the contents of an XML element and its children to the Visual Studio debug output window. Use the TRACE_ELEMENT() function with no parameters to show the contents of the root element only. Use TRACE_ELEMENT(IXMLElement* pElem) to show all children of pElem.


TRACE_ELEMENT() is a function name—not a macro.



Previous fileTop of DocumentContentsNo linkNext file

Copyright © Rogue Wave Software, Inc. All Rights Reserved.

The Rogue Wave name and logo, and Stingray, are registered trademarks of Rogue Wave Software. All other trademarks are the property of their respective owners.
Provide feedback to Rogue Wave about its documentation.