35# if __STDC_VERSION__ < 202000
36# define static_assert _Static_assert
49#ifdef __clang_analyzer__
50#define STATIC_ANALYZER 1
53#define STATIC_ANALYZER 1
62# define WITH_VERIFY_PTR 1
69#ifndef __SANITIZE_ADDRESS__
71#if __has_feature(address_sanitizer)
72#define __SANITIZE_ADDRESS__ (1)
93#if (defined(__EMSCRIPTEN__) && defined(__EMSCRIPTEN_PTHREADS__)) || !defined(__EMSCRIPTEN__) && defined(HAVE_PTHREAD_H)
94# define HAVE_PTHREADS 1
105#define CMP_PREFER_SMALLER(_a,_b) (((_a) > (_b)) - ((_a) < (_b)))
109#define CMP_PREFER_LARGER(_a,_b) (((_a) < (_b)) - ((_a) > (_b)))
113#define CMP(_a, _b) CMP_PREFER_SMALLER(_a, _b)
122#define CMP_RETURN(_a, _b, _field) \
124 int8_t _ret = CMP((_a)->_field, (_b)->_field); \
125 if (_ret != 0) return _ret; \
139static inline int8_t
memcmp_return(
void const *a,
void const *b,
size_t a_len,
size_t b_len)
144 if (!a_len && b_len)
return -1;
145 if (a_len && !b_len)
return +1;
146 if (!a_len && !b_len)
return 0;
148 cmp_len = (a_len < b_len) ? a_len : b_len;
150 ret =
CMP(memcmp(a, b, cmp_len), 0);
151 if (ret != 0)
return ret;
153 return CMP(a_len, b_len);
164#define MEMCMP_RETURN(_a, _b, _field, _len_field) \
166 int8_t _ret = memcmp_return((_a)->_field, (_b)->_field, (_a)->_len_field, (_b)->_len_field); \
167 if (_ret != 0) return _ret; \
178#define MEMCMP_FIELDS(_a, _b, _field, _len_field) \
179 memcmp_return((_a)->_field, (_b)->_field, (_a)->_len_field, (_b)->_len_field)
186#define UNCONST(_type, _ptr) ((_type)((uintptr_t)(_ptr)))
193#define typeof_field(_type, _field) __typeof__(((_type *)NULL)->_field)
199# define XHEXIFY4(b1,b2,b3,b4) (0x ## b1 ## b2 ## b3 ## b4)
200# define HEXIFY4(b1,b2,b3,b4) XHEXIFY4(b1, b2, b3, b4)
202# define XHEXIFY3(b1,b2,b3) (0x ## b1 ## b2 ## b3)
203# define HEXIFY3(b1,b2,b3) XHEXIFY3(b1, b2, b3)
205# define XHEXIFY2(b1,b2) (0x ## b1 ## b2)
206# define HEXIFY2(b1,b2) XHEXIFY2(b1, b2)
208# define XHEXIFY(b1) (0x ## b1)
209# define HEXIFY(b1) XHEXIFY(b1)
215#define XSTRINGIFY(x) #x
216#define STRINGIFY(x) XSTRINGIFY(x)
217#define JOINSTR(x,y) XSTRINGIFY(x ## y)
223#define _JOIN(x,y) x ## y
224#define JOIN(x,y) _JOIN(x,y)
228#define L(_str) { _str, sizeof(_str) - 1 }
232#define F1(_idx, _val) [_idx] = _val
233#define F2(_idx, _val) F1(_idx, _val), F1(_idx + 1, _val)
234#define F4(_idx, _val) F2(_idx, _val), F2(_idx + 2, _val)
235#define F8(_idx, _val) F4(_idx, _val), F4(_idx + 4, _val)
236#define F16(_idx, _val) F8(_idx, _val), F8(_idx + 8, _val)
237#define F32(_idx, _val) F16(_idx, _val), F16(_idx + 16, _val)
238#define F64(_idx, _val) F32(_idx, _val), F32(_idx + 32, _val)
239#define F128(_idx, _val) F64(_idx, _val), F64(_idx + 64, _val)
240#define F256(_idx, _val) F128(_idx, _val), F128(_idx + 128, _val)
252 _1, _2, _3, _4, _5, _6, _7, _8, _9,_10, \
253 _11,_12,_13,_14,_15,_16,_17,_18,_19,_20, \
254 _21,_22,_23,_24,_25,_26,_27,_28,_29,_30, \
255 _31,_32,_33,_34,_35,_36,_37,_38,_39,_40, \
256 _41,_42,_43,_44,_45,_46,_47,_48,_49,_50, \
257 _51,_52,_53,_54,_55,_56,_57,_58,_59,_60, \
262 59,58,57,56,55,54,53,52,51,50, \
263 49,48,47,46,45,44,43,42,41,40, \
264 39,38,37,36,35,34,33,32,31,30, \
265 29,28,27,26,25,24,23,22,21,20, \
266 19,18,17,16,15,14,13,12,11,10, \
269#define _VA_NARG(...) VA_ARG_N(__VA_ARGS__)
275#define VA_NARG(...) _VA_NARG(__VA_ARGS__, VA_RSEQ_N())
282# define NDEBUG_LOCATION_ARGS char const *file, int line,
283# define NDEBUG_LOCATION_VALS file, line,
284# define NDEBUG_LOCATION_FMT "%s[%d]: "
285# define NDEBUG_LOCATION_EXP __FILE__, __LINE__,
286# define NDEBUG_LOCATION_NONNULL(_num) ((_num) + 2)
288# define NDEBUG_LOCATION_ARGS
289# define NDEBUG_LOCATION_VALS
290# define NDEBUG_LOCATION_FMT ""
291# define NDEBUG_LOCATION_EXP
292# define NDEBUG_LOCATION_NONNULL(_num) (_num)
300#define IS_CONST(_type, _var) \
316#define IS_TYPE(_type, _var) \
324#define UNUSED_VAR(_x) ((void)_x)
329#define PAD(_x, _y) (_y - ((_x) % _y))
334#define NEVER_RETURNS _Noreturn
335#define HIDDEN CC_HINT(visibility("hidden"))
336#define UNUSED CC_HINT(unused)
340#if (defined(__clang__) && (__clang_major__ >= 10)) || (defined(__GNUC__) && __GNUC__ >= 7)
341# define FALL_THROUGH CC_HINT(fallthrough)
343# define FALL_THROUGH ((void)0)
347# define NDEBUG_UNUSED
349# define NDEBUG_UNUSED UNUSED
352#define BLANK_FORMAT " "
357#define SIZEOF_MEMBER(_t, _m) sizeof(((_t *)0)->_m)
358#define NUM_ELEMENTS(_t) (sizeof((_t)) / sizeof((_t)[0]))
365#define NUM_PTR_ELEMENTS(_t) (sizeof((_t)) / sizeof(void *))
378#define IS_COMPATIBLE(_x, _t) _Generic(_x, _t:1, default: 0)
388#define IS_FIELD_COMPATIBLE(_s, _f, _t) _Generic(((_s *)0)->_f, _t:1, default: 0)
395# define CC_HINT(...) __attribute__((__VA_ARGS__))
396# define likely(_x) __builtin_expect((_x), 1)
397# define unlikely(_x) __builtin_expect((_x), 0)
398# define unpredictable(_x) __builtin_unpredictable((_x))
401# define likely(_x) _x
402# define unlikely(_x) _x
403# define unpredictable(_x) _x
410 #ifndef __GNUC_PREREQ__
411 #define __GNUC_PREREQ__(x, y) \
412 ((__GNUC__ == (x) && __GNUC_MINOR__ >= (y)) || \
416 #define __GNUC_PREREQ__(x, y) 0
423#define PRAGMA(_x) _Pragma(#_x)
428#if defined(__clang__) && (__clang_major__ >= 13)
429# define CC_ACQUIRE_HANDLE(_tag) CC_HINT(acquire_handle(_tag))
430# define CC_USE_HANDLE(_tag) CC_HINT(use_handle(_tag))
431# define CC_RELEASE_HANDLE(_tag) CC_HINT(release_handle(_tag))
433# define CC_ACQUIRE_HANDLE(_tag)
434# define CC_USE_HANDLE(_tag)
435# define CC_RELEASE_HANDLE(_tag)
442# define __has_feature(_x) 0
444#if defined(__clang__) && __has_feature(undefined_behavior_sanitizer)
445# define CC_NO_UBSAN(_sanitize) __attribute__((no_sanitize(STRINGIFY(_sanitize))))
446#elif __GNUC_PREREQ__(4, 9) && defined(__SANITIZE_UNDEFINED__)
447# define CC_NO_UBSAN(_sanitize) __attribute__((no_sanitize_undefined))
449# define CC_NO_UBSAN(_sanitize)
455#if defined(__clang__)
456# define CC_NO_SANITIZE_UNDEFINED(_what) CC_HINT(no_sanitize(_what))
458# define CC_NO_SANITIZE_UNDEFINED(_what)
464#if defined(__clang__) && ((__clang_major__ * 100) + __clang_minor__ >= 208)
465# define DIAG_UNKNOWN_PRAGMAS unknown-pragmas
466# define DIAG_PRAGMA(_x) PRAGMA(clang diagnostic _x)
467# define DIAG_OFF(_x) DIAG_PRAGMA(ignored JOINSTR(-W,_x))
468# define DIAG_ON(_x) DIAG_PRAGMA(warning JOINSTR(-W,_x))
469# define DIAG_PUSH() DIAG_PRAGMA(push)
470# define DIAG_POP() DIAG_PRAGMA(pop)
471#elif !defined(__clang__) && defined(__GNUC__) && ((__GNUC__ * 100) + __GNUC_MINOR__) >= 402
472# define DIAG_UNKNOWN_PRAGMAS pragmas
473# define DIAG_PRAGMA(_x) PRAGMA(GCC diagnostic _x)
474# define DIAG_OFF(_x) DIAG_PRAGMA(ignored JOINSTR(-W,_x))
475# define DIAG_ON(_x) DIAG_PRAGMA(warning JOINSTR(-W,_x))
476# define DIAG_PUSH() DIAG_PRAGMA(push)
477# define DIAG_POP() DIAG_PRAGMA(pop)
479# define DIAG_UNKNOWN_PRAGMAS
490# define USES_APPLE_DEPRECATED_API DIAG_OFF(deprecated-declarations)
491# define USES_APPLE_RST DIAG_ON(deprecated-declarations)
493# define USES_APPLE_DEPRECATED_API
494# define USES_APPLE_RST
499# define RCSID(id) static char const rcsid[] __attribute__ ((used)) = id;
500# define RCSIDH(h, id) static char const rcsid_ ## h [] __attribute__ ((used)) = id;
501#elif defined(__SUNPRO_C)
503# define RCSID(id) PRAGMA(sun ident id)
504# define RCSIDH(h, id) PRAGMA(sun ident id)
507# define RCSIDH(h, id)
530#define IGNORE(_expr, _type) \
532 _type ignored UNUSED = (_expr); \
540#define strncpy(_dst, _src, _len) dont_use_strncpy()
static int8_t memcmp_return(void const *a, void const *b, size_t a_len, size_t b_len)
memcmp function which has similar behaviour as strncmp
char * dont_use_strncpy(char *dst, char const *src, size_t len)
Force a compilation error if strncpy() is used.
#define CMP(_a, _b)
Same as CMP_PREFER_SMALLER use when you don't really care about ordering, you just want an ordering.