Puede 'enlazar' referencias de atributos. qi::parse
, qi::phrase_parse
(y relacionados) aceptan argumentos variados que se utilizarán para recibir los atributos expuestos.
Un ejemplo simplista es: (EDITAR incluyó un ejemplo utree
demasiado)
#include <boost/fusion/adapted.hpp>
#include <boost/spirit/include/qi.hpp>
#include <boost/spirit/include/support_utree.hpp>
namespace qi = boost::spirit::qi;
int main()
{
using namespace qi;
std::string input("1 2 3 4 5");
std::string::const_iterator F(input.begin()), f(F), l(input.end());
std::vector<int> ints;
if (qi::phrase_parse(f = F, l, *qi::int_, qi::space, ints))
std::cout << ints.size() << " ints parsed\n";
int i;
std::string s;
// it is variadic:
if (qi::parse(f = F, l, "1 2 " >> qi::int_ >> +qi::char_, i, s))
std::cout << "i: " << i << ", s: " << s << '\n';
std::pair<int, std::string> data;
// any compatible sequence can be used:
if (qi::parse(f = F, l, "1 2 " >> qi::int_ >> +qi::char_, data))
std::cout << "first: " << data.first << ", second: " << data.second << '\n';
// using utree:
boost::spirit::utree tree;
if (qi::parse(f = F, l, "1 2 " >> qi::int_ >> qi::as_string [ +qi::char_ ], tree))
std::cout << "tree: " << tree << '\n';
}
Salidas:
5 ints parsed
i: 3, s: 4 5
first: 3, second: 4 5
tree: (3 " 4 5")
Unos cuantos ejemplos de analizadores con 'AST' como estructuras de datos:
Si usted quiere tener una estructura AST muy genérico, mira utree
: http://www.boost.org/doc/libs/1_50_0/libs/spirit/doc/html/spirit/support/utree.html
Sin un ejemplo de código que es bastante difícil de responder a su pregunta – sehe
No creo que ninguna pregunta es espíritu una pregunta novato – Spacemoose