我有一个奇怪的案例,我现在正在使用,我需要在两个不同的上下文中使用相同的符号表。在“J”命令的情况下,我只想查看以特定前缀开头的符号表的元素,但是这个前缀不是在解析的文本中指定的,而是仅用于查找符号表。
我目前的解决方案是遍历解析器外部的符号表,生成第二个专门用于此“J”命令的符号表,但我很好奇是否有办法将其组合到解析器中。 / p>
目前,以下玩具代码结果为100,10,10,对myRule中的第一个symTable引用是否有相当容易的修改,这样它将解析为100,10,1?
#define BOOST_SPIRIT_USE_PHOENIX_V3
#include <boost/spirit/include/qi.hpp>
#include <boost/spirit/include/phoenix.hpp>
#include <boost/spirit/include/qi_symbols.hpp>
#include <boost/foreach.hpp>
#include <string>
#include <vector>
#include <iostream>
namespace qi = boost::spirit::qi;
namespace phx = boost::phoenix;
int main() {
qi::symbols<char, unsigned int> symTable;
symTable.add("prefix_A", 1)
("A" , 10);
qi::rule<std::string::const_iterator, unsigned int()> xRule = qi::lit("X")[qi::_val = 100];
qi::rule<std::string::const_iterator, unsigned int()> myRule =
(qi::lit("J") >> qi::omit[+qi::space] >> symTable/*("prefix_")*/)
| (qi::lit("R") >> qi::omit[+qi::space] >> symTable)
| xRule;
std::string test = "X;R A;J A";
std::string::const_iterator it= test.begin();
std::string::const_iterator end= test.end();
std::vector<unsigned int> results;
if (!qi::parse(it, end, (myRule % ";"), results))
std::cout << "Parse Failed\n";
else {
BOOST_FOREACH(unsigned int x, results)
std::cout << x << ",";
if(it != end)
std::cout << "\nIncomplete Parse\n";
else
std::cout << "\nParsed\n";
}
return 0;
}