4

我在将具有 iostream 解析支持的类集成到精神解析器中时遇到了一些麻烦。下面的示例(根据 Spirit 示例修改)演示了该问题。如果我尝试仅解析自定义类,它会成功,如第一次解析和调用断言所示。如果我尝试解析自定义类以及(在这种情况下)逗号和浮点数,解析器将失败。

谁能阐明为什么会这样?如果我使用精神解析器而不是流解析器,我可以使第二个示例工作,但这违背了使用 stream_parser 的目的。

我在本地示例中启用了规则调试,这表明自定义解析器使用了字符串的全部内容 - 但是,代码显示它不应该这样做......

任何帮助表示赞赏!

提升 1.44.0,gcc 4.1.1

#include <boost/spirit/include/qi.hpp>

struct complex
{
  complex (double a = 0.0, double b = 0.0) : a(a), b(b) {}
  double a,b;
};

std::istream& operator>> (std::istream& is, complex& z)
{
  char lbrace = '\0', comma = '\0', rbrace = '\0';
  is >> lbrace >> z.a >> comma >> z.b >> rbrace;
  if (lbrace != '{' || comma != ',' || rbrace != '}')
      is.setstate(std::ios_base::failbit);
  return is;
}

int main( int argc, char**argv)
{
  using namespace boost::spirit;
  complex parsedComplex;
  float   parsedFloat;
  bool result;

  std::string str = "{1.0,2.5}";
  std::string::iterator first = str.begin();
  result = qi::phrase_parse(first,str.end(),
    qi::stream_parser<char,complex>(), ascii::blank,parsedComplex);
  assert(result && first==str.end()); // OK

  str = "{1.0,2.5},123.456";
  first = str.begin();
  result = qi::phrase_parse(first,str.end(),
     qi::stream_parser<char,complex>() >> qi::lit(',') >> qi::float_,
     ascii::blank,parsedComplex,parsedFloat);
  assert(result && first==str.end());  // FAILS
}
4

1 回答 1

5

这原来是流解析器组件中的一个错误。它没有考虑底层标准流正在缓冲输入的事实。该问题已在 SVN 中修复,该修复将成为 Boost V1.47 的一部分。我根据您的代码在 Spirit 的回归测试套件中添加了一个新测试 - 希望您不介意。感谢您的报告!

于 2011-03-26T01:08:57.370 回答