15 #include <boost/algorithm/string.hpp>
36 while ((thisNode = iter()))
54 while ((thisNode = iter()))
56 if (thisNode->
getType() == requiredType && thisNode->
getName() == requiredName)
62 if (thisNode->
getType() ==
"PHCompositeNode")
65 PHNode *nodeFoundInSubTree = nodeIter.
findFirst(requiredType.c_str(), requiredName.c_str());
66 if (nodeFoundInSubTree)
return nodeFoundInSubTree;
78 while ((thisNode = iter()))
80 if (thisNode->
getName() == requiredName)
86 if (thisNode->
getType() ==
"PHCompositeNode")
90 if (nodeFoundInSubTree)
92 return nodeFoundInSubTree;
104 if (pathString.empty())
113 vector<string> splitpath;
118 for (vector<string>::const_iterator iter = splitpath.begin(); iter != splitpath.end(); ++iter)
136 while ((subNode = subNodeIter()))
138 if (subNode->
getType() ==
"PHCompositeNode" && subNode->
getName() == *iter)
166 while ((thisNode = iter()))
168 if (thisNode->
getType() ==
"PHCompositeNode")
171 subNodeIter.
forEach(operation);
PHPointerList< PHNode > subNodes
void print(const std::string &="")
PHBoolean addNode(PHNode *)
void for_each(PHNodeOperation &)
PHPointerList< PHNode > & ls()
PHBoolean addNode(PHNode *)
PHBoolean cd(const std::string &pathString="")
PHPointerList< PHNode > subNodeList
PHCompositeNode * currentNode
PHNode * findFirst(const std::string &, const std::string &)
void forEach(PHNodeOperation &)
const std::string getType() const
const std::string getName() const
PHNode * getParent() const
static const std::string nodetreepathdelim