X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-psi;a=blobdiff_plain;f=src%2Ftypes%2Fimpl_val.h;h=9b28a7da6374c837c937131d7847577a8c270922;hp=1e6c119f06e61974c2b4d48c76fd1f89c9ccd38f;hb=a7ac1c0a3c855321f21682c127a4b707de33a303;hpb=440ff658995f1378fd74c0101ff6c2b4951ffdf9 diff --git a/src/types/impl_val.h b/src/types/impl_val.h index 1e6c119..9b28a7d 100644 --- a/src/types/impl_val.h +++ b/src/types/impl_val.h @@ -43,6 +43,10 @@ typedef union impl_val { uint32_t u32; int64_t i64; uint64_t u64; +#if HAVE_INT128 + int128_t i128; + uint128_t u128; +#endif float fval; double dval; #ifdef HAVE_LONG_DOUBLE @@ -60,4 +64,68 @@ typedef union impl_val { #endif } impl_val; +#ifndef linux +# define isinfl isinf +# define isnanl isnan +#endif +#if HAVE_LONG_DOUBLE +# define CASE_IMPLVAL_LD_PRINTF(fun, to, ival) \ + case PSI_T_LONG_DOUBLE: \ + if (isinfl(ival.ldval)) { \ + fun(to, "\\INF"); \ + } else if (isnanl(ival.ldval)) { \ + fun(to, "\\NAN"); \ + } else { \ + fun(to, "%" PRIldval "L", ival.ldval); \ + } \ + break; +#else +# define CASE_IMPLVAL_LD_PRINTF(fun, to, ival) +#endif + +#define CASE_IMPLVAL_NUM_PRINTF(fun, to, ival) \ + case PSI_T_INT8: \ + fun(to, "%" PRId8, ival.i8); \ + break; \ + case PSI_T_UINT8: \ + fun(to, "%" PRIu8, ival.u8); \ + break; \ + case PSI_T_INT16: \ + fun(to, "%" PRId16, ival.i16); \ + break; \ + case PSI_T_UINT16: \ + fun(to, "%" PRIu16, ival.u16); \ + break; \ + case PSI_T_INT32: \ + fun(to, "%" PRId32, ival.i32); \ + break; \ + case PSI_T_UINT32: \ + fun(to, "%" PRIu32 "U", ival.u32); \ + break; \ + case PSI_T_INT64: \ + fun(to, "%" PRId64 "L", ival.i64); \ + break; \ + case PSI_T_UINT64: \ + fun(to, "%" PRIu64 "UL", ival.u64); \ + break; \ + case PSI_T_FLOAT: \ + if (isinf(ival.dval)) { \ + fun(to, "\\INF"); \ + } else if (isnan(ival.dval)) { \ + fun(to, "\\NAN"); \ + } else { \ + fun(to, "%" PRIfval "F", ival.dval); \ + } \ + break; \ + case PSI_T_DOUBLE: \ + if (isinf(ival.dval)) { \ + fun(to, "\\INF"); \ + } else if (isnan(ival.dval)) { \ + fun(to, "\\NAN"); \ + } else { \ + fun(to, "%" PRIdval, ival.dval); \ + } \ + break; \ + CASE_IMPLVAL_LD_PRINTF(fun, to, ival) + #endif