我想使用类似于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/