Source: queryNodesSmart.cpp
This example application calls both the selectSingleNode
method and the selectNodes
method on an XML DOM object loaded from the stocks.xml file. The same XPath expression is input to both methods:
//stock[1]/*
This expression specifies all the child elements of the first <stock>
element in the XML document. In MSXML, the selectSingleNode
method returns the first element of the resultant node-set, and the selectNodes
method returns all the elements in the node-set.
Programmatically, this source code performs the following steps:
Creates an instance of an XML DOM object (
pXMLDom
).Calls the
load
method onpXMLDom
to load XML data from a file (stocks.xml).Calls the
selectSingleNode
method onpXMLDom
to select a DOM node according to the input XPath expression (//stock[1]/*
). Then displays the resulting node in the console if the query is successful.Calls the
selectNodes
method onpXMLDom
to select a DOM node-set according to the input XPath expression ("//stock[1]/*
"). Then displays the resulting nodes in the console if the query is successful.
C/C++ Source File (queryNodesSmart.cpp)
#include <stdio.h>
#include <tchar.h>
#import <msxml6.dll>
// Macro that calls a COM method returning HRESULT value.
#define CHK_HR(stmt) do { hr=(stmt); if (FAILED(hr)) goto CleanUp; } while(0)
void queryNodesSmart()
{
MSXML2::IXMLDOMDocumentPtr pXMLDom;
HRESULT hr = pXMLDom.CreateInstance(__uuidof(MSXML2::DOMDocument60), NULL, CLSCTX_INPROC_SERVER);
if (FAILED(hr))
{
printf("Failed to instantiate an XML DOM.\n");
return;
}
try
{
pXMLDom->async = VARIANT_FALSE;
pXMLDom->validateOnParse = VARIANT_FALSE;
pXMLDom->resolveExternals = VARIANT_FALSE;
if ( pXMLDom->load(L"stocks.xml") != VARIANT_TRUE)
{
CHK_HR(pXMLDom->parseError->errorCode);
printf("Failed to load DOM from stocks.xml.\n%s\n",
(LPCSTR)pXMLDom->parseError->Getreason());
}
// Query a single node.
MSXML2::IXMLDOMNodePtr pNode = pXMLDom->selectSingleNode(L"//stock[1]/*");
if (pNode)
{
printf("Result from selectSingleNode:\nNode, <%s>:\n\t%s\n\n",
(LPCSTR)pNode->nodeName, (LPCSTR)pNode->xml);
}
else
{
printf("No node is fetched.\n");
}
// Query a node-set.
MSXML2::IXMLDOMNodeListPtr pnl = pXMLDom->selectNodes(L"//stock[1]/*");
if(pnl)
{
printf("Results from selectNodes:\n");
for (long i = 0; i < pnl->length; i++)
{
pNode = pnl->item[i];
printf("Node (%d), <%s>:\n\t%s\n",
i, (LPCSTR)pNode->nodeName, (LPCSTR)pnl->item[i]->xml);
}
}
else
{
printf("No node set is fetched.\n");
}
}
catch (_com_error errorObject)
{
printf("Exception thrown, HRESULT: 0x%08x", errorObject.Error());
}
CleanUp:
return;
}
int _tmain(int argc, _TCHAR* argv[])
{
HRESULT hr = CoInitialize(NULL);
if (SUCCEEDED(hr))
{
queryNodesSmart();
CoUninitialize();
}
return 0;
}
To add the queryNodes source code to the project
Select FileView on the project browser, and highlight queryNodeSmartProj files. From the File menu, select New.
On the Files tab of the New dialog box, highlight C++ Source File. Then type "queryNodes.cpp" in the File name text box, and click OK.
Copy the C/C++ source code above and paste it into the source file you just created.
Next, we'll add the resource file to the queryNodesSmart project.