在指向另一个宏的可变参数宏中为每个参数添加前缀
Prefix each parameter in a variadic macro that points to another macro
假设我有这些以ATTRIB_
为前缀的宏
#define ATTRIB_A "a"
#define ATTRIB_B "b"
#define ATTRIB_C "c"
我希望能够使用一个可变参数宏来解压缩每个给定参数,然后以ATTRIB_
为前缀以获取属性宏的全名,以便扩展该宏:
#define ATTRIBS(...) CONFUSED_HERE(##__VA_ARGS__)
这将用作:
const char * a = ATTRIBS(A, B, C);
结果将等于:
const char * a = "a" "b" "c";
好像像这样使用(除了更短(:
ATTRIBS(ATTRIB_A, ATTRIB_B, ATTRIB_C);
请注意,这不是此宏的实际用途。我很好奇如何将前缀应用于可变参数宏的每个参数以访问/扩展另一个宏。
我不关心可移植性,只要它适用于最近的 MinGW/GCC 编译器。万一它们带有一些我不知道的扩展名。
from foreach-macro-on-macros-arguments
#define PP_NARG(...) PP_NARG_(__VA_ARGS__,PP_RSEQ_N())
#define PP_NARG_(...) PP_ARG_N(__VA_ARGS__)
#define PP_ARG_N(
_1, _2, _3, _4, _5, _6, _7, _8, _9,_10,
_11,_12,_13,_14,_15,_16,_17,_18,_19,_20,
_21,_22,_23,_24,_25,_26,_27,_28,_29,_30,
_31,_32,_33,_34,_35,_36,_37,_38,_39,_40,
_41,_42,_43,_44,_45,_46,_47,_48,_49,_50,
_51,_52,_53,_54,_55,_56,_57,_58,_59,_60,
_61,_62,_63,N,...) N
#define PP_RSEQ_N()
63,62,61,60,
59,58,57,56,55,54,53,52,51,50,
49,48,47,46,45,44,43,42,41,40,
39,38,37,36,35,34,33,32,31,30,
29,28,27,26,25,24,23,22,21,20,
19,18,17,16,15,14,13,12,11,10,
9,8,7,6,5,4,3,2,1,0
/* need extra level to force extra eval */
#define Paste(a,b) a ## b
#define XPASTE(a,b) Paste(a,b)
/* APPLYXn variadic X-Macro by M Joshua Ryan */
/* Free for all uses. Don't be a jerk. */
/* I got bored after typing 15 of these. */
/* You could keep going upto 64 (PPNARG's limit). */
#define APPLYX1(a) X(a)
#define APPLYX2(a,b) X(a) X(b)
#define APPLYX3(a,b,c) X(a) X(b) X(c)
#define APPLYX4(a,b,c,d) X(a) X(b) X(c) X(d)
#define APPLYX5(a,b,c,d,e) X(a) X(b) X(c) X(d) X(e)
#define APPLYX6(a,b,c,d,e,f) X(a) X(b) X(c) X(d) X(e) X(f)
#define APPLYX7(a,b,c,d,e,f,g)
X(a) X(b) X(c) X(d) X(e) X(f) X(g)
#define APPLYX8(a,b,c,d,e,f,g,h)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h)
#define APPLYX9(a,b,c,d,e,f,g,h,i)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h) X(i)
#define APPLYX10(a,b,c,d,e,f,g,h,i,j)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h) X(i) X(j)
#define APPLYX11(a,b,c,d,e,f,g,h,i,j,k)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h) X(i) X(j) X(k)
#define APPLYX12(a,b,c,d,e,f,g,h,i,j,k,l)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h) X(i) X(j) X(k) X(l)
#define APPLYX13(a,b,c,d,e,f,g,h,i,j,k,l,m)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h) X(i) X(j) X(k) X(l) X(m)
#define APPLYX14(a,b,c,d,e,f,g,h,i,j,k,l,m,n)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h) X(i) X(j) X(k) X(l) X(m) X(n)
#define APPLYX15(a,b,c,d,e,f,g,h,i,j,k,l,m,n,o)
X(a) X(b) X(c) X(d) X(e) X(f) X(g) X(h) X(i) X(j) X(k) X(l) X(m) X(n) X(o)
#define APPLYX_(M, ...) M(__VA_ARGS__)
#define APPLYXn(...) APPLYX_(XPASTE(APPLYX, PP_NARG(__VA_ARGS__)), __VA_ARGS__)
#define ATTRIB_A "a"
#define ATTRIB_B "b"
#define ATTRIB_C "c"
#define X(a) XPASTE(ATTRIB_, a)
#define ATTRIBS(...) APPLYXn(__VA_ARGS__)
int main()
{
const char * a = ATTRIBS(A, B, C);
std::cout << a << std::endl;
}
演示
相关文章:
- 空函数的参数是否加载到缓存中?
- 如何动态加载和调用具有特定于库的类型作为函数参数的符号
- 加载器,设置带有参数的源
- 如何在ROS中高效加载大量参数
- Qml:从文件加载组件时将参数作为 URL 的一部分传递
- Java:加载带有char **的C DLL,将回调作为参数
- C 深度首次使用前缀参数对Trie进行了搜索
- 在指向另一个宏的可变参数宏中为每个参数添加前缀
- 在什么基础上,由单个元素组成的参数包的折叠表达式被转换为未加括号的表达式
- 为什么后缀失败并且前缀在传递迭代器作为参数并在尾部位置递归时工作正常
- 土壤图像加载库参数
- 将二进制文件加载到eigen矩阵中时,请删除潜在的冗余模板参数
- C++:将模板参数的模板类型成员加为好友的语法正确吗
- 如何将参数传递给从 CPP 中的静态库加载的方法
- 将变参数包中的值加载到临时数组中
- 硬编码参数与从文件加载
- 如果模板化"ResourceCache"需要不同的创建参数/方法,它们如何加载/创建 T 类型的资源?
- C++ Boost::序列化"no matching function for call"到我的加载函数参数中类的构造函数
- 在C++命名空间中,当在头中声明的非成员子例程前面加前缀时,“static”限定符是否有任何作用
- 在源文件中指定include前缀与在编译器的搜索路径参数中指定include前缀的优缺点是什么