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


C++ ParseNode::begin方法代码示例

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


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

示例1: addSymbols

// pre: the state 'lastState' is a newly created state that has only a lambda transition coming in to it.
// post: lastState is updated to a new state that has the property that only lambda transitions go to it.
void addSymbols(ParseNode::iterator_type begin, ParseNode::iterator_type end, FaSymbolTable &symTab, FaRuleIr &ruleIr, FaNfa *nfa, unsigned &lastState)
{
	for(ParseNode::iterator_type i = begin; i != end; ++i)
	{
		assert((*i)->getToken() == RULE_rcsymbol);
		unsigned symbolHeadToken = (*(*i)->begin())->getToken();
	
		if(symbolHeadToken == RULE_rcitem)
		{
			ParseNode *item = *(*i)->begin();
			assert(item->getToken() == RULE_rcitem);
			
			ParseNode *item2 = *item->begin();
			std::string item2Text = item2->getTokenText();
			unsigned newState = ruleIr.addState(*nfa);
			
			bool ok = ruleIr.addEdge(*nfa, lastState, newState, item2Text);
			if(!ok)
			{
				std::string msg = "error adding NFA transition (check that keywords and tokens are defined before use)";
				throw ParseSpecificError((*i)->getLine(), (*i)->getFile(), msg);
			}
			
			lastState = newState;
		}
		else
		if(symbolHeadToken == '{' || symbolHeadToken == '[')
		{
			unsigned q0 = ruleIr.addState(*nfa);
			ruleIr.addLambda(*nfa, lastState, q0);
			lastState = q0;
			ParseNode::iterator_type j = (*i)->begin();
			ParseNode *alternate = *++j;
			assert(alternate->getToken() == RULE_rcalternate);
			addSymbols(alternate->begin(), alternate->end(), symTab, ruleIr, nfa, lastState);
			
			if(symbolHeadToken == '{')
				ruleIr.addLambda(*nfa, lastState, q0);
			ruleIr.addLambda(*nfa, q0, lastState);
			unsigned qf = ruleIr.addState(*nfa);
			ruleIr.addLambda(*nfa, lastState, qf);
			lastState = qf;
		}
	}
	
	unsigned newState = ruleIr.addState(*nfa);
	ruleIr.addLambda(*nfa, lastState, newState);
	lastState = newState;
}
开发者ID:huffman,项目名称:CRUDASM7,代码行数:51,代码来源:ruleparse.cpp

示例2: doParse

// pre: root != NULL
void doParse(ParseNode *root, std::string inFileName, std::string outBaseName)
{
	std::map<std::string, std::string> firstManualToken;
	FaSymbolTable symTab;
	FaRuleIr ruleIr(&symTab);

	// Iterate thru children of start symbol.
	for(ParseNode::iterator_type i = root->begin(); i != root->end(); ++i)
	{
		ParseNode *statement = *i;
		ParseNode *statementHead = *statement->begin();
		std::string statementHeadText = statementHead->getTokenText();
		if(statementHeadText.empty())
		{
			// name "::=" alternate { '|' alternate } ';'
			// name ::= IDENT | "start" ;
			///std::cout << "[name]" << std::endl;
			std::string ruleName = (*statementHead->begin())->getTokenText();
			ParseNode::iterator_type j = statement->begin();
			++j;	// skip ruleName
			++j;	// skip "::="
			for(;;)
			{
				ParseNode *alternate = *j;
				
				parseAlternate(symTab, ruleIr, alternate, ruleName);
				
				++j;	// skip alternate
				if((*j)->getTokenText() != "|")
					break;	// found ';' at end
				++j;	// skip '|'
			}
		}
		else
		if(statementHeadText == "token")
		{
			for(ParseNode::iterator_type j = ++statement->begin(); j != statement->end(); ++j)
			{
				std::string s = (*j)->getTokenText();
				if(s == ";")
					break;
				ruleIr.addToken(s);
			}
		}
		else
		if(statementHeadText == "keyword")
		{
			std::string s1 = (*(++statement->begin()))->getTokenText();
			std::string s2 = (*(++(++statement->begin())))->getTokenText();
			ruleIr.addKeyword(s1, s2);
		}
		else
		if(statementHeadText == "copyright")
		{
			ruleIr.setCopyright(unquote((*(++statement->begin()))->getTokenText()));
		}
		else
		if(statementHeadText == "prefix")
		{
			ruleIr.setPrefix(unquote((*(++statement->begin()))->getTokenText()));
		}
		else
		if(statementHeadText == "manual")
		{
			ParseNode::iterator_type j = ++statement->begin();
			std::string s0 = (*j)->getTokenText();
			++j;
			std::string s1 = unquote((*j)->getTokenText());
			++j;
			ruleIr.addToken(s0);
			firstManualToken[s0] = s1;
			if(s1.empty() || (s1.size() & 1) != 0)
			{
				std::string msg = "invalid manual token definition (both string literals must be nonempty and even in length)";
				throw ParseSpecificError((*i)->getLine(), (*i)->getFile(), msg);
			}
		}
	}
	
	std::string err = ruleIr.convertGrammar();
	if(!err.empty())
	{
		std::cerr << "error: " << inFileName << ": " << err << std::endl;
		throw ParseError();
	}
	
	std::string fn1 = "out_" + outBaseName + "_parser.h";
	std::string fn2 = "out_" + outBaseName + "_header.h";
	std::string fn3 = "out_" + outBaseName + "_lexer.h";
	
	std::ofstream fo1(fn1.c_str());
	ruleIr.writeParser(fo1, fn1);
	std::ofstream fo2(fn2.c_str());
	ruleIr.writeHeader(fo2, fn2);
	std::ofstream fo3(fn3.c_str());
	ruleIr.writeLexer(fo3, fn3, firstManualToken);
}
开发者ID:huffman,项目名称:CRUDASM7,代码行数:98,代码来源:ruleparse.cpp


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