为了能够在Visual Studio 2015 RC上运行,需要做如下修改

1、修改boost/spirit/home/x3/nonterminal/detail/rule.hpp中的has_on_error和has_on_success的定义为:

 template <typename ID, typename Iterator, typename Context>struct do_has_on_error {template<typename U> static auto test(int) -> decltype(sizeof(declval<U>().on_error(std::declval<Iterator&>(), std::declval<Iterator>(), std::declval<expectation_failure<Iterator>>(), std::declval<Context>())) >= 0, mpl::true_());template<typename> static mpl::false_ test(...);using type = decltype(test<ID>(0));};template <typename ID, typename Iterator, typename Context>using has_on_error = typename do_has_on_error<ID, Iterator, Context>::type;template <typename ID, typename Iterator, typename Attribute, typename Context>struct do_has_on_success {template<typename U> static auto test(int) -> decltype(sizeof(declval<U>().on_success(std::declval<Iterator&>(), std::declval<Iterator>(), std::declval<Attribute&>(), std::declval<Context>())) >= 0, mpl::true_());template<typename> static mpl::false_ test(...);using type = decltype(test<ID>(0));};template<typename ID, typename Iterator, typename Attribute, typename Context>using has_on_success = typename do_has_on_success<ID, Iterator, Attribute, Context>::type;

2、修改boost/spirit/home/x3/nonterminal/rule.hpp中BOOST_SPIRIT_DEFINE_的定义为:

#define BOOST_SPIRIT_DEFINE_(r, data, rule_name)                                \using BOOST_PP_CAT(rule_name, _t) = decltype(rule_name);                    \template <typename Iterator, typename Context, typename Attribute>          \inline bool parse_rule(                                                     \BOOST_PP_CAT(rule_name, _t) rule_                                       \, Iterator& first, Iterator const& last                                   \, Context const& context, Attribute& attr)                                \{                                                                           \using boost::spirit::x3::unused;                                        \static auto const def_ = (rule_name = BOOST_PP_CAT(rule_name, _def));   \return def_.parse(first, last, context, unused, attr);                  \}                                                                           \/***/

接口的区别

phrase_parse 自动跳过空格

parse 不自动跳过空格

定义Rule

1、提供Rule的名称

rule<ID, Attribute> const r = "some-name";

注:ID不需要定义。

2、提供Rule的定义,

auto const r_def = double_ >> *(',' >> double_);

注:必须是“名称_def”的形式。

3、定义parse_rule函数

BOOST_SPIRIT_DEFINE(r);

4、使用r

Spirit x3设计者提供的示例

/*=============================================================================
Copyright (c) 2001-2015 Joel de Guzman
Copyright (c) 2015 Ahmed CharlesDistributed under the Boost Software License, Version 1.0. (See accompanying
file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
=============================================================================*/
///
//
//  A Roman Numerals Parser (demonstrating the symbol table). This is
//  discussed in the "Symbols" chapter in the Spirit User's Guide.
//
//  [ JDG August 22, 2002 ] spirit1
//  [ JDG March 13, 2007 ]  spirit2
//  [ JDG May 13, 2015 ]    spirit X3
//
///#include <boost/config/warning_disable.hpp>
#include <boost/spirit/home/x3.hpp>#include <iostream>
#include <string>namespace client
{namespace x3 = boost::spirit::x3;namespace ascii = boost::spirit::x3::ascii;/////  Parse roman hundreds (100..900) numerals using the symbol table.//  Notice that the data associated with each slot is the parser's attribute//  (which is passed to attached semantic actions).///struct hundreds_ : x3::symbols<unsigned>{hundreds_(){add("C", 100)("CC", 200)("CCC", 300)("CD", 400)("D", 500)("DC", 600)("DCC", 700)("DCCC", 800)("CM", 900);}} hundreds;/////  Parse roman tens (10..90) numerals using the symbol table.///struct tens_ : x3::symbols<unsigned>{tens_(){add("X", 10)("XX", 20)("XXX", 30)("XL", 40)("L", 50)("LX", 60)("LXX", 70)("LXXX", 80)("XC", 90);}} tens;/////  Parse roman ones (1..9) numerals using the symbol table.///struct ones_ : x3::symbols<unsigned>{ones_(){add("I", 1)("II", 2)("III", 3)("IV", 4)("V", 5)("VI", 6)("VII", 7)("VIII", 8)("IX", 9);}} ones;/////  roman (numerals) grammar////      Note the use of the || operator. The expression//      a || b reads match a or b and in sequence. Try//      defining the roman numerals grammar in YACC or//      PCCTS. Spirit rules! :-)///namespace parser{using x3::eps;using x3::lit;using x3::_val;using x3::_attr;using ascii::char_;auto set_zero = [](auto& ctx) { _val(ctx) = 0; };auto add1000 = [](auto& ctx) { _val(ctx) += 1000; };auto add = [](auto& ctx) { _val(ctx) += _attr(ctx); };x3::rule<class roman, unsigned> const roman = "roman";auto const roman_def =eps[set_zero]>>(-(+lit('M')[add1000])>> -hundreds[add]>> -tens[add]>> -ones[add]);BOOST_SPIRIT_DEFINE(roman);}
}///
//  Main program
///
int
main()
{std::cout << "/\n\n";std::cout << "\t\tRoman Numerals Parser\n\n";std::cout << "/\n\n";std::cout << "Type a Roman Numeral ...or [q or Q] to quit\n\n";typedef std::string::const_iterator iterator_type;using client::parser::roman; // Our parserstd::string str;unsigned result;while (std::getline(std::cin, str)){if (str.empty() || str[0] == 'q' || str[0] == 'Q')break;std::string::const_iterator iter = str.begin();std::string::const_iterator end = str.end();bool r = parse(iter, end, roman, result);if (r && iter == end){std::cout << "-------------------------\n";std::cout << "Parsing succeeded\n";std::cout << "result = " << result << std::endl;std::cout << "-------------------------\n";}else{std::string rest(iter, end);std::cout << "-------------------------\n";std::cout << "Parsing failed\n";std::cout << "stopped at: \": " << rest << "\"\n";std::cout << "-------------------------\n";}}std::cout << "Bye... :-) \n\n";return 0;
}

