2011-10-04 89 views
2

我想編寫一個boost::spirit解析器,該解析器在使用雙引號的雙引號中解析簡單字符串,例如, "a \"b\" c"使用Boost :: Spirit解析轉義字符串:: Spirit

這裏是我的嘗試:

#include <boost/config/warning_disable.hpp> 
#include <boost/spirit/include/qi.hpp> 

#include <iostream> 
#include <string> 

namespace client 
{ 
    namespace qi = boost::spirit::qi; 
    namespace ascii = boost::spirit::ascii; 

    template <typename Iterator> 
    bool parse(Iterator first, Iterator last) 
    { 
    using qi::char_; 

    qi::rule< Iterator, std::string(), ascii::space_type > text; 
    qi::rule< Iterator, std::string() > content; 
    qi::rule< Iterator, char() > escChar; 

    text = '"' >> content >> '"'; 
    content = +(~char_('"') | escChar); 
    escChar = '\\' >> char_("\""); 

    bool r = qi::phrase_parse(first, last, text, ascii::space); 
    if (first != last) // fail if we did not get a full match 
     return false; 
    return r; 
    } 
} 

int main() { 
    std::string str = "\"a \\\"b\\\" c\""; 
    if (client::parse(str.begin(), str.end())) 
    std::cout << str << " Parses OK: " << std::endl; 
    else 
    std::cout << "Fail\n"; 
    return 0; 
} 

它遵循上Parsing escaped strings with boost spirit的例子,但輸出爲「失敗」。我怎樣才能使它工作?

回答

2

過了一段時間,因爲我在精神上走了一步,但我認爲你的一條規則是錯誤的。

嘗試:

content = +(escChar | ~char_('"')) 

代替:

content = +(~char_('"') | escChar) 

它使用~char('"')符合\,因此從來輪到達如果escChar匹配檢查。然後它讀取下一個"作爲字符串的結尾並停止解析。

+0

如何修改此語法以便捕獲\? – Addy