我正在使用提升精神x3并且一点都不清楚。我有一个具有非常不同和重复的行的文件。前几行可能是评论。接下来的1000行可能是坐标,下一千行可能是int的列表等等......
我的问题是如何识别该行并知道该行使用哪个解析器。例如,这里有两个解析器函数....
template <typename Iterator>
bool parse_ints(Iterator first, Iterator last, std::vector<int>& v)
{
using x3::int_;
using x3::phrase_parse;
using x3::_attr;
using ascii::space;
auto push_back = [&](auto& ctx){ v.push_back(_attr(ctx)); };
bool r = phrase_parse(first, last,
(
int_[push_back]
>> *(',' >> int_[push_back])
)
,
space);
if (first != last)
return false;
return r;
}
template <typename Iterator>
bool parse_doubles(Iterator first, Iterator last, std::vector<double>& v)
{
using x3::double_;
using x3::phrase_parse;
using x3::_attr;
using ascii::space;
auto push_back = [&](auto& ctx){ v.push_back(_attr(ctx)); };
bool r = phrase_parse(first, last,
(
double_[push_back]
>> *(',' >> double_[push_back])
)
,
space);
if (first != last) // fail if we did not get a full match
return false;
return r;
}
以下是输入的输入方式(istringstream的大小为数百MB)。在while循环中,我想知道要调用哪个解析器。
int main()
{
istringstream str(my.data());
while (getline(str, line)) {
// based on the format of 'line', how does one know which
// parser to call?
}
}
答案 0 :(得分:1)
你的语法可以描述整个输入。所以你可以说
auto input = *headerComment
>> points
>> edges;
你可以简单地定义
auto headerComment = '#' >> *(char_ - eol) >> eol;
例如
auto points = skip(blank) [
*(point >> eol)
];
auto edges = skip(blank) [
*(edge >> eol)
];
point = int_ >> int_ >> int_; // assuming x y z
edge = int_ >> int_; // assuming from to
这假定输入格式是明确的。即如果点x y
只是因为它与边缘无法区分,它就不会起作用。