2
3
4
5
6
7
8
10#ifndef GIMBAL_MACRO_UTILS_H
11#define GIMBAL_MACRO_UTILS_H
15#include <gimbal/core/gimbal_config.h>
23#define GBL_MIN(a, b) (((a) < (b))? (a) : (b))
24#define GBL_MAX(a, b) (((a) > (b))? (a) : (b))
25#define GBL_CEIL(numerator, denominator) ((numerator / denominator + (numerator % denominator != 0
)))
26#define GBL_CLAMP(n, min, max) (((n) > (max)) ? (max) : (((n) < (min)) ? (min) : (n)))
28#define GBL_BIT_MASK_2(bits, offset) (((1u
<< bits) - 1u
) << offset)
32#define GBL_BCD_BYTE_PACK(n) (((n / 10
) << 4
) | (n % 10
))
33#define GBL_BCD_BYTE_UNPACK(n) (unsigned)(((n >> 4
) * 10
) + (n & 0xf
))
35#define GBL_CONTAINER_OF(ptr, type, member) ((type*)((char*)(ptr) - offsetof
(type, member)))
36#define GBL_COUNT_OF(array) (sizeof(array) / sizeof(array[0
]))
39#define GBL_PTR_OFFSET_3(type, ptr, bytes) ((type)(((uintptr_t)ptr) + bytes))
42#define GBL_SWITCH_CASE_STRINGIFY(s) case s: return #s
44#define GBL_LABEL_EMPTY(name) name: {;}
48 unsigned char swap_temp[sizeof(x) == sizeof(y) ?
49 (signed)sizeof(x) : -1
];
50 memcpy(swap_temp, &y, sizeof(x));
51 memcpy(&y, &x, sizeof(x));
52 memcpy(&x, swap_temp, sizeof(x));
55#define GBL_ASSERT(...)
59#define GBL_BIT_FIELDS(...)
60 GBL_TUPLE_FOREACH(GBL_BIT_FIELDS_ENTRY_
, GBL_PHONY, GBL_BIT_FIELDS_ENDIAN_XFORM_
(__VA_ARGS__))
63# define GBL_META_GENERIC_MACRO_GENERATE(traits, X)
65 GBL_MAP_TUPLES(GBL_META_GENERIC_MACRO_TRAIT_OVERLOADS_DECLARE_CASE_C_,
66 GBL_MAP_TUPLES(GBL_EVAL, GBL_META_GENERIC_MACRO_TRAIT_PROPERTY_OVERLOADS_ traits))
67 default: GBL_EVAL(GBL_META_GENERIC_MACRO_TRAIT_PROPERTY_DEFAULT traits)
70# define GBL_META_GENERIC_MACRO_GENERATE(traits, X)
72 using GenericType = decltype(X);
74 GBL_MAP_TUPLES(GBL_META_GENERIC_MACRO_TRAIT_OVERLOADS_DECLARE_CASE_CPP_
,
76 else if constexpr(requires { GBL_EVAL(GBL_META_GENERIC_MACRO_TRAIT_PROPERTY_DEFAULT_ traits)
77 (std::forward<decltype(args)>(args)...); })
78 return GBL_EVAL(GBL_META_GENERIC_MACRO_TRAIT_PROPERTY_DEFAULT_ traits)(std::forward<decltype(args)>(args)...);
82#define GBL_META_GENERIC_MACRO_TRAIT_PROPERTY_DEFAULT(defaultFunc, overloads) defaultFunc
83#define GBL_META_GENERIC_MACRO_NO_DEFAULT GBL_NULL
87#define GBL_BIT_FIELDS_ENTRY_(a, b) b;
90# define GBL_BIT_FIELDS_ENDIAN_XFORM_(...) (__VA_ARGS__)
92# define GBL_BIT_FIELDS_ENDIAN_XFORM_(...) (GBL_REVERSE(__VA_ARGS__))
95#define GBL_META_GENERIC_MACRO_TRAIT_PROPERTY_OVERLOADS_(defaultFunc, overloads) overloads
96#define GBL_META_GENERIC_MACRO_TRAIT_OVERLOADS_PROPERTY_TYPE_(type, function) type
97#define GBL_META_GENERIC_MACRO_TRAIT_OVERLOADS_PROPERTY_FUNCTION_(type, function) function
99#define GBL_META_GENERIC_MACRO_TRAIT_OVERLOADS_DECLARE_CASE_C_(type, function)
102#define GBL_META_GENERIC_MACRO_TRAIT_OVERLOADS_DECLARE_CASE_CPP_(type, function)
103 else if constexpr(std::same_as<GenericType, type>) return function(std::forward<decltype(args)>(args)...);
110#define GBL_SCOPE_EXIT continue
#define GBL_VA_OVERLOAD_SELECT(BASE, SUFFIXER,...)
#define GBL_TUPLE_FOREACH(MACRO_, DATA_, TUPLE_)
#define GBL_VA_OVERLOAD_SUFFIXER_ARGC(...)
#define GBL_VA_OVERLOAD_CALL_ARGC(BASE,...)
#define GBL_MAP_TUPLES(f,...)
#define GBL_PTR_OFFSET(...)
#define GBL_BIT_MASK_2(bits, offset)
#define GBL_BIT_MASK(...)
#define GBL_APPEND_LINE(a)
#define GBL_PTR_OFFSET_3(type, ptr, bytes)