3 #define reinterpret_cast(T, it) _unsafe_cast_##T(0, it)
5 T _unsafe_cast_##T(int dummy, ...) { return ...(0, T); } \
6 USING(T##_fld, .T); T##_fld _unsafe_cast_##T##_fld(int dummy, ...) { return ...(0, T##_fld); }
13 USING(rawfunc, float(...));
17 #define _strid(s) ITOF(reinterpret_cast(int, s))
18 #define strid(s) stof(sprintf("%i", s))
20 .int _unsafe_fld1, _unsafe_fld2;
23 #define FTOI(f) ((f) * INTEGER_ONE)
24 #define ITOF(i) ((i) / INTEGER_ONE)
26 STATIC_INIT(INTEGER_ONE)
28 INTEGER_ONE = reinterpret_cast(int, _unsafe_fld2) - reinterpret_cast(int, _unsafe_fld1);
31 #define ARRAY_INDEX(T, arr, idx) (reinterpret_cast(T##_fld, reinterpret_cast(int, arr[0]) + FTOI(idx)))