Using rapidxml I'm wanting to loop through a set of nodes, and am using what I found to be the best way to do this (from trusty stackoverflow, the doc doesn't appear to have an example of iteration):
while (curNode->next_sibling() !=NULL ) {
string shiftLength = curNode->first_attribute("shiftLength")->value();
cout << "Shift Length " << "\t" << shiftLength << endl;
curNode = curNode->next_sibling();
}
Unfortunately, on my OSX 10.6 this is leaving out the last sibling node - I guess because in the last iteration of the loop, next_sibling is called twice. I can get at this last node if I write, after the loop:
cout << " LAST IS: " << curNode->first_attribute("shiftLength")->value();
...but that's dodgy, and the program quits at that point.
First question: Could this be a unique foible of my setup (OSX 10.6) or have I coded wrong?
Second question: Does anyone have an example of what they believe is the correct way to iterate through an unknown number of XML nodes using rapidxml?
Thanks guys
Pete
This is the proper way to iterate though all child nodes of a node in rapidxml:
xml_node<> *node = ...
for (xml_node<> *child = node->first_node(); child; child = child->next_sibling())
{
// do stuff with child
}
Here's the final code in working form:
xml_node<> *curNode = ... // e. g. parentNode->first_node();
while (curNode) {
string start = curNode->first_attribute("start")->value();
string numStaff = curNode->first_attribute("numStaff")->value();
cout << start << "\t" << numStaff << endl;
curNode = curNode->next_sibling();
}
while (curNode->next_sibling() !=NULL )
This says "while there's one more node left after the one I'm working on". That's why your loop's stopping early - when curNode
is the final sibling, its "next_sibling
" will be NULL. This test should work better:
while (curNode !=NULL )
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With