运行截图

Boost.Spirit x3学习笔记相关推荐

  1. boost asio io_service学习笔记

    转自:http://hi.baidu.com/jrckkyy/blog/item/e86835d61e60722506088b6a.html 构造函数 构造函数的主要动作就是调用CreateIoCom ...

  2. Boost Graph Library-BGL学习笔记1

    首先需要说明的是BGL是一个增强STL map的通用类库,这个库是一个仅有header文件的C++库,不需要分开编译.我发现很多文章上来就讲怎么用,其实安装和导入可能会让一些人卡一会儿,做法也比较简单 ...

  3. C/C++ 开发 boost 库参考手册整理(2) 【学习笔记】

    文档声明: 以下资料均属于本人在学习过程中产出的学习笔记,如果错误或者遗漏之处,请多多指正.并且该文档在后期会随着学习的深入不断补充完善.感谢各位的参考查看. 笔记资料仅供学习交流使用,转载请标明出处 ...

  4. 学习笔记: BOOST拓扑

    BOOST 拓扑的应用 学习笔记:https://www.bilibili.com/video/BV1D4411y7V8/ ⭕️ 升压 boost升压电路(boost converter or ste ...

  5. Boost库学习笔记(二)算法模块-C++11标准

    Boost库学习笔记(二)算法模块-C++11标准 一.综述 Boost.Algorithm是一系列人通用推荐算法的集合,虽然有用的通用算法很多,但是为了保证质量和体积,并不会将太多通用算法通过审查测 ...

  6. Boost库学习笔记(一)安装与配置

    Boost库学习笔记(一)安装与配置 1. 获取boost https://www.boost.org/users/history/version_1_79_0.html 任选其一 boost的目录结 ...

  7. GTSAM Tutorial学习笔记

    GTSAM Tutorial学习笔记 GTSAM Tutorial学习笔记 1. 基本原理 2. Demo代码 3. LIO-SAM中部分代码分析 3.1 预积分因子图 3.2 关键帧因子图 GTSA ...

  8. SVO 学习笔记(深度滤波)

    SVO 学习笔记(深度滤波) 这篇博客 论文中的深度滤波 深度滤波的代码流程 更新Seed对象 初始化Seed对象 结尾 这篇博客  这篇博客将介绍SVO论文中的Mapping部分,主要介绍深度滤波器 ...

  9. SVO 学习笔记(三)

    SVO 学习笔记(三) 这篇博客 Initialization Frame_Handler_Mono processFirstFrame processSecondFrame processFrame ...

最新文章

  1. 1057. Stack (30)
  2. 亿级流量治理系列:常用的限流算法有哪些?
  3. python存储numpy数据为文件_numpy.savetxt是否将数组保存到文件中的特定位置?
  4. DbHelperSQL.cs
  5. 计算机文档里的东西可以删吗,电脑c盘哪些文件可以删除
  6. 用自然语言从GitHub搜代码,跳过论坛提问环节,来自Facebook新研究
  7. java actor_Akka笔记之Actor简介
  8. 全球及中国抓紧器行业十四五发展态势及前景规划建议报告2021-2027年版
  9. Java Web项目运行流程
  10. 理解TCP的通信原理及IO阻塞
  11. 完全实战-从零开始配置服务器
  12. python缩进的描述_Python编程思想(2):Python主要特性、命名规则与代码缩进
  13. 8086 MOV 指令的注意事项
  14. 官宣 | 千呼万唤,Apache Flink 1.11.0 正式发布啦!(内含福利)
  15. Android编译tcpdump,android 5.0以上使用tcpdump
  16. 数据仓库和Hadoop大数据平台有什么差别?
  17. java 根据模板,导出word并提供下载
  18. html取消select下拉,jquery取消选择select下拉框
  19. 《理想藏书》书籍推荐
  20. 挣值管理名词(EV、AC、PV等)与公式详解

热门文章

  1. Python小白的数学建模课-A3. 12个新冠疫情数模竞赛赛题与点评
  2. c 递归实现谢宾斯基三角形
  3. NPDP产品经理小知识:知识产权管理
  4. 程序猿生存指南-60 一晌贪欢
  5. html手机页面弹幕效果,H5移动端弹幕动画实现
  6. idea意外退出无法调试,报错:idea unable to open debug port
  7. 分布式GK Summary算法
  8. 编译原理实验报告一:PL0语言编译器分析(PL0,词法分析,语法分析,中间代码生成)
  9. 学习Python,经常见到PEP,那么PEP是什么呢?
  10. Pixie: A System for Recommending 3+ Billion Items to 200+ Million Users in Real-Time简介