如何解决如何将BOOST_PP_CAT两次应用于较短的C ++重复代码?
true { return yy::parser::make_T_TRUE(yy::parser::token::T_TRUE,yy::location()); }
false { return yy::parser::make_T_FALSE(yy::parser::token::T_FALSE,yy::location()); }
try { return yy::parser::make_T_TRY(yy::parser::token::T_TRY,yy::location()); }
catch { return yy::parser::make_T_CATCH(yy::parser::token::T_CATCH,yy::location()); }
finally { return yy::parser::make_T_FINALLY(yy::parser::token::T_FINALLY,yy::location()); }
如果我有这样的宏,则可以看到:
#define MAKE(t) return yy::parser::make_ ## t (yy::parser::token:: ## t,yy::location())
然后我可以编写更少的重复代码,生活会更轻松:
true { MAKE(T_TRUE); }
false { MAKE(T_FALSE); }
try { MAKE(T_TRY); }
catch { MAKE(T_CATCH); }
finally { MAKE(T_FINALLY); }
但是##
或BOOST_PP_CAT
不能在一行中被两次调用,第二个扩展将无法工作。
有什么办法解决这个问题吗?
解决方法
仅在创建新标识符 make_t 的第一位需要##
。其次,使用不带有##
的 t ,因为::
可以将 t 与宏中的其他标记区分开。
#define MAKE(t) return yy::parser::make_ ## t (yy::parser::token::t,yy::location())
true { MAKE(T_TRUE); }
false { MAKE(T_FALSE); }
try { MAKE(T_TRY); }
catch { MAKE(T_CATCH); }
finally { MAKE(T_FINALLY); }
通过g++ -E test.cpp
调用预处理得到
true { return yy::parser::make_T_TRUE (yy::parser::token::T_TRUE,yy::location()); }
false { return yy::parser::make_T_FALSE (yy::parser::token::T_FALSE,yy::location()); }
try { return yy::parser::make_T_TRY (yy::parser::token::T_TRY,yy::location()); }
catch { return yy::parser::make_T_CATCH (yy::parser::token::T_CATCH,yy::location()); }
finally { return yy::parser::make_T_FINALLY (yy::parser::token::T_FINALLY,yy::location()); }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。