Blender V5.0
BLI_array_utils.h
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2023 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
5#pragma once
6
11
13#include "BLI_sys_types.h"
14
20void _bli_array_reverse(void *arr_v, uint arr_len, size_t arr_stride);
21#define BLI_array_reverse(arr, arr_len) _bli_array_reverse(arr, arr_len, sizeof(*(arr)))
22
29void _bli_array_wrap(void *arr_v, uint arr_len, size_t arr_stride, int dir);
30#define BLI_array_wrap(arr, arr_len, dir) _bli_array_wrap(arr, arr_len, sizeof(*(arr)), dir)
31
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)
44
52uint _bli_array_deduplicate_ordered(void *arr, uint arr_len, size_t arr_stride);
53#define BLI_array_deduplicate_ordered(arr, arr_len) \
54 _bli_array_deduplicate_ordered(arr, arr_len, sizeof(*(arr)))
55
63int _bli_array_findindex(const void *arr, uint arr_len, size_t arr_stride, const void *p);
64#define BLI_array_findindex(arr, arr_len, p) _bli_array_findindex(arr, arr_len, sizeof(*(arr)), p)
65
69int _bli_array_rfindindex(const void *arr, uint arr_len, size_t arr_stride, const void *p);
70#define BLI_array_rfindindex(arr, arr_len, p) \
71 _bli_array_rfindindex(arr, arr_len, sizeof(*(arr)), p)
72
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))))
79
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))))
86
103bool _bli_array_iter_span(const void *arr,
104 uint arr_len,
105 size_t arr_stride,
106 bool use_wrap,
107 bool use_delimit_bounds,
108 bool (*test_fn)(const void *arr_item, void *user_data),
109 void *user_data,
110 uint span_step[2],
111 uint *r_span_len);
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, \
115 arr_len, \
116 sizeof(*(arr)), \
117 use_wrap, \
118 use_delimit_bounds, \
119 test_fn, \
120 user_data, \
121 span_step, \
122 r_span_len)
123
127bool _bli_array_is_zeroed(const void *arr_v, uint arr_len, size_t arr_stride);
128#define BLI_array_is_zeroed(arr, arr_len) _bli_array_is_zeroed(arr, arr_len, sizeof(*(arr)))
129
137bool _bli_array_iter_spiral_square(const void *arr_v,
138 const int arr_shape[2],
139 size_t elem_size,
140 const int center[2],
141 bool (*test_fn)(const void *arr_item, void *user_data),
142 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)
unsigned int uint