basic: better readable IN_SET macro
Putting the set elements in an array variable and using ELEMENTSOF makes it clearer what's going on. Incidentally, it also makes gcc -O2 generate slightly smaller code: "size systemd", before: text data bss dec hex filename 1378318 128608 2632 1509558 1708b6 systemd After: text data bss dec hex filename 1377286 128608 2632 1508526 1704ae systemd
This commit is contained in:
parent
bd37a92297
commit
249a2737ba
|
@ -406,12 +406,12 @@ do { \
|
|||
|
||||
#define IN_SET(x, y, ...) \
|
||||
({ \
|
||||
const typeof(y) _y = (y); \
|
||||
const typeof(_y) _x = (x); \
|
||||
const typeof(y) _array[] = { (y), __VA_ARGS__ }; \
|
||||
const typeof(y) _x = (x); \
|
||||
unsigned _i; \
|
||||
bool _found = false; \
|
||||
for (_i = 0; _i < 1 + sizeof((const typeof(_x)[]) { __VA_ARGS__ })/sizeof(const typeof(_x)); _i++) \
|
||||
if (((const typeof(_x)[]) { _y, __VA_ARGS__ })[_i] == _x) { \
|
||||
for (_i = 0; _i < ELEMENTSOF(_array); _i++) \
|
||||
if (_array[_i] == _x) { \
|
||||
_found = true; \
|
||||
break; \
|
||||
} \
|
||||
|
|
Loading…
Reference in a new issue