我想使用类似于C的转义规则来解析字符串。我想保留转义符,而不是对其进行解码,然后再进行编码。因此,我认为*(char_('\\') >> char_ | char_ - '"')可以满足我的要求,但事实并非如此:它的行为就像我编写了lit('\\')来丢弃那个家伙一样。

#define TEST(Rule) test(input, #Rule, Rule)
int main()
{
  const auto input = std::string{"\\( \\\" \\\\ \\)"};
  TEST(lexeme[*(lit('\\') >> char_ | char_ - '"')]);
  TEST(lexeme[*(char_('\\') >> char_ | char_ - '"')]);
  TEST(lexeme[*char_]);
}


\( \" \\ \): lexeme[*(lit('\\') >> char_ | char_ - '"')]: ( " \ )
\( \" \\ \): lexeme[*(char_('\\') >> char_ | char_ - '"')]: ( " \ )
\( \" \\ \): lexeme[*char_]: \( \" \\ \)

整个示例在Coliru上可用。

最佳答案

您的第二个语法(lexeme[*(char_('\\') >> char_ | char_ - '"')])的代码是正确的(char_('\\')应该合成为char类型的属性,并始终返回'\\'值)。

刚才已确认这是Spirit中的错误:https://github.com/boostorg/spirit/issues/434

关于c++ - Boost.X3:char_ >> char_丢弃字符并表现为点亮,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48390872/

10-10 23:19