First I thought "that's easy", but it did take a few tries to figure out:
#define AA 10
#define BB 20
#define stringify(x) #x
#define FILE2(a, b) stringify(file_ ## a ## _ ## b)
#define FILE(a, b) FILE2(a, b)
#include FILE(AA, BB)
As requested I'll try to explain. FILE(AA, BB)
expands to FILE2(AA, BB)
but then AA
and BB
is expanded before FILE2, so the next expansion is FILE2(10, 20)
which expands to stringify(file_10_20)
which becomes the string.
If you skip FILE2 you'll end up with stringify(file_AA_BB)
which won't work. The C standard actually spends several pages defining how macro expansion is done. In my experience the best way to think is "if there wasn't enough expansion, add another layer of define
"
Only stringily will not work because the # is applied before AA is replaced by 10. That's how you usually want it actually, e.g.:
#define debugint(x) warnx(#x " = %d", x)
debugint(AA);
will print
AA = 10
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…