C
C
Traverse Direct Children via FirstChild / NextSibling, or LastChild / PreviousSibling
See more XML Examples
Demonstrates some ways to iterate over direct child nodes using the FirstChild / NextSibling and LastChild / PreviousSibling methods.The input XML, available at http://www.chilkatsoft.com/data/fruit.xml, is this:
<root>
<fruit color="red">apple</fruit>
<fruit color="green">pear</fruit>
<veg color="orange">carrot</veg>
<meat animal="cow">beef</meat>
<xyz>
<fruit color="blue">blueberry</fruit>
<veg color="green">broccoli</veg>
</xyz>
<fruit color="purple">grape</fruit>
<cheese color="yellow">cheddar</cheese>
</root>
Chilkat C Downloads
#include <C_CkXml.h>
void ChilkatSample(void)
{
BOOL success;
HCkXml xml;
HCkXml child;
HCkXml nextSibling;
HCkXml prevSibling;
BOOL bContinue;
success = FALSE;
xml = CkXml_Create();
success = CkXml_LoadXmlFile(xml,"qa_data/xml/fruit.xml");
if (success != TRUE) {
printf("%s\n",CkXml_lastErrorText(xml));
CkXml_Dispose(xml);
return;
}
// Iterate over the direct children by using FirstChild / NextSibling
child = CkXml_FirstChild(xml);
bContinue = CkXml_getLastMethodSuccess(xml);
while ((bContinue == TRUE)) {
printf("%s : %s\n",CkXml_tag(child),CkXml_content(child));
nextSibling = CkXml_NextSibling(child);
bContinue = CkXml_getLastMethodSuccess(child);
CkXml_Dispose(child);
child = nextSibling;
}
printf("-----\n");
// Do the same, but with FirstChild2 / NextSibling2 to avoid
// creating so many XML object instances:
success = CkXml_FirstChild2(xml);
while (success == TRUE) {
printf("%s : %s\n",CkXml_tag(xml),CkXml_content(xml));
success = CkXml_NextSibling2(xml);
}
// Revert back up to the parent:
success = CkXml_GetParent2(xml);
printf("-----\n");
// Iterate in reverse order using LastChild / PreviousSibling
child = CkXml_LastChild(xml);
bContinue = CkXml_getLastMethodSuccess(xml);
while ((bContinue == TRUE)) {
printf("%s : %s\n",CkXml_tag(child),CkXml_content(child));
prevSibling = CkXml_PreviousSibling(child);
bContinue = CkXml_getLastMethodSuccess(child);
CkXml_Dispose(child);
child = prevSibling;
}
printf("-----\n");
// Do the same, but with LastChild2 / PreviousSibling2 to avoid
// creating so many XML object instances:
success = CkXml_LastChild2(xml);
while (success == TRUE) {
printf("%s : %s\n",CkXml_tag(xml),CkXml_content(xml));
success = CkXml_PreviousSibling2(xml);
}
// Revert back up to the parent:
success = CkXml_GetParent2(xml);
CkXml_Dispose(xml);
}