diff options
author | Denis Kenzior <denkenz@gmail.com> | 2024-04-12 10:54:54 -0500 |
---|---|---|
committer | Denis Kenzior <denkenz@gmail.com> | 2024-04-16 14:06:53 -0500 |
commit | b995e0f3b990e91b2ec57134d3ce66cf9511e9a0 (patch) | |
tree | 1996f7db73d28fcd046a328b64a1f83f2998bbd1 | |
parent | d8eaabc0c346a93543ba51f9ee6d5e8dd37ac5de (diff) |
util: Remove confusing static keyword use
'__n' is declared as static const which is confusing since it
would imply that __n is only initialized once. This works out in the
end since the macro used in a separate anonymous block, but some compilers
(i.e. clang) will generate a symbol table entry for '__n'. This is not
needed since the expression is always constant.
Declare '__n' as a const size_t instead since that is the type produced
by the sizeof() operation used by L_ARRAY_SIZE.
While here, also declare '__i' as size_t to match '__n'.
Fixes: 4a9f6388dd7f ("util: Add L_IN_SET macros")
-rw-r--r-- | ell/util.h | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -349,8 +349,8 @@ inline __attribute__((always_inline)) void _l_close_cleanup(void *p) #define _L_IN_SET_CMP(val, type, cmp, ...) __extension__ ({ \ const type __v = (val); \ const typeof(__v) __elems[] = {__VA_ARGS__}; \ - unsigned int __i; \ - static const unsigned int __n = L_ARRAY_SIZE(__elems); \ + size_t __i; \ + const size_t __n = L_ARRAY_SIZE(__elems); \ bool __r = false; \ for (__i = 0; __i < __n && !__r; __i++) \ __r = (cmp); \ |