2012-07-19 6 views
5

Hola a todos soy nuevo para impulsar y aumentar :: espíritu, así que lo siento por la pregunta de novato.Boost :: Spirit resultado de phrase_parse

Cuando uso la función qi::phrase_parse, la función devuelve solo la variable bool que indica si el análisis ha sido exitoso o no, pero no sé dónde puedo encontrar el resultado del análisis ... algún tipo de árbol de sintaxis, etc.

Si uso macro #define BOOST_SPIRIT_DEBUG La representación XML del árbol se imprime en la salida estándar, pero estos nodos deben almacenarse en algún lugar. ¿Puedes ayudarme por favor?

+1

Sin un ejemplo de código que es bastante difícil de responder a su pregunta – sehe

+0

No creo que ninguna pregunta es espíritu una pregunta novato – Spacemoose

Respuesta

8

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

+1

Se agregaron enlaces a analizadores de muestras con los AST adecuados. ** EDIT ** también incluyó un ejemplo – sehe

Cuestiones relacionadas