25#define BLI_array_reverse(arr, arr_len) _bli_array_reverse(arr, arr_len, sizeof(*(arr)))
34#define BLI_array_wrap(arr, arr_len, dir) _bli_array_wrap(arr, arr_len, sizeof(*(arr)), dir)
43 void *arr,
uint arr_len,
size_t arr_stride,
const uint *order,
void *arr_temp);
44#define BLI_array_permute(arr, arr_len, order) \
45 _bli_array_permute(arr, arr_len, sizeof(*(arr)), order, NULL)
46#define BLI_array_permute_ex(arr, arr_len, order, arr_temp) \
47 _bli_array_permute(arr, arr_len, sizeof(*(arr)), order, arr_temp)
57#define BLI_array_deduplicate_ordered(arr, arr_len) \
58 _bli_array_deduplicate_ordered(arr, arr_len, sizeof(*(arr)))
68#define BLI_array_findindex(arr, arr_len, p) _bli_array_findindex(arr, arr_len, sizeof(*(arr)), p)
74#define BLI_array_rfindindex(arr, arr_len, p) \
75 _bli_array_rfindindex(arr, arr_len, sizeof(*(arr)), p)
78 void *arr,
const void *arr_a,
const void *arr_b,
uint arr_len,
size_t arr_stride);
79#define BLI_array_binary_and(arr, arr_a, arr_b, arr_len) \
80 (CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_a)), \
81 CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_b)), \
82 _bli_array_binary_and(arr, arr_a, arr_b, arr_len, sizeof(*(arr))))
85 void *arr,
const void *arr_a,
const void *arr_b,
uint arr_len,
size_t arr_stride);
86#define BLI_array_binary_or(arr, arr_a, arr_b, arr_len) \
87 (CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_a)), \
88 CHECK_TYPE_PAIR_INLINE(*(arr), *(arr_b)), \
89 _bli_array_binary_or(arr, arr_a, arr_b, arr_len, sizeof(*(arr))))
111 bool use_delimit_bounds,
112 bool (*test_fn)(
const void *arr_item,
void *user_data),
116#define BLI_array_iter_span( \
117 arr, arr_len, use_wrap, use_delimit_bounds, test_fn, user_data, span_step, r_span_len) \
118 _bli_array_iter_span(arr, \
122 use_delimit_bounds, \
132#define BLI_array_is_zeroed(arr, arr_len) _bli_array_is_zeroed(arr, arr_len, sizeof(*(arr)))
142 const int arr_shape[2],
145 bool (*test_fn)(
const void *arr_item,
void *user_data),
147#define BLI_array_iter_spiral_square(arr, arr_shape, center, test_fn, user_data) \
148 _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)