boost :: spirit :: qi和无序变量

Log*_*nit 6 c++ boost boost-spirit boost-spirit-qi

我正在写一个lexigraphical分析器.它需要一个英文字符串,并将其转换为一组纬度/经度坐标.这有点像谷歌地球.

无论如何,我已经编写了符号表和语法,并且很高兴解析格式化数据.

struct LatLongDegrees
{
 std::string  dirLat_;
 double   degLat_;
 std::string     dirLong_;
 double   degLong_;
}
Run Code Online (Sandbox Code Playgroud)

例如:{"North",23.59,"East", - 30.82}

这是我的语法:

 basic =(latitude >> ' ' >> double_ >> ' ' >> longitude >> ' ' >> double_);
Run Code Online (Sandbox Code Playgroud)

纬度和经度是从速记罗盘方向到字符串(例如"e"到"东")的符号表

所以,关于我的问题:

我想在我的语法中添加以下规则,其中纬度和经度符号位于相反的位置:

reversed = (longitude  >> ' ' >> double_ >> ' ' >> latitude >> double_ )
Run Code Online (Sandbox Code Playgroud)

这解析,但是degLat_和degLong_值不会与字符串值一起反转.它们只是直接解析到结构中,而不考虑字符串标签.

当要解析的数据不是连续的时,如何构建struct(或boost :: fusion向量)?

hka*_*ser 6

你有几种可能性.最简单的方法是按所需顺序将您的结构调整为Fusion序列:

BOOST_FUSION_ADAPT_STRUCT(
    LatLongDegrees,
    (std::string, dirLong_)
    (double, degLong_)
    (std::string, dirLat_)
    (double, degLat_)
);
Run Code Online (Sandbox Code Playgroud)

(是的,适应的顺序不必与原始结构中成员的顺序相匹配,您甚至可以省略成员或复制它们).如果您有一个特定的订单要解析您的成员,这样可以正常工作.

如果在同一程序中需要不同的顺序,您可能希望使用类似的自适应机制,但另外允许为自适应结构命名:

BOOST_FUSION_ADAPT_STRUCT_NAME(
    LatLongDegrees, reversed_LatLongDegrees,
    (std::string, dirLong_)
    (double, degLong_)
    (std::string, dirLat_)
    (double, degLat_)
);
Run Code Online (Sandbox Code Playgroud)

reversed_LatLongDegreesSpirit语法中用作属性的数据类型在哪里:

rule <Iterator, reversed_LatLongDegrees()> reversed;
reversed = longitude  >> ' ' >> double_ >> ' ' >> latitude >> double_;

LatLongDegrees data;
parse(begin, end, reversed, data);
Run Code Online (Sandbox Code Playgroud)

这允许同时为同一结构创建多个适配.