预处理器功能宏中的参数转发

时间:2015-06-01 07:52:55

标签: c++11 macros c-preprocessor

是否可以转发参数列表以创建函数声明? 给出了以下伪宏:

#define FUNCTION_DECLARATION(function_name, ...) \
void function_name(__VA_ARGS__) \
{ \
    other_function_but_gets_the_same_params(__VA_ARGS__); \
}

我想使用类似于以下语法的东西创建一个函数声明:

FUNCTION_DECLARATION(MyFunction, char, char, int)

1 个答案:

答案 0 :(得分:2)

嗯,你提出这个问题很有意思,因为我上周完成了这个工作。

以下是您感兴趣的内容。使用Boost.Preprocessor。

#define STRIP_PARENS(...)   __VA_ARGS__

#define PARAM_PROTO(i, elem)                                            \
    STRIP_PARENS elem _ ## i

#define PARAM_FWD(i, elem)                                              \
    std::forward<STRIP_PARENS elem>(_ ## i)

#define MAKE_PARAM(r, macro, i, elem)                                   \
    STRIP_PARENS BOOST_PP_IF(                                           \
        BOOST_PP_IS_EMPTY(STRIP_PARENS elem),                           \
        (),                                                             \
        (BOOST_PP_COMMA_IF(i) macro(i, elem))                           \
    )

#define MAKE_PARAM_LIST(params, macro)                                  \
    BOOST_PP_SEQ_FOR_EACH_I(MAKE_PARAM, macro, params)

#define FUNCTION_DECLARATION(function_name, params)                     \
    void function_name(MAKE_PARAM_LIST(params, PARAM_PROTO)) {          \
        other_function(MAKE_PARAM_LIST(params, PARAM_FWD));             \
    }

使用如下:

FUNCTION_DECLARATION(myFunction, ((int))((float))((std::string&)))

// Expands to :
void myFunction(int _0, float _1, std::string& _2) {
    other_function(
        std::forward<int>(_0),
        std::forward<float>(_1),
        std::forward<std::string&>(_2)
    );
}

仅供参考,奇怪的参数列表是为了处理包含逗号的类型(例如std::array<int, 4>)。双括号是因为BOOST_PP_SEQ_SIZE也会在逗号上跳过,更深一层......

相关问题