本文整理汇总了C++中tokenizer::found方法的典型用法代码示例。如果您正苦于以下问题:C++ tokenizer::found方法的具体用法?C++ tokenizer::found怎么用?C++ tokenizer::found使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类tokenizer
的用法示例。
在下文中一共展示了tokenizer::found方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: parse
void protoDeclaration::parse(tokenizer &tokens, void *data)
{
tokens.syntax_start(this);
tokens.increment(true);
tokens.expect("]");
tokens.increment(true);
tokens.expect<interfaceDeclaration>();
tokens.increment(true);
tokens.expect("[");
tokens.increment(true);
tokens.expect<parse::instance>();
tokens.increment(true);
tokens.expect("PROTO");
tokens.expect("EXTERNPROTO");
if (tokens.decrement(__FILE__, __LINE__, data))
{
if (tokens.found("PROTO"))
external = false;
else if (tokens.found("EXTERNPROTO"))
external = true;
}
if (tokens.decrement(__FILE__, __LINE__, data))
nodeType = tokens.next();
if (tokens.decrement(__FILE__, __LINE__, data))
tokens.next();
while (tokens.decrement(__FILE__, __LINE__, data))
{
interfaces.push_back(interfaceDeclaration(tokens, external, data));
tokens.increment(false);
tokens.expect<interfaceDeclaration>();
}
if (tokens.decrement(__FILE__, __LINE__, data))
tokens.next();
if (external)
{
tokens.increment(true);
tokens.expect<fieldValue>();
if (tokens.decrement(__FILE__, __LINE__, data))
value = fieldValue(tokens, "MFString", data);
}
else
{
tokens.increment(true);
tokens.expect("}");
tokens.increment(true);
tokens.expect<scene>();
tokens.increment(true);
tokens.expect("{");
if (tokens.decrement(__FILE__, __LINE__, data))
tokens.next();
if (tokens.decrement(__FILE__, __LINE__, data))
sub = new scene(tokens, data);
if (tokens.decrement(__FILE__, __LINE__, data))
tokens.next();
}
tokens.syntax_end(this);
}
示例2: parse
void statement::parse(tokenizer &tokens, void *data)
{
tokens.syntax_start(this);
statement_type = "node";
tokens.increment(true);
tokens.expect("graph");
tokens.expect("node");
tokens.expect("edge");
tokens.expect<node_id>();
tokens.expect("subgraph");
if (tokens.decrement(__FILE__, __LINE__, data))
{
if (tokens.found("subgraph"))
nodes.push_back(new graph(tokens, data));
else if (tokens.found<node_id>())
nodes.push_back(new node_id(tokens, data));
else
{
statement_type = "attribute";
attribute_type = tokens.next();
}
}
if (statement_type != "attribute")
{
tokens.increment(false);
tokens.expect("->");
tokens.expect("--");
while (tokens.decrement(__FILE__, __LINE__, data))
{
statement_type = "edge";
tokens.next();
tokens.increment(false);
tokens.expect("->");
tokens.expect("--");
tokens.increment(true);
tokens.expect<node_id>();
tokens.expect("subgraph");
if (tokens.decrement(__FILE__, __LINE__, data))
{
if (tokens.found("subgraph"))
nodes.push_back(new graph(tokens, data));
else if (tokens.found<node_id>())
nodes.push_back(new node_id(tokens, data));
}
}
}
tokens.increment(statement_type == "attribute");
tokens.expect<attribute_list>();
if (tokens.decrement(__FILE__, __LINE__, data))
attributes.parse(tokens, data);
tokens.syntax_end(this);
}