Comment puis-je parse fin de ligne avec boost :: esprit :: qi?
-
19-09-2019 - |
Question
Si pas d'un simple eol
faire l'affaire?
#include <algorithm>
#include <boost/spirit/include/qi.hpp>
#include <iostream>
#include <string>
using boost::spirit::ascii::space;
using boost::spirit::lit;
using boost::spirit::qi::eol;
using boost::spirit::qi::phrase_parse;
struct fix : std::unary_function<char, void> {
fix(std::string &result) : result(result) {}
void operator() (char c) {
if (c == '\n') result += "\\n";
else if (c == '\r') result += "\\r";
else result += c;
}
std::string &result;
};
template <typename Parser>
void parse(const std::string &s, const Parser &p) {
std::string::const_iterator it = s.begin(), end = s.end();
bool r = phrase_parse(it, end, p, space);
std::string label;
fix f(label);
std::for_each(s.begin(), s.end(), f);
std::cout << '"' << label << "\":\n" << " - ";
if (r && it == end) std::cout << "success!\n";
else std::cout << "parse failed; r=" << r << '\n';
}
int main() {
parse("foo", lit("foo"));
parse("foo\n", lit("foo") >> eol);
parse("foo\r\n", lit("foo") >> eol);
}
Sortie:
"foo": - success! "foo\n": - parse failed; r=0 "foo\r\n": - parse failed; r=0
Pourquoi les deux derniers échouent?
Question connexe:
La solution
Vous utilisez space
comme skipper pour vos appels à phrase_parse. Cet analyseur correspond à un caractère pour lequel retourne std::isspace
vrai (en supposant que vous faites l'analyse syntaxique à base ascii). Pour cette raison, le \r\n
dans l'entrée sont mangés par votre skipper avant de pouvoir être vus par votre analyseur eol
.
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow