aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDenis Kenzior <denkenz@gmail.com>2024-04-12 10:54:54 -0500
committerDenis Kenzior <denkenz@gmail.com>2024-04-16 14:06:53 -0500
commitb995e0f3b990e91b2ec57134d3ce66cf9511e9a0 (patch)
tree1996f7db73d28fcd046a328b64a1f83f2998bbd1
parentd8eaabc0c346a93543ba51f9ee6d5e8dd37ac5de (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.h4
1 files changed, 2 insertions, 2 deletions
diff --git a/ell/util.h b/ell/util.h
index 80b29b7b..a829bceb 100644
--- a/ell/util.h
+++ b/ell/util.h
@@ -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); \