21#define BLI_array_reverse(arr, arr_len) _bli_array_reverse(arr, arr_len, sizeof(*(arr)))
30#define BLI_array_wrap(arr, arr_len, dir) _bli_array_wrap(arr, arr_len, sizeof(*(arr)), dir)
39 void *arr,
uint arr_len,
size_t arr_stride,
const uint *order,
void *arr_temp);
40#define BLI_array_permute(arr, arr_len, order) \
41 _bli_array_permute(arr, arr_len, sizeof(*(arr)), order, NULL)
42#define BLI_array_permute_ex(arr, arr_len, order, arr_temp) \
43 _bli_array_permute(arr, arr_len, sizeof(*(arr)), order, arr_temp)
53#define BLI_array_deduplicate_ordered(arr, arr_len) \
54 _bli_array_deduplicate_ordered(arr, arr_len, sizeof(*(arr)))
64#define BLI_array_findindex(arr, arr_len, p) _bli_array_findindex(arr, arr_len, sizeof(*(arr)), p)
70#define BLI_array_rfindindex(arr, arr_len, p) \
71 _bli_array_rfindindex(arr, arr_len, sizeof(*(arr)), p)
74 void *arr,
const void *arr_a,
const void *arr_b,
uint arr_len,
size_t arr_stride);
75#define BLI_array_binary_and(arr, arr_a, arr_b, arr_len) \
76 (CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_a)), \
77 CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_b)), \
78 _bli_array_binary_and(arr, arr_a, arr_b, arr_len, sizeof(*(arr))))
81 void *arr,
const void *arr_a,
const void *arr_b,
uint arr_len,
size_t arr_stride);
82#define BLI_array_binary_or(arr, arr_a, arr_b, arr_len) \
83 (CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_a)), \
84 CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_b)), \
85 _bli_array_binary_or(arr, arr_a, arr_b, arr_len, sizeof(*(arr))))
107 bool use_delimit_bounds,
108 bool (*test_fn)(
const void *arr_item,
void *user_data),
112#define BLI_array_iter_span( \
113 arr, arr_len, use_wrap, use_delimit_bounds, test_fn, user_data, span_step, r_span_len) \
114 _bli_array_iter_span(arr, \
118 use_delimit_bounds, \
128#define BLI_array_is_zeroed(arr, arr_len) _bli_array_is_zeroed(arr, arr_len, sizeof(*(arr)))
138 const int arr_shape[2],
141 bool (*test_fn)(
const void *arr_item,
void *user_data),
143#define BLI_array_iter_spiral_square(arr, arr_shape, center, test_fn, user_data) \
144 _bli_array_iter_spiral_square(arr, arr_shape, sizeof(*(arr)), center, test_fn, user_data)
void _bli_array_binary_or(void *arr, const void *arr_a, const void *arr_b, uint arr_len, size_t arr_stride)
int _bli_array_rfindindex(const void *arr, uint arr_len, size_t arr_stride, const void *p)
uint _bli_array_deduplicate_ordered(void *arr, uint arr_len, size_t arr_stride)
bool _bli_array_is_zeroed(const void *arr_v, uint arr_len, size_t arr_stride)
bool _bli_array_iter_spiral_square(const void *arr_v, const int arr_shape[2], size_t elem_size, const int center[2], bool(*test_fn)(const void *arr_item, void *user_data), void *user_data)
void _bli_array_permute(void *arr, uint arr_len, size_t arr_stride, const uint *order, void *arr_temp)
int _bli_array_findindex(const void *arr, uint arr_len, size_t arr_stride, const void *p)
bool _bli_array_iter_span(const void *arr, uint arr_len, size_t arr_stride, bool use_wrap, bool use_delimit_bounds, bool(*test_fn)(const void *arr_item, void *user_data), void *user_data, uint span_step[2], uint *r_span_len)
void _bli_array_wrap(void *arr_v, uint arr_len, size_t arr_stride, int dir)
void _bli_array_reverse(void *arr_v, uint arr_len, size_t arr_stride)
void _bli_array_binary_and(void *arr, const void *arr_a, const void *arr_b, uint arr_len, size_t arr_stride)