Blender V4.5
mathutils.hh
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
10
11#include <Python.h>
12
13/* Can cast different mathutils types to this, use for generic functions. */
14
15#include "BLI_array.hh"
16#include "BLI_vector.hh"
17
18struct DynStr;
19
22extern char BaseMathObject_is_valid_doc[];
23extern char BaseMathObject_owner_doc[];
24
25PyObject *_BaseMathObject_new_impl(PyTypeObject *root_type, PyTypeObject *base_type);
26
27#define BASE_MATH_NEW(struct_name, root_type, base_type) \
28 ((struct_name *)_BaseMathObject_new_impl(&root_type, base_type))
29
31enum {
43};
44#define BASE_MATH_FLAG_DEFAULT 0
45
46#define BASE_MATH_MEMBERS(_data) \
47 \
48 PyObject_VAR_HEAD \
49 float *_data; \
50 \
51 PyObject *cb_user; \
52 \
53 unsigned char cb_type; \
54 \
56 unsigned char cb_subtype; \
57 \
58 unsigned char flag
62};
63
64/* types */
65#include "mathutils_Color.hh" // IWYU pragma: export
66#include "mathutils_Euler.hh" // IWYU pragma: export
67#include "mathutils_Matrix.hh" // IWYU pragma: export
68#include "mathutils_Quaternion.hh" // IWYU pragma: export
69#include "mathutils_Vector.hh" // IWYU pragma: export
70
71/* avoid checking all types */
72#define BaseMathObject_CheckExact(v) (Py_TYPE(v)->tp_dealloc == (destructor)BaseMathObject_dealloc)
73
78
79extern char BaseMathObject_freeze_doc[];
81
82int BaseMathObject_traverse(BaseMathObject *self, visitproc visit, void *arg);
86
87PyMODINIT_FUNC PyInit_mathutils();
88
89int EXPP_FloatsAreEqual(float af, float bf, int maxDiff);
90int EXPP_VectorsAreEqual(const float *vecA, const float *vecB, int size, int floatSteps);
91
93using BaseMathCheckFunc = int (*)(BaseMathObject *);
95using BaseMathGetFunc = int (*)(BaseMathObject *, int);
97using BaseMathSetFunc = int (*)(BaseMathObject *, int);
99using BaseMathGetIndexFunc = int (*)(BaseMathObject *, int, int);
101using BaseMathSetIndexFunc = int (*)(BaseMathObject *, int, int);
109};
110
112
119int _BaseMathObject_ResizeOkOrRaiseExc(BaseMathObject *self, const char *error_prefix);
120
123
124/* since this is called so often avoid where possible */
125#define BaseMath_CheckCallback(_self) \
126 (((_self)->cb_user ? _BaseMathObject_CheckCallback((BaseMathObject *)_self) : 0))
127#define BaseMath_ReadCallback(_self) \
128 (((_self)->cb_user ? _BaseMathObject_ReadCallback((BaseMathObject *)_self) : 0))
129#define BaseMath_WriteCallback(_self) \
130 (((_self)->cb_user ? _BaseMathObject_WriteCallback((BaseMathObject *)_self) : 0))
131#define BaseMath_ReadIndexCallback(_self, _index) \
132 (((_self)->cb_user ? _BaseMathObject_ReadIndexCallback((BaseMathObject *)_self, _index) : 0))
133#define BaseMath_WriteIndexCallback(_self, _index) \
134 (((_self)->cb_user ? _BaseMathObject_WriteIndexCallback((BaseMathObject *)_self, _index) : 0))
135
136/* support BASE_MATH_FLAG_IS_FROZEN */
137#define BaseMath_ReadCallback_ForWrite(_self) \
138 (UNLIKELY((_self)->flag & BASE_MATH_FLAG_IS_FROZEN) ? \
139 (_BaseMathObject_RaiseFrozenExc((BaseMathObject *)_self), -1) : \
140 (BaseMath_ReadCallback(_self)))
142#define BaseMath_ReadIndexCallback_ForWrite(_self, _index) \
143 (UNLIKELY((_self)->flag & BASE_MATH_FLAG_IS_FROZEN) ? \
144 (_BaseMathObject_RaiseFrozenExc((BaseMathObject *)_self), -1) : \
145 (BaseMath_ReadIndexCallback(_self, _index)))
147#define BaseMath_Prepare_ForWrite(_self) \
148 (UNLIKELY((_self)->flag & BASE_MATH_FLAG_IS_FROZEN) ? \
149 (_BaseMathObject_RaiseFrozenExc((BaseMathObject *)_self), -1) : \
150 0)
152#define BaseMathObject_Prepare_ForHash(_self) \
153 (UNLIKELY(((_self)->flag & BASE_MATH_FLAG_IS_FROZEN) == 0) ? \
154 (_BaseMathObject_RaiseNotFrozenExc((BaseMathObject *)_self), -1) : \
155 0)
159 */
160#define BaseMathObject_Prepare_ForResize(_self, error_prefix) \
161 _BaseMathObject_ResizeOkOrRaiseExc((BaseMathObject *)_self, error_prefix)
162
163/* utility func */
169 float *array, int array_num_min, int array_num_max, PyObject *value, const char *error_prefix);
174 int array_num_min,
175 PyObject *value,
176 const char *error_prefix);
181 int array_dim,
182 PyObject *value,
183 const char *error_prefix);
188 int array_dim,
189 PyObject *value,
190 const char *error_prefix);
195 int array_dim,
196 PyObject *value,
197 const char *error_prefix);
201bool mathutils_array_parse_alloc_viseq(PyObject *value,
202 const char *error_prefix,
204int mathutils_any_to_rotmat(float rmat[3][3], PyObject *value, const char *error_prefix);
205
211Py_hash_t mathutils_array_hash(const float *array, size_t array_len);
212
213/* zero remaining unused elements of the array */
214#define MU_ARRAY_ZERO (1u << 30)
215/* ignore larger py sequences than requested (just use first elements),
216 * handy when using 3d vectors as 2d */
217#define MU_ARRAY_SPILL (1u << 31)
219#define MU_ARRAY_FLAGS (MU_ARRAY_ZERO | MU_ARRAY_SPILL)
220
232int column_vector_multiplication(float r_vec[4], VectorObject *vec, MatrixObject *mat);
233
234#ifndef MATH_STANDALONE
235/* dynstr as python string utility functions */
236/* dynstr as python string utility functions, frees 'ds'! */
237PyObject *mathutils_dynstr_to_py(struct DynStr *ds);
238#endif
BMesh const char void * data
PyObject * self
static DBVT_INLINE btScalar size(const btDbvtVolume &a)
Definition btDbvt.cpp:52
char BaseMathObject_is_valid_doc[]
Definition mathutils.cc:655
char BaseMathObject_is_wrapped_doc[]
Definition mathutils.cc:641
char BaseMathObject_is_frozen_doc[]
Definition mathutils.cc:648
char BaseMathObject_owner_doc[]
Definition mathutils.cc:634
char BaseMathObject_freeze_doc[]
Definition mathutils.cc:661
int _BaseMathObject_CheckCallback(BaseMathObject *self)
Definition mathutils.cc:539
int EXPP_FloatsAreEqual(float af, float bf, int maxDiff)
Definition mathutils.cc:470
@ BASE_MATH_FLAG_IS_WRAP
Definition mathutils.hh:37
@ BASE_MATH_FLAG_IS_FROZEN
Definition mathutils.hh:42
bool mathutils_array_parse_alloc_viseq(PyObject *value, const char *error_prefix, blender::Array< blender::Vector< int > > &r_data)
Definition mathutils.cc:372
PyMODINIT_FUNC PyInit_mathutils()
Definition mathutils.cc:781
int mathutils_array_parse_alloc(float **array, int array_num_min, PyObject *value, const char *error_prefix)
Definition mathutils.cc:192
int BaseMathObject_is_gc(BaseMathObject *self)
Definition mathutils.cc:727
void _BaseMathObject_RaiseFrozenExc(const BaseMathObject *self)
Definition mathutils.cc:604
Py_hash_t mathutils_array_hash(const float *array, size_t array_len)
Definition mathutils.cc:68
void BaseMathObject_dealloc(BaseMathObject *self)
Definition mathutils.cc:705
int _BaseMathObject_WriteCallback(BaseMathObject *self)
Definition mathutils.cc:563
int mathutils_int_array_parse(int *array, int array_dim, PyObject *value, const char *error_prefix)
Definition mathutils.cc:300
int EXPP_VectorsAreEqual(const float *vecA, const float *vecB, int size, int floatSteps)
Definition mathutils.cc:489
int mathutils_array_parse(float *array, int array_num_min, int array_num_max, PyObject *value, const char *error_prefix)
Definition mathutils.cc:96
int mathutils_array_parse_alloc_vi(int **array, int array_dim, PyObject *value, const char *error_prefix)
Definition mathutils.cc:335
int(*)(BaseMathObject *, int) BaseMathGetFunc
Definition mathutils.hh:94
int(*)(BaseMathObject *, int) BaseMathSetFunc
Definition mathutils.hh:96
int mathutils_array_parse_alloc_v(float **array, int array_dim, PyObject *value, const char *error_prefix)
Definition mathutils.cc:259
int _BaseMathObject_ResizeOkOrRaiseExc(BaseMathObject *self, const char *error_prefix)
Definition mathutils.cc:615
PyObject * BaseMathObject_owner_get(BaseMathObject *self, void *)
Definition mathutils.cc:635
PyObject * _BaseMathObject_new_impl(PyTypeObject *root_type, PyTypeObject *base_type)
Definition mathutils.cc:732
int mathutils_any_to_rotmat(float rmat[3][3], PyObject *value, const char *error_prefix)
Definition mathutils.cc:408
int column_vector_multiplication(float r_vec[4], VectorObject *vec, MatrixObject *mat)
int(*)(BaseMathObject *, int, int) BaseMathSetIndexFunc
Definition mathutils.hh:100
PyObject * BaseMathObject_is_frozen_get(BaseMathObject *self, void *)
Definition mathutils.cc:650
PyObject * BaseMathObject_freeze(BaseMathObject *self)
Definition mathutils.cc:669
int(*)(BaseMathObject *) BaseMathCheckFunc
Definition mathutils.hh:92
int(*)(BaseMathObject *, int, int) BaseMathGetIndexFunc
Definition mathutils.hh:98
#define BASE_MATH_MEMBERS(_data)
Definition mathutils.hh:46
PyObject * BaseMathObject_is_wrapped_get(BaseMathObject *self, void *)
Definition mathutils.cc:643
PyObject * mathutils_dynstr_to_py(struct DynStr *ds)
Definition mathutils.cc:501
int _BaseMathObject_WriteIndexCallback(BaseMathObject *self, int index)
Definition mathutils.cc:590
PyObject * BaseMathObject_is_valid_get(BaseMathObject *self, void *)
Definition mathutils.cc:656
int BaseMathObject_clear(BaseMathObject *self)
Definition mathutils.cc:687
int _BaseMathObject_ReadIndexCallback(BaseMathObject *self, int index)
Definition mathutils.cc:576
int _BaseMathObject_ReadCallback(BaseMathObject *self)
Definition mathutils.cc:548
unsigned char Mathutils_RegisterCallback(Mathutils_Callback *cb)
Definition mathutils.cc:521
void _BaseMathObject_RaiseNotFrozenExc(const BaseMathObject *self)
Definition mathutils.cc:609
int BaseMathObject_traverse(BaseMathObject *self, visitproc visit, void *arg)
Definition mathutils.cc:681
BaseMathSetIndexFunc set_index
Definition mathutils.hh:107
BaseMathCheckFunc check
Definition mathutils.hh:103
BaseMathGetIndexFunc get_index
Definition mathutils.hh:106
BaseMathSetFunc set
Definition mathutils.hh:105
BaseMathGetFunc get
Definition mathutils.hh:104