我不知道是否有类似的问题。
如何简化
(a == 78 || a == 98 || a == 73 || a == 11 || a == 90 || a==103 || a==45 )
表达到
MY_CHECK(a, (78, 98, 73, 11, 90, 103, 45) )
使用boost预处理器??
在boost预处理器中是否有任何现成的解决方案。
答案 0 :(得分:0)
答案 1 :(得分:0)
由于BOOST_PP_SEQ_FOLD_LEFT
周围没有data
参数,因此我找不到转换后跟折叠的效果。仍然:
#define MY_CHECK_FOLD_OR(s, a, b) a || b
#define MY_CHECK_FOLD_EQ(s, var, elem) (var) == (elem)
#define MY_CHECK(var, values) \
(BOOST_PP_SEQ_FOLD_LEFT( \
MY_CHECK_FOLD_OR, false, \
BOOST_PP_SEQ_TRANSFORM( \
MY_CHECK_FOLD_EQ, var, \
BOOST_PP_TUPLE_TO_SEQ(values) \
) \
))
...扩展了:
if (MY_CHECK(a, (1, 2, 3)))
...进入:
if ((false || (a) == (1) || (a) == (2) || (a) == (3)))