 |
Blender
V2.93
|
Go to the documentation of this file.
40 #define BLI_LINKSTACK_DECLARE(var, type) \
42 BLI_mempool *var##_pool_; \
45 #define BLI_LINKSTACK_INIT(var) \
48 var##_pool_ = BLI_mempool_create(sizeof(LinkNode), 0, 64, BLI_MEMPOOL_NOP); \
52 #define BLI_LINKSTACK_SIZE(var) BLI_mempool_len(var##_pool_)
56 # define BLI_LINKSTACK_PUSH(var, ptr) \
57 (CHECK_TYPE_INLINE(ptr, typeof(var##_type_)), \
58 BLI_linklist_prepend_pool(&(var), ptr, var##_pool_))
59 # define BLI_LINKSTACK_POP(var) \
60 (var ? (typeof(var##_type_))BLI_linklist_pop_pool(&(var), var##_pool_) : NULL)
61 # define BLI_LINKSTACK_POP_DEFAULT(var, r) \
62 (var ? (typeof(var##_type_))BLI_linklist_pop_pool(&(var), var##_pool_) : r)
64 # define BLI_LINKSTACK_PUSH(var, ptr) (BLI_linklist_prepend_pool(&(var), ptr, var##_pool_))
65 # define BLI_LINKSTACK_POP(var) (var ? BLI_linklist_pop_pool(&(var), var##_pool_) : NULL)
66 # define BLI_LINKSTACK_POP_DEFAULT(var, r) (var ? BLI_linklist_pop_pool(&(var), var##_pool_) : r)
69 #define BLI_LINKSTACK_SWAP(var_a, var_b) \
71 CHECK_TYPE_PAIR(var_a##_type_, var_b##_type_); \
72 SWAP(LinkNode *, var_a, var_b); \
73 SWAP(BLI_mempool *, var_a##_pool_, var_b##_pool_); \
77 #define BLI_LINKSTACK_FREE(var) \
79 BLI_mempool_destroy(var##_pool_); \
84 (void)&(var##_type_); \
103 # define _BLI_SMALLSTACK_CAST(var) (typeof(_##var##_type))
105 # define _BLI_SMALLSTACK_CAST(var)
108 #define _BLI_SMALLSTACK_FAKEUSER(var) (void)(&(_##var##_type))
110 #define BLI_SMALLSTACK_DECLARE(var, type) \
111 LinkNode *_##var##_stack = NULL, *_##var##_free = NULL, *_##var##_temp = NULL; \
114 #define BLI_SMALLSTACK_PUSH(var, data) \
116 CHECK_TYPE_PAIR(data, _##var##_type); \
117 if (_##var##_free) { \
118 _##var##_temp = _##var##_free; \
119 _##var##_free = _##var##_free->next; \
122 _##var##_temp = alloca(sizeof(LinkNode)); \
124 _##var##_temp->next = _##var##_stack; \
125 _##var##_temp->link = data; \
126 _##var##_stack = _##var##_temp; \
127 _BLI_SMALLSTACK_FAKEUSER(var); \
132 #define _BLI_SMALLSTACK_DEL_EX(var_src, var_dst) \
133 (void)(_BLI_SMALLSTACK_FAKEUSER(var_src), \
134 _BLI_SMALLSTACK_FAKEUSER(var_dst), \
135 (_##var_src##_temp = _##var_src##_stack->next), \
136 (_##var_src##_stack->next = _##var_dst##_free), \
137 (_##var_dst##_free = _##var_src##_stack), \
138 (_##var_src##_stack = _##var_src##_temp))
140 #define _BLI_SMALLSTACK_DEL(var) _BLI_SMALLSTACK_DEL_EX(var, var)
143 #define BLI_SMALLSTACK_POP(var) \
144 (_BLI_SMALLSTACK_CAST(var)( \
145 (_##var##_stack) ? (_BLI_SMALLSTACK_DEL(var), (_##var##_free->link)) : NULL))
148 #define BLI_SMALLSTACK_POP_EX(var_src, var_dst) \
149 (_BLI_SMALLSTACK_CAST(var_src)( \
150 (_##var_src##_stack) ? \
151 (_BLI_SMALLSTACK_DEL_EX(var_src, var_dst), (_##var_dst##_free->link)) : \
154 #define BLI_SMALLSTACK_PEEK(var) \
155 (_BLI_SMALLSTACK_CAST(var)((_##var##_stack) ? _##var##_stack->link : NULL))
157 #define BLI_SMALLSTACK_IS_EMPTY(var) ((_BLI_SMALLSTACK_CAST(var) _##var##_stack) == NULL)
160 #define BLI_SMALLSTACK_AS_TABLE(var, data) \
162 LinkNode *_##var##_iter; \
164 for (_##var##_iter = _##var##_stack, i = 0; _##var##_iter; \
165 _##var##_iter = _##var##_iter->next, i++) { \
166 (data)[i] = _BLI_SMALLSTACK_CAST(var)(_##var##_iter->link); \
172 #define BLI_SMALLSTACK_ITER_BEGIN(var, item) \
174 LinkNode *_##var##_iter; \
175 for (_##var##_iter = _##var##_stack; _##var##_iter; _##var##_iter = _##var##_iter->next) { \
176 item = _BLI_SMALLSTACK_CAST(var)(_##var##_iter->link);
178 #define BLI_SMALLSTACK_ITER_END \
183 #define BLI_SMALLSTACK_SWAP(var_a, var_b) \
185 CHECK_TYPE_PAIR(_##var_a##_type, _##var_b##_type); \
186 SWAP(LinkNode *, _##var_a##_stack, _##var_b##_stack); \
187 SWAP(LinkNode *, _##var_a##_free, _##var_b##_free); \