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


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

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


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

示例1: buildSubTree

ASTNode* TestASTMatcher::buildSubTree()
{
	ASTNode* plusNode = new ASTNode("", PLUS, 0);
	ASTNode* minusNode = new ASTNode("", MINUS, 0);
	ASTNode* varNodeB = new ASTNode("b", VARIABLE, 0);
	ASTNode* varNodeC = new ASTNode("c", VARIABLE, 0);
	ASTNode* constantNode = new ASTNode("1", CONSTANT, 0);

	minusNode->joinChild(plusNode);
	plusNode->joinChild(varNodeB);
	varNodeB->joinNext(varNodeC);
	plusNode->joinNext(constantNode);

	return minusNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:15,代码来源:TestASTMatcher.cpp

示例2: buildSubTreeWithDiffValue

ASTNode* TestASTMatcher::buildSubTreeWithDiffValue()
{
	ASTNode* timesNode = new ASTNode("", TIMES, 0);
	ASTNode* divideNode = new ASTNode("", DIVIDE, 0);
	ASTNode* varNodeB = new ASTNode("b", VARIABLE, 0);
	ASTNode* varNodeC = new ASTNode("c", VARIABLE, 0);
	ASTNode* constantNode = new ASTNode("1", CONSTANT, 0);

	divideNode->joinChild(timesNode);
	timesNode->joinChild(varNodeB);
	varNodeB->joinNext(varNodeC);
	timesNode->joinNext(constantNode);

	return timesNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:15,代码来源:TestASTMatcher.cpp

示例3: ifStmt

ASTNode* Parser::ifStmt()
{
	matchKeyword("if");
	ASTNode* ifNode = new ASTNode("", IF, _stmtNum);

	_varTable->addVariable(_token);
	ASTNode* varNode = new ASTNode(_token, VARIABLE, 0);
	matchName();

	matchKeyword("then");
	matchKeyword("{");

	ASTNode* ifStmtListNode = statementList();

	matchKeyword("}");
	matchKeyword("else");
	matchKeyword("{");
	
	ASTNode* elseStmtListNode = statementList();

	matchKeyword("}");

	ifNode->joinChild(varNode);
	varNode->joinNext(ifStmtListNode);
	ifStmtListNode->joinNext(elseStmtListNode);

	return ifNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:28,代码来源:Parser.cpp

示例4: procedure

ASTNode* Parser::procedure()
{
	matchKeyword("procedure");

	if (_procTable->getIndex(_token) > -1) {
		throw ParseException(_stmtNum, _token, "Duplicate procedure names");
	}

	std::string procedure = _token;

	ASTNode* procNode = new ASTNode(procedure, PROCEDURE, 0);
	matchName();

	matchKeyword("{");
	int fromStmtNum = _stmtNum + 1;

	ASTNode* stmtListNode = statementList();
	
	matchKeyword("}");
	int toStmtNum = _stmtNum;

	_procTable->addProcedure(procedure, fromStmtNum, toStmtNum);

	procNode->joinChild(stmtListNode);

	return procNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:27,代码来源:Parser.cpp

示例5: buildTree

ASTNode* TestASTMatcher::buildTree()
{
	ASTNode* assignNode = new ASTNode("", ASSIGN, 1);
	ASTNode* plusNode = new ASTNode("", PLUS, 0);
	ASTNode* minusNode = new ASTNode("", MINUS, 0);
	ASTNode* varNodeA = new ASTNode("a", VARIABLE, 0);
	ASTNode* varNodeB = new ASTNode("b", VARIABLE, 0);
	ASTNode* varNodeC = new ASTNode("c", VARIABLE, 0);
	ASTNode* constantNode = new ASTNode("1", CONSTANT, 0);

	assignNode->joinChild(varNodeA);
	varNodeA->joinNext(minusNode);
	minusNode->joinChild(plusNode);
	plusNode->joinChild(varNodeB);
	varNodeB->joinNext(varNodeC);
	plusNode->joinNext(constantNode);

	return assignNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:19,代码来源:TestASTMatcher.cpp

示例6: assignStmt

ASTNode* Parser::assignStmt()
{
	_varTable->addVariable(_token);
	ASTNode* varNode = new ASTNode(_token, VARIABLE, 0);
	matchName();

	matchKeyword("=");
	ASTNode* assignNode = new ASTNode("", ASSIGN, _stmtNum);

	ASTNode* expNode = expression();

	matchKeyword(";");

	assignNode->joinChild(varNode);
	varNode->joinNext(expNode);

	return assignNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:18,代码来源:Parser.cpp

示例7: program

ASTNode* Parser::program()
{
	ASTNode* progNode = new ASTNode("Simple", PROGRAM, 0);

	ASTNode* procNode = procedure();

	progNode->joinChild(procNode);

	ASTNode* prevProcNode;

	while (isKeyword("procedure")) {
		prevProcNode = procNode;
		procNode = procedure();

		prevProcNode->joinNext(procNode);
	}

	return progNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:19,代码来源:Parser.cpp

示例8: statementList

ASTNode* Parser::statementList()
{
	ASTNode* stmtListNode = new ASTNode("", STATEMENT_LIST, 0);

	ASTNode* stmtNode = statement();

	stmtListNode->joinChild(stmtNode);

	ASTNode* prevStmtNode;

	while (!isKeyword("}")) {
		prevStmtNode = stmtNode;
		stmtNode = statement();

		prevStmtNode->joinNext(stmtNode);
	}

	return stmtListNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:19,代码来源:Parser.cpp

示例9: whileStmt

ASTNode* Parser::whileStmt()
{
	matchKeyword("while");
	ASTNode* whileNode = new ASTNode("", WHILE, _stmtNum);

	_varTable->addVariable(_token);
	ASTNode* varNode = new ASTNode(_token, VARIABLE, 0);
	matchName();

	matchKeyword("{");

	ASTNode* stmtListNode = statementList();
	
	matchKeyword("}");

	whileNode->joinChild(varNode);
	varNode->joinNext(stmtListNode);

	return whileNode;
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:20,代码来源:Parser.cpp

示例10: buildOperators

void ASTExpressionBuilder::buildOperators()
{
	ASTNode* operatorNode;
	ASTNode* leftNode;
	ASTNode* rightNode;

	ASTType type;

	if (_operators.back() == "+") {
		type = PLUS;
	} else if (_operators.back() == "-") {
		type = MINUS;
	} else if (_operators.back() == "*") {
		type = TIMES;
	}else if (_operators.back() == "/") {
		type = DIVIDE;
	}

	operatorNode = new ASTNode("", type, 0);

	if (!_results.empty()) {
		rightNode = _results.back();
		_results.pop_back();
	} else {
		throw ParseException(_token, "Unable to parse expression");
	}

	if (!_results.empty()) {
		leftNode = _results.back();
		_results.pop_back();
	} else {
		throw ParseException(_token, "Unable to parse expression");
	}

	operatorNode->joinChild(leftNode);
	leftNode->joinNext(rightNode);

	_results.push_back(operatorNode);

	_operators.pop_back();
}
开发者ID:kwajunyong,项目名称:chocolate-muffins,代码行数:41,代码来源:ASTExpressionBuilder.cpp


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