From: Damjan Marion Date: Fri, 29 Sep 2023 12:31:08 +0000 (+0200) Subject: vppinfra: add foreach_int macro X-Git-Tag: v24.06-rc0~243 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;h=refs%2Fchanges%2F97%2F39597%2F4;p=vpp.git vppinfra: add foreach_int macro foreach_int(x, 1, 3, 5, 7) { fformat(stdout, "x is %u\n", x); } Type: improvement Change-Id: Idc355f4a284f421b150e3acb7a3a57bcede408c7 Signed-off-by: Damjan Marion --- diff --git a/.clang-format b/.clang-format index 050505b168b..03568413bf8 100644 --- a/.clang-format +++ b/.clang-format @@ -20,6 +20,7 @@ ForEachMacros: - 'vec_foreach_index_backwards' - 'vec_foreach_pointer' - 'vlib_foreach_rx_tx' + - 'foreach_int' - 'foreach_vlib_main' - 'foreach_set_bit_index' - 'foreach_vlib_frame_bitmap_set_bit_index' diff --git a/src/vppinfra/types.h b/src/vppinfra/types.h index a3fbfcc845b..42217968dcc 100644 --- a/src/vppinfra/types.h +++ b/src/vppinfra/types.h @@ -196,6 +196,12 @@ typedef i64 i64u __attribute__ ((aligned (1), __may_alias__)); typedef word wordu __attribute__ ((aligned (1), __may_alias__)); typedef uword uwordu __attribute__ ((aligned (1), __may_alias__)); +#define foreach_int(__var, ...) \ + for (int __int_array[] = { __VA_ARGS__ }, *__int_ptr = __int_array, \ + __var = *__int_ptr; \ + __int_ptr - ARRAY_LEN (__int_array) < __int_array; \ + __var = *++__int_ptr) + #endif /* included_clib_types_h */ /*