当前位置: 首页>>代码示例>>C++>>正文


C++ ASTNode::getChildren方法代码示例

本文整理汇总了C++中ASTNode::getChildren方法的典型用法代码示例。如果您正苦于以下问题:C++ ASTNode::getChildren方法的具体用法?C++ ASTNode::getChildren怎么用?C++ ASTNode::getChildren使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ASTNode的用法示例。


在下文中一共展示了ASTNode::getChildren方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: visitOnEnteringPolygon

        OnEnteringPolygon* SITSituationVisitor::visitOnEnteringPolygon(ASTNode *node) {
            OnEnteringPolygon *oep = NULL;

            if (node != NULL) {
                oep = new OnEnteringPolygon();

                ASTNode *n = findByKey("OBJECTID", node->getParent(), 3);
                if (n == NULL) {
                    OPENDAVINCI_CORE_THROW_EXCEPTION(SITSituationVisitorException, "Node to get name from OBJECTID expected.");
                }
                oep->setID(n->getValue<uint32_t>());

                n = findByKey("VERTEX2", node->getParent(), 4);
                if (n == NULL) {
                    OPENDAVINCI_CORE_THROW_EXCEPTION(SITSituationVisitorException, "Node to get name from VERTEX222 expected.");
                }
                n = n->getParent()->getParent();
                vector<ASTNode*> listOfEnteringPolygon = n->getChildren();
                vector<ASTNode*>::iterator it = listOfEnteringPolygon.begin();
                while (it != listOfEnteringPolygon.end()) {
                    n = (*it++);
                    if (n->getFirstChild()->getKey() == "VERTEX2") {
                        oep->add(visitVertex3(n));
                    }
                }
            }

            return oep;
        }
开发者ID:TacoVox,项目名称:OpenDaVINCI,代码行数:29,代码来源:SITSituationVisitor.cpp

示例2: visitChildren

void ASTVisitor::visitChildren(const ASTNode& node)
{
   const ASTNodes& children = node.getChildren();
   for ( int index = 0; index < children.size(); index++ )
   {
      const ASTNode& child = children[index];
      child.accept(*this);
   }
}
开发者ID:crafter2d,项目名称:crafter2d,代码行数:9,代码来源:astvisitor.cpp

示例3:

bool ASTNode::operator==(const ASTNode& rhs) const {
  if (typeid(*this) != typeid(rhs)) return false;
  if (children.size() != rhs.getChildren().size()) return false;
  for (uint64 i = 0; i < children.size(); i++) {
    if (this->at(i) == nullptr && rhs.at(i) == nullptr) continue;
    if (*(this->at(i)) != *(rhs.at(i))) return false;
  }
  return true;
}
开发者ID:slak44,项目名称:test-lang,代码行数:9,代码来源:ast.cpp

示例4: reverseVisitChildren

void ASTVisitor::reverseVisitChildren(const ASTNode& node)
{
   const ASTNodes& children = node.getChildren();
   children.accept(*this);
}
开发者ID:crafter2d,项目名称:crafter2d,代码行数:5,代码来源:astvisitor.cpp


注:本文中的ASTNode::getChildren方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。