17#define PY_SSIZE_T_CLEAN
20#include <frameobject.h>
28#ifndef MATH_STANDALONE
42#if PY_VERSION_HEX <= 0x030c0000
43# define PyLong_AsInt _PyLong_AsInt
44# define PyUnicode_CompareWithASCIIString _PyUnicode_EqualToASCIIString
53 const size_t array_item_size,
56 const PyTypeObject *type,
57 const char *error_prefix)
59 const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast);
60 PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast);
63 BLI_assert(PyList_Check(value_fast) || PyTuple_Check(value_fast));
66 PyErr_Format(PyExc_TypeError,
67 "%.200s: invalid sequence length. expected %d, got %d",
75 if (type == &PyFloat_Type) {
76 switch (array_item_size) {
78 double *array_double =
static_cast<double *
>(
array);
79 for (i = 0; i <
length; i++) {
80 array_double[i] = PyFloat_AsDouble(value_fast_items[i]);
85 float *array_float =
static_cast<float *
>(
array);
86 for (i = 0; i <
length; i++) {
87 array_float[i] = PyFloat_AsDouble(value_fast_items[i]);
97 else if (type == &PyLong_Type) {
98 switch (array_item_size) {
101 for (i = 0; i <
length; i++) {
102 array_int[i] = PyC_Long_AsI64(value_fast_items[i]);
108 for (i = 0; i <
length; i++) {
109 array_int[i] = PyC_Long_AsI32(value_fast_items[i]);
115 for (i = 0; i <
length; i++) {
122 for (i = 0; i <
length; i++) {
133 else if (type == &PyBool_Type) {
134 switch (array_item_size) {
137 for (i = 0; i <
length; i++) {
138 array_bool[i] = (PyLong_AsLong(value_fast_items[i]) != 0);
144 for (i = 0; i <
length; i++) {
145 array_bool[i] = (PyLong_AsLong(value_fast_items[i]) != 0);
151 for (i = 0; i <
length; i++) {
152 array_bool[i] = (PyLong_AsLong(value_fast_items[i]) != 0);
158 for (i = 0; i <
length; i++) {
159 array_bool[i] = (PyLong_AsLong(value_fast_items[i]) != 0);
170 PyErr_Format(PyExc_TypeError,
"%s: internal error %s is invalid", error_prefix, type->tp_name);
174 if (PyErr_Occurred()) {
175 PyErr_Format(PyExc_TypeError,
176 "%s: one or more items could not be used as a %s",
186 const size_t array_item_size,
189 const PyTypeObject *type,
190 const char *error_prefix)
192 PyObject *value_fast;
195 if (!(value_fast = PySequence_Fast(value, error_prefix))) {
200 Py_DECREF(value_fast);
205 const size_t array_item_size,
209 const PyTypeObject *type,
210 const char *error_prefix);
213 const size_t array_item_size,
214 PyObject *value_fast,
217 const PyTypeObject *type,
218 const char *error_prefix)
220 const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast);
221 const int length = dims[0];
231 if (value_len !=
length) {
232 PyErr_Format(PyExc_TypeError,
233 "%.200s: invalid sequence length. expected %d, got %d",
240 PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast);
241 const int *dims_next = dims + 1;
242 const int dims_next_len = dims_len - 1;
244 for (
int i = 0; i <
length; i++) {
261 const size_t array_item_size,
265 const PyTypeObject *type,
266 const char *error_prefix)
268 PyObject *value_fast;
271 if (!(value_fast = PySequence_Fast(value, error_prefix))) {
276 array_p, array_item_size, value_fast, dims, dims_len, type, error_prefix);
277 Py_DECREF(value_fast);
282 const size_t array_item_size,
283 PyObject *value_fast,
286 const PyTypeObject *type,
287 const char *error_prefix)
290 &
array, array_item_size, value_fast, dims, dims_len, type, error_prefix);
294 const size_t array_item_size,
298 const PyTypeObject *type,
299 const char *error_prefix)
302 &
array, array_item_size, value, dims, dims_len, type, error_prefix);
316 PyObject *tuple = PyTuple_New(
len);
317 for (
uint i = 0; i <
len; i++) {
318 PyTuple_SET_ITEM(tuple, i, PyFloat_FromDouble(
array[i]));
325 PyObject *tuple = PyTuple_New(
len);
326 for (
uint i = 0; i <
len; i++) {
327 PyTuple_SET_ITEM(tuple, i, PyFloat_FromDouble(
array[i]));
334 PyObject *tuple = PyTuple_New(
len);
335 for (
uint i = 0; i <
len; i++) {
336 PyTuple_SET_ITEM(tuple, i, PyLong_FromLong(
array[i]));
343 PyObject *tuple = PyTuple_New(
len);
344 for (
uint i = 0; i <
len; i++) {
345 PyTuple_SET_ITEM(tuple, i, PyBool_FromLong(
array[i]));
352 PyObject *tuple = PyTuple_New(
len);
353 for (
uint i = 0; i <
len; i++) {
354 PyTuple_SET_ITEM(tuple, i, PyBool_FromLong(
array[i]));
362 PyObject *tuple = PyTuple_New(
len);
363 for (
uint i = 0; i <
len; i++) {
364 if (PyObject *value = PyUnicode_FromString(
array[i])) {
365 PyTuple_SET_ITEM(tuple, i, value);
386 const int len = dims[0];
389 *array_p = (*array_p) +
len;
392 PyObject *tuple = PyTuple_New(dims[0]);
393 const int *dims_next = dims + 1;
394 const int dims_next_len = dims_len - 1;
395 for (
uint i = 0; i <
len; i++) {
410 const int len = dims[0];
413 *array_p = (*array_p) +
len;
416 PyObject *tuple = PyTuple_New(dims[0]);
417 const int *dims_next = dims + 1;
418 const int dims_next_len = dims_len - 1;
419 for (
uint i = 0; i <
len; i++) {
434 const int len = dims[0];
437 *array_p = (*array_p) +
len;
440 PyObject *tuple = PyTuple_New(dims[0]);
441 const int *dims_next = dims + 1;
442 const int dims_next_len = dims_len - 1;
443 for (
uint i = 0; i <
len; i++) {
458 const int len = dims[0];
461 *array_p = (*array_p) +
len;
464 PyObject *tuple = PyTuple_New(dims[0]);
465 const int *dims_next = dims + 1;
466 const int dims_next_len = dims_len - 1;
467 for (
uint i = 0; i <
len; i++) {
486 const uint tot = PyTuple_GET_SIZE(tuple);
489 for (i = 0; i < tot; i++) {
490 PyTuple_SET_ITEM(tuple, i, value);
497 const uint tot = PyList_GET_SIZE(list);
500 for (i = 0; i < tot; i++) {
501 PyList_SET_ITEM(list, i, value);
514 bool *bool_p =
static_cast<bool *
>(p);
516 if (((value = PyLong_AsLong(o)) == -1) || !
ELEM(value, 0, 1)) {
517 PyErr_Format(PyExc_ValueError,
"expected a bool or int (0/1), got %s", Py_TYPE(o)->tp_name);
521 *bool_p = value ?
true :
false;
528 const char *value = PyUnicode_AsUTF8(o);
529 if (value ==
nullptr) {
530 PyErr_Format(PyExc_ValueError,
"expected a string, got %s", Py_TYPE(o)->tp_name);
534 for (i = 0;
e->items[i].id; i++) {
535 if (
STREQ(
e->items[i].id, value)) {
536 e->value_found =
e->items[i].value;
544 PyObject *enum_items = PyTuple_New(i);
545 for (i = 0;
e->items[i].id; i++) {
546 PyTuple_SET_ITEM(enum_items, i, PyUnicode_FromString(
e->items[i].id));
548 PyErr_Format(PyExc_ValueError,
"expected a string in %S, got '%s'", enum_items, value);
549 Py_DECREF(enum_items);
555 for (
int i = 0; items[i].
id; i++) {
556 if (items[i].value == value) {
565 PyObject *dummy_pydict;
566 return PyArg_ParseTuple(args,
"|O!:__deepcopy__", &PyDict_Type, &dummy_pydict) != 0;
571#ifndef MATH_STANDALONE
581 const char *null_str =
"<null>";
582 fprintf(stderr,
"<%s> : ", name);
583 if (var ==
nullptr) {
584 fprintf(stderr,
"%s\n", null_str);
587 PyObject_Print(var, stderr, 0);
588 const PyTypeObject *type = Py_TYPE(var);
590 " ref:%d, ptr:%p, type: %s\n",
593 type ? type->tp_name : null_str);
600 const char *null_str =
"<null>";
601 if (var ==
nullptr) {
605 const PyTypeObject *type = Py_TYPE(var);
606 PyObject *var_str = PyObject_Repr(var);
607 if (var_str ==
nullptr) {
614 " ref=%d, ptr=%p, type=%s, value=%.200s",
617 type ? type->tp_name : null_str,
618 var_str ? PyUnicode_AsUTF8(var_str) :
"<error>");
619 if (var_str !=
nullptr) {
628 const char *filename;
633 fprintf(stderr,
"Python line lookup failed, interpreter inactive\n");
640 fprintf(stderr,
"%s:%d\n", filename, lineno);
647 fprintf(stderr,
"Python line lookup failed, interpreter inactive\n");
652 const PyGILState_STATE gilstate = PyGILState_Ensure();
653 PyRun_SimpleString(
"__import__('traceback').print_stack()");
654 PyGILState_Release(gilstate);
665 PyFrameObject *frame;
669 *r_filename =
nullptr;
675 if (!(frame = PyEval_GetFrame())) {
678 if (!(code = PyFrame_GetCode(frame))) {
684 *r_filename = PyUnicode_AsUTF8(code->co_filename);
688 if (r_filename && *r_filename ==
nullptr) {
691 PyObject *mod_name = PyDict_GetItemString(PyEval_GetGlobals(),
"__name__");
693 PyObject *
mod = PyDict_GetItem(PyImport_GetModuleDict(), mod_name);
695 PyObject *mod_file = PyModule_GetFilenameObject(
mod);
697 *r_filename = PyUnicode_AsUTF8(mod_name);
706 if (*r_filename ==
nullptr) {
707 *r_filename = PyUnicode_AsUTF8(mod_name);
713 *r_lineno = PyFrame_GetLineNumber(frame);
743 for (i = 0; i < n; i++) {
744 attr = va_arg(vargs,
char *);
745 item = PyObject_GetAttrString(item, attr);
772 ret = PyFrozenSet_New(
nullptr);
775 PyObject *py_str = PyUnicode_FromString(*
str);
776 PySet_Add(
ret, py_str);
791 PyObject *error_value_as_unicode =
nullptr;
793 if (PyErr_Occurred()) {
794 PyObject *error_type, *error_value, *error_traceback;
795 PyErr_Fetch(&error_type, &error_value, &error_traceback);
797 if (PyUnicode_Check(error_value)) {
798 error_value_as_unicode = error_value;
799 Py_INCREF(error_value_as_unicode);
802 error_value_as_unicode = PyUnicode_FromFormat(
803 "%.200s(%S)", Py_TYPE(error_value)->tp_name, error_value);
805 PyErr_Restore(error_type, error_value, error_traceback);
811 PyObject *error_value_format = PyUnicode_FromFormatV(
format, args);
814 if (error_value_as_unicode) {
815 if (error_value_format) {
816 PyObject *error_value_format_prev = error_value_format;
817 error_value_format = PyUnicode_FromFormat(
818 "%S, %S", error_value_format, error_value_as_unicode);
819 Py_DECREF(error_value_format_prev);
823 error_value_format = PyUnicode_FromFormat(
"(internal error), %S", error_value_as_unicode);
825 Py_DECREF(error_value_as_unicode);
828 PyErr_SetObject(exception_type_prefix, error_value_format);
829 Py_XDECREF(error_value_format);
843 PyCodeObject *f_code = (PyCodeObject *)PyFunction_GET_CODE(py_func);
849 "File \"%s\", line %d, in %s\n",
850 PyUnicode_AsUTF8(f_code->co_filename),
851 f_code->co_firstlineno,
852 PyUnicode_AsUTF8(((PyFunctionObject *)py_func)->func_name));
879 if (!PyErr_ExceptionMatches(PyExc_SystemExit)) {
884 if (_Py_GetConfig()->inspect) {
912 PyObject *
result =
nullptr;
914 PyObject *error_type, *error_value, *error_traceback;
915 PyErr_Fetch(&error_type, &error_value, &error_traceback);
919 PyErr_NormalizeException(&error_type, &error_value, &error_traceback);
922 PyObject *string_io =
nullptr;
923 PyObject *string_io_mod =
nullptr;
924 PyObject *string_io_getvalue =
nullptr;
925 if ((string_io_mod = PyImport_ImportModule(
"io")) &&
926 (string_io = PyObject_CallMethod(string_io_mod,
"StringIO",
nullptr)) &&
927 (string_io_getvalue = PyObject_GetAttrString(string_io,
"getvalue")))
929 PyObject *stderr_backup = PySys_GetObject(
"stderr");
931 Py_INCREF(stderr_backup);
932 PySys_SetObject(
"stderr", string_io);
934 PyErr_Display(error_type, error_value, error_traceback);
936 result = PyObject_CallObject(string_io_getvalue,
nullptr);
937 PySys_SetObject(
"stderr", stderr_backup);
938 Py_DECREF(stderr_backup);
941 PySys_WriteStderr(
"Internal error creating: io.StringIO()!\n");
945 PyErr_Display(error_type, error_value, error_traceback);
948 Py_XDECREF(string_io_mod);
949 Py_XDECREF(string_io_getvalue);
950 Py_XDECREF(string_io);
953 result = PyObject_Str(error_value);
956 result = PyUnicode_FromFormat(
"<unprintable %s object>", Py_TYPE(error_value)->tp_name);
960 PyErr_Restore(error_type, error_value, error_traceback);
972 PyObject *
result =
nullptr;
974 PyObject *error_type, *error_value, *error_traceback;
976 PyErr_Fetch(&error_type, &error_value, &error_traceback);
978 if (PyErr_GivenExceptionMatches(error_type, PyExc_SyntaxError)) {
982 if (PyTuple_CheckExact(error_value) && PyTuple_GET_SIZE(error_value) >= 1) {
983 result = PyObject_Str(PyTuple_GET_ITEM(error_value, 0));
988 result = PyObject_Str(error_value);
991 result = PyUnicode_FromFormat(
"<unprintable %s object>", Py_TYPE(error_value)->tp_name);
995 PyErr_Restore(error_type, error_value, error_traceback);
1012 result = PyUnicode_AsUTF8AndSize(py_str, r_size);
1022 if (PyBytes_Check(py_str)) {
1023 *r_size = PyBytes_GET_SIZE(py_str);
1024 return PyBytes_AS_STRING(py_str);
1026 if ((*r_coerce = PyUnicode_EncodeFSDefault(py_str))) {
1027 *r_size = PyBytes_GET_SIZE(*r_coerce);
1028 return PyBytes_AS_STRING(*r_coerce);
1039 result = PyUnicode_AsUTF8(py_str);
1049 if (PyBytes_Check(py_str)) {
1050 return PyBytes_AS_STRING(py_str);
1052 if ((*r_coerce = PyUnicode_EncodeFSDefault(py_str))) {
1053 return PyBytes_AS_STRING(*r_coerce);
1090 Py_CLEAR(
data->value_coerce);
1096 if (
data->value ==
nullptr) {
1101 return data->value_coerce ? Py_CLEANUP_SUPPORTED : 1;
1123 PyObject *modules = PyImport_GetModuleDict();
1124 PyObject *builtins = PyEval_GetBuiltins();
1125 PyObject *mod_main = PyModule_New(
"__main__");
1126 PyDict_SetItemString(modules,
"__main__", mod_main);
1127 Py_DECREF(mod_main);
1128 PyModule_AddStringConstant(mod_main,
"__name__",
"__main__");
1134 PyModule_AddObjectRef(mod_main,
"__builtins__", builtins);
1136 return PyModule_GetDict(mod_main);
1141 for (
int i = 0; imports[i]; i++) {
1142 PyObject *name = PyUnicode_FromString(imports[i]);
1143 PyObject *
mod = PyImport_ImportModuleLevelObject(name,
nullptr,
nullptr,
nullptr, 0);
1146 PyDict_SetItem(py_dict, name,
mod);
1161 PyObject *modules = PyImport_GetModuleDict();
1162 PyObject *main_mod = PyDict_GetItemString(modules,
"__main__");
1166 Py_INCREF(main_mod);
1173 PyObject *modules = PyImport_GetModuleDict();
1175 PyDict_SetItemString(modules,
"__main__", main_mod);
1176 Py_DECREF(main_mod);
1179 PyDict_DelItemString(modules,
"__main__");
1186 return (PyThreadState_GetDict() !=
nullptr);
1200 FILE *fp = fopen(filepath,
"r");
1203 const PyGILState_STATE gilstate = PyGILState_Ensure();
1207 Py_ssize_t *sizes =
static_cast<Py_ssize_t *
>(PyMem_MALLOC(
sizeof(*sizes) * (n / 2)));
1211 PyObject *values = PyList_New(n / 2);
1213 PyObject *py_result, *
ret;
1215 PyObject *struct_mod = PyImport_ImportModule(
"struct");
1216 PyObject *calcsize = PyObject_GetAttrString(struct_mod,
"calcsize");
1217 PyObject *pack = PyObject_GetAttrString(struct_mod,
"pack");
1218 PyObject *unpack = PyObject_GetAttrString(struct_mod,
"unpack");
1220 Py_DECREF(struct_mod);
1223 for (i = 0; i * 2 < n; i++) {
1224 const char *
format = va_arg(vargs,
char *);
1225 void *
ptr = va_arg(vargs,
void *);
1227 ret = PyObject_CallFunction(calcsize,
"s",
format);
1230 sizes[i] = PyLong_AsLong(
ret);
1232 ret = PyObject_CallFunction(unpack,
"sy#",
format, (
char *)
ptr, sizes[i]);
1235 if (
ret ==
nullptr) {
1236 printf(
"%s error, line:%d\n", __func__, __LINE__);
1240 PyList_SET_ITEM(values, i, Py_NewRef(Py_None));
1245 if (PyTuple_GET_SIZE(
ret) == 1) {
1247 PyObject *tmp = PyTuple_GET_ITEM(
ret, 0);
1253 PyList_SET_ITEM(values, i,
ret);
1259 PyDict_SetItemString(py_dict,
"values", values);
1262 py_result = PyRun_File(fp, filepath, Py_file_input, py_dict, py_dict);
1270 values = PyDict_GetItemString(py_dict,
"values");
1272 if (values && PyList_Check(values)) {
1275 Py_DECREF(py_result);
1276 py_result =
nullptr;
1280 for (i = 0; i * 2 < n; i++) {
1281 const char *
format = va_arg(vargs,
char *);
1282 void *
ptr = va_arg(vargs,
void *);
1287 item = PyList_GET_ITEM(values, i);
1288 if (PyTuple_CheckExact(item)) {
1289 int ofs = PyTuple_GET_SIZE(item);
1290 item_new = PyTuple_New(ofs + 1);
1292 PyObject *member = PyTuple_GET_ITEM(item, ofs);
1293 PyTuple_SET_ITEM(item_new, ofs + 1, member);
1297 PyTuple_SET_ITEM(item_new, 0, PyUnicode_FromString(
format));
1300 item_new = Py_BuildValue(
"sO",
format, item);
1303 ret = PyObject_Call(pack, item_new,
nullptr);
1307 memcpy(
ptr, PyBytes_AS_STRING(
ret), sizes[i]);
1311 printf(
"%s error on arg '%d', line:%d\n", __func__, i, __LINE__);
1317 Py_DECREF(item_new);
1322 printf(
"%s error, 'values' not a list, line:%d\n", __func__, __LINE__);
1326 printf(
"%s error line:%d\n", __func__, __LINE__);
1331 Py_DECREF(calcsize);
1337 PyGILState_Release(gilstate);
1340 fprintf(stderr,
"%s: '%s' missing\n", __func__, filepath);
1346 PyObject *as_pointer;
1349 if (
STREQ(Py_TYPE(value)->tp_name, type_name) &&
1350 (as_pointer = PyObject_GetAttrString(value,
"as_pointer")) !=
nullptr &&
1351 PyCallable_Check(as_pointer))
1356 pointer = PyObject_CallObject(as_pointer,
nullptr);
1357 Py_DECREF(as_pointer);
1360 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1363 result = PyLong_AsVoidPtr(pointer);
1366 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1372 PyErr_Format(PyExc_TypeError,
1373 "expected '%.200s' type found '%.200s' instead",
1375 Py_TYPE(value)->tp_name);
1389 PyObject *py_items = PyList_New(0);
1391 PyList_APPEND(py_items, PyUnicode_FromString(item->
identifier));
1393 PyObject *py_string = PyObject_Repr(py_items);
1394 Py_DECREF(py_items);
1402 *r_value = item->
value;
1411 const char *identifier,
1413 const char *error_prefix)
1418 PyExc_ValueError,
"%s: '%.200s' not found in (%U)", error_prefix, identifier, enum_str);
1419 Py_DECREF(enum_str);
1429 const char *error_prefix)
1434 if (!PySet_Check(value)) {
1435 PyErr_Format(PyExc_TypeError,
1436 "%.200s expected a set, not %.200s",
1438 Py_TYPE(value)->tp_name);
1444 if (PySet_GET_SIZE(value) > 0) {
1445 PyObject *it = PyObject_GetIter(value);
1447 while ((key = PyIter_Next(it))) {
1451 const char *param = PyUnicode_AsUTF8(key);
1452 if (param ==
nullptr) {
1453 PyErr_Format(PyExc_TypeError,
1454 "%.200s set must contain strings, not %.200s",
1456 Py_TYPE(key)->tp_name);
1467 if (key !=
nullptr) {
1478 PyObject *
ret = PySet_New(
nullptr);
1483 pystr = PyUnicode_FromString(items->
identifier);
1484 PySet_Add(
ret, pystr);
1499 const char *imports_star[],
1501 const char *filename)
1504 const
char *imports_star[],
1506 const
char *filename)
1513 for (
int i = 0; imports_star[i]; i++) {
1514 PyObject *
mod = PyImport_ImportModule(
"math");
1517 PyDict_Merge(py_dict, PyModule_GetDict(
mod), 0);
1532 retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict);
1542 const char *filename,
1546 const char *imports_star[] = {
"math",
nullptr};
1550 if (PyTuple_Check(retval)) {
1553 for (
int i = 0; i < PyTuple_GET_SIZE(retval); i++) {
1554 const double val_item = PyFloat_AsDouble(PyTuple_GET_ITEM(retval, i));
1555 if (val_item == -1 && PyErr_Occurred()) {
1563 val = PyFloat_AsDouble(retval);
1567 if (val == -1 && PyErr_Occurred()) {
1570 else if (!isfinite(val)) {
1588 const char *filename,
1594 if (val == 0 && PyErr_Occurred()) {
1613 const char *filename,
1615 size_t *r_value_size)
1620 const char *val = PyUnicode_AsUTF8AndSize(retval, &val_len);
1621 if (val ==
nullptr && PyErr_Occurred()) {
1625 char *val_alloc =
static_cast<char *
>(
MEM_mallocN(val_len + 1, __func__));
1626 memcpy(val_alloc, val, val_len + 1);
1627 *r_value = val_alloc;
1628 *r_value_size = val_len;
1642 const char *filename,
1651 const char *filename,
1653 size_t *r_value_size)
1657 if (retval == Py_None) {
1664 const char *val = PyUnicode_AsUTF8AndSize(retval, &val_len);
1665 if (val ==
nullptr && PyErr_Occurred()) {
1669 char *val_alloc =
static_cast<char *
>(
MEM_mallocN(val_len + 1, __func__));
1670 memcpy(val_alloc, val, val_len + 1);
1671 *r_value = val_alloc;
1672 *r_value_size = val_len;
1687 const char *filename,
1707# pragma warning(push)
1708# pragma GCC diagnostic ignored "-Wtype-limits"
1717 if (value ==
nullptr) {
1719 return PyLong_AsUnsignedLong(value);
1722 if (PyLong_Check(value)) {
1723 return PyLong_AsUnsignedLong(value);
1727 PyObject *value_converted = PyNumber_Index(value);
1728 if (value_converted ==
nullptr) {
1732 ulong to_return = PyLong_AsUnsignedLong(value_converted);
1733 Py_DECREF(value_converted);
1740 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1744 PyErr_SetString(PyExc_TypeError,
"Python number not a bool (0/1)");
1753 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1757 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int8");
1766 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1770 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int16");
1788 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint8");
1801 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint16");
1814 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint32");
1822 if (value ==
nullptr) {
1824 return uint64_t(PyLong_AsUnsignedLongLong(value));
1827 if (PyLong_Check(value)) {
1828 return uint64_t(PyLong_AsUnsignedLongLong(value));
1832 PyObject *value_converted = PyNumber_Index(value);
1833 if (value_converted ==
nullptr) {
1839 Py_DECREF(value_converted);
1844# pragma warning(pop)
1855 switch (typestr[0]) {
#define BLI_assert_unreachable()
#define ATTR_WARN_UNUSED_RESULT
#define ATTR_NONNULL(...)
size_t BLI_snprintf(char *__restrict dst, size_t dst_maxncpy, const char *__restrict format,...) ATTR_NONNULL(1
#define UNUSED_VARS_NDEBUG(...)
#define POINTER_OFFSET(v, ofs)
typedef double(DMatrix)[4][4]
Read Guarded memory(de)allocation.
ATTR_WARN_UNUSED_RESULT const BMVert const BMEdge * e
static DBVT_INLINE btScalar size(const btDbvtVolume &a)
SIMD_FORCE_INLINE btScalar length(const btQuaternion &q)
Return the length of a quaternion.
draw_view in_light_buf[] float
void *(* MEM_mallocN)(size_t len, const char *str)
int16_t PyC_Long_AsI16(PyObject *value)
int PyC_AsArray_Multi_FAST(void *array, const size_t array_item_size, PyObject *value_fast, const int *dims, const int dims_len, const PyTypeObject *type, const char *error_prefix)
const char * PyC_UnicodeAsBytesAndSize(PyObject *py_str, Py_ssize_t *r_size, PyObject **r_coerce)
PyObject * PyC_Tuple_PackArray_Bool(const bool *array, uint len)
char PyC_StructFmt_type_from_str(const char *typestr)
PyObject * PyC_Err_SetString_Prefix(PyObject *exception_type_prefix, const char *str)
void * PyC_RNA_AsPointer(PyObject *value, const char *type_name)
bool PyC_StructFmt_type_is_bool(char format)
uint8_t PyC_Long_AsU8(PyObject *value)
PyObject * PyC_Tuple_PackArray_Multi_Bool(const bool *array, const int dims[], const int dims_len)
PyObject * PyC_Err_Format_Prefix(PyObject *exception_type_prefix, const char *format,...)
void PyC_ObSpit(const char *name, PyObject *var)
int8_t PyC_Long_AsI8(PyObject *value)
PyObject * PyC_FlagSet_AsString(const PyC_FlagSet *item)
PyObject * PyC_UnicodeFromBytesAndSize(const char *str, Py_ssize_t size)
void PyC_RunQuicky(const char *filepath, int n,...)
bool PyC_RunString_AsString(const char *imports[], const char *expr, const char *filename, char **r_value)
static ulong pyc_Long_AsUnsignedLong(PyObject *value)
static PyObject * pyc_run_string_as_py_object(const char *imports[], const char *imports_star[], const char *expr, const char *filename) ATTR_NONNULL(3
int PyC_CheckArgs_DeepCopy(PyObject *args)
int PyC_ParseUnicodeAsBytesAndSize(PyObject *o, void *p)
PyObject * PyC_Tuple_PackArray_I32FromBool(const int *array, uint len)
static int PyC_AsArray_Multi_impl(void **array_p, const size_t array_item_size, PyObject *value, const int *dims, const int dims_len, const PyTypeObject *type, const char *error_prefix)
int PyC_FlagSet_ValueFromID(const PyC_FlagSet *item, const char *identifier, int *r_value, const char *error_prefix)
PyObject * PyC_DefaultNameSpace(const char *filename)
bool PyC_RunString_AsStringAndSizeOrNone(const char *imports[], const char *expr, const char *filename, char **r_value, size_t *r_value_size)
int PyC_ParseStringEnum(PyObject *o, void *p)
PyObject * PyC_UnicodeFromBytes(const char *str)
PyObject * PyC_Tuple_PackArray_Multi_F64(const double *array, const int dims[], const int dims_len)
uint64_t PyC_Long_AsU64(PyObject *value)
static PyObject * PyC_Tuple_PackArray_Multi_I32_impl(const int **array_p, const int dims[], const int dims_len)
bool PyC_StructFmt_type_is_int_any(char format)
PyObject * PyC_Tuple_PackArray_I32(const int *array, uint len)
void PyC_ObSpitStr(char *result, size_t result_maxncpy, PyObject *var)
PyObject * PyC_ExceptionBuffer()
static PyObject * PyC_Tuple_PackArray_Multi_Bool_impl(const bool **array_p, const int dims[], const int dims_len)
PyObject * PyC_Tuple_PackArray_String(const char **array, uint len)
bool PyC_RunString_AsStringOrNone(const char *imports[], const char *expr, const char *filename, char **r_value)
int PyC_Long_AsBool(PyObject *value)
int PyC_AsArray(void *array, const size_t array_item_size, PyObject *value, const Py_ssize_t length, const PyTypeObject *type, const char *error_prefix)
int PyC_FlagSet_ValueFromID_int(const PyC_FlagSet *item, const char *identifier, int *r_value)
bool PyC_IsInterpreterActive()
bool PyC_RunString_AsNumber(const char *imports[], const char *expr, const char *filename, double *r_value)
bool PyC_StructFmt_type_is_byte(char format)
int PyC_FlagSet_ToBitfield(const PyC_FlagSet *items, PyObject *value, int *r_value, const char *error_prefix)
PyObject * PyC_Tuple_PackArray_Multi_F32(const float *array, const int dims[], const int dims_len)
PyObject * PyC_ExceptionBuffer_Simple()
int PyC_AsArray_Multi(void *array, const size_t array_item_size, PyObject *value, const int *dims, const int dims_len, const PyTypeObject *type, const char *error_prefix)
PyObject * PyC_MainModule_Backup()
bool PyC_RunString_AsStringAndSize(const char *imports[], const char *expr, const char *filename, char **r_value, size_t *r_value_size)
void PyC_FileAndNum_Safe(const char **r_filename, int *r_lineno)
const char * PyC_StringEnum_FindIDFromValue(const PyC_StringEnumItems *items, const int value)
int PyC_ParseUnicodeAsBytesAndSize_OrNone(PyObject *o, void *p)
uint32_t PyC_Long_AsU32(PyObject *value)
int PyC_AsArray_FAST(void *array, const size_t array_item_size, PyObject *value_fast, const Py_ssize_t length, const PyTypeObject *type, const char *error_prefix)
bool PyC_NameSpace_ImportArray(PyObject *py_dict, const char *imports[])
void PyC_FileAndNum(const char **r_filename, int *r_lineno)
static void pyc_exception_buffer_handle_system_exit()
void PyC_List_Fill(PyObject *list, PyObject *value)
uint16_t PyC_Long_AsU16(PyObject *value)
PyObject * PyC_UnicodeFromStdStr(const std::string &str)
void PyC_Err_PrintWithFunc(PyObject *py_func)
static PyObject * PyC_Tuple_PackArray_Multi_F64_impl(const double **array_p, const int dims[], const int dims_len)
void PyC_MainModule_Restore(PyObject *main_mod)
PyObject * PyC_Tuple_PackArray_F32(const float *array, uint len)
PyObject * PyC_Tuple_PackArray_F64(const double *array, uint len)
PyObject * PyC_Tuple_PackArray_Multi_I32(const int *array, const int dims[], const int dims_len)
int PyC_ParseBool(PyObject *o, void *p)
static PyObject * PyC_Tuple_PackArray_Multi_F32_impl(const float **array_p, const int dims[], const int dims_len)
static int PyC_AsArray_Multi_FAST_impl(void **array_p, const size_t array_item_size, PyObject *value_fast, const int *dims, const int dims_len, const PyTypeObject *type, const char *error_prefix)
PyObject * PyC_FrozenSetFromStrings(const char **strings)
void PyC_Tuple_Fill(PyObject *tuple, PyObject *value)
PyObject * PyC_FlagSet_FromBitfield(PyC_FlagSet *items, int flag)
PyObject * PyC_Object_GetAttrStringArgs(PyObject *o, Py_ssize_t n,...)
bool PyC_StructFmt_type_is_float_any(char format)
const char * PyC_UnicodeAsBytes(PyObject *py_str, PyObject **r_coerce)
bool PyC_RunString_AsIntPtr(const char *imports[], const char *expr, const char *filename, intptr_t *r_value)
unsigned __int64 uint64_t
ccl_device_inline int mod(int x, int m)