13#define PY_SSIZE_T_CLEAN
16#include <frameobject.h>
24#ifndef MATH_STANDALONE
34#if PY_VERSION_HEX < 0x030d0000
35# define PyLong_AsInt _PyLong_AsInt
36# define PyUnicode_CompareWithASCIIString _PyUnicode_EqualToASCIIString
45 const size_t array_item_size,
48 const PyTypeObject *type,
49 const char *error_prefix)
51 const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast);
52 PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast);
55 BLI_assert(PyList_Check(value_fast) || PyTuple_Check(value_fast));
58 PyErr_Format(PyExc_TypeError,
59 "%.200s: invalid sequence length. expected %d, got %d",
67 if (type == &PyFloat_Type) {
68 switch (array_item_size) {
69 case sizeof(double): {
70 double *array_double =
static_cast<double *
>(
array);
72 array_double[
i] = PyFloat_AsDouble(value_fast_items[
i]);
77 float *array_float =
static_cast<float *
>(
array);
79 array_float[
i] = PyFloat_AsDouble(value_fast_items[
i]);
89 else if (type == &PyLong_Type) {
90 switch (array_item_size) {
94 array_int[
i] = PyC_Long_AsI64(value_fast_items[
i]);
101 array_int[
i] = PyC_Long_AsI32(value_fast_items[
i]);
105 case sizeof(int16_t): {
106 int16_t *array_int =
static_cast<int16_t *
>(
array);
112 case sizeof(int8_t): {
113 int8_t *array_int =
static_cast<int8_t *
>(
array);
125 else if (type == &PyBool_Type) {
126 switch (array_item_size) {
130 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
137 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
141 case sizeof(int16_t): {
142 int16_t *array_bool =
static_cast<int16_t *
>(
array);
144 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
148 case sizeof(int8_t): {
149 int8_t *array_bool =
static_cast<int8_t *
>(
array);
151 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
162 PyErr_Format(PyExc_TypeError,
"%s: internal error %s is invalid", error_prefix, type->tp_name);
166 if (PyErr_Occurred()) {
167 PyErr_Format(PyExc_TypeError,
168 "%s: one or more items could not be used as a %s",
178 const size_t array_item_size,
181 const PyTypeObject *type,
182 const char *error_prefix)
184 PyObject *value_fast;
187 if (!(value_fast = PySequence_Fast(value, error_prefix))) {
192 Py_DECREF(value_fast);
197 const size_t array_item_size,
201 const PyTypeObject *type,
202 const char *error_prefix);
205 const size_t array_item_size,
206 PyObject *value_fast,
209 const PyTypeObject *type,
210 const char *error_prefix)
212 const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast);
213 const int length = dims[0];
223 if (value_len !=
length) {
224 PyErr_Format(PyExc_TypeError,
225 "%.200s: invalid sequence length. expected %d, got %d",
232 PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast);
233 const int *dims_next = dims + 1;
234 const int dims_next_len = dims_len - 1;
253 const size_t array_item_size,
257 const PyTypeObject *type,
258 const char *error_prefix)
260 PyObject *value_fast;
263 if (!(value_fast = PySequence_Fast(value, error_prefix))) {
268 array_p, array_item_size, value_fast, dims, dims_len, type, error_prefix);
269 Py_DECREF(value_fast);
274 const size_t array_item_size,
275 PyObject *value_fast,
278 const PyTypeObject *type,
279 const char *error_prefix)
282 &
array, array_item_size, value_fast, dims, dims_len, type, error_prefix);
286 const size_t array_item_size,
290 const PyTypeObject *type,
291 const char *error_prefix)
294 &
array, array_item_size, value, dims, dims_len, type, error_prefix);
308 PyObject *tuple = PyTuple_New(
len);
310 PyTuple_SET_ITEM(tuple,
i, PyFloat_FromDouble(
array[
i]));
317 PyObject *tuple = PyTuple_New(
len);
319 PyTuple_SET_ITEM(tuple,
i, PyFloat_FromDouble(
array[
i]));
326 PyObject *tuple = PyTuple_New(
len);
328 PyTuple_SET_ITEM(tuple,
i, PyLong_FromLong(
array[
i]));
335 PyObject *tuple = PyTuple_New(
len);
337 PyTuple_SET_ITEM(tuple,
i, PyBool_FromLong(
array[
i]));
344 PyObject *tuple = PyTuple_New(
len);
346 PyTuple_SET_ITEM(tuple,
i, PyBool_FromLong(
array[
i]));
354 PyObject *tuple = PyTuple_New(
len);
356 if (PyObject *value = PyUnicode_FromString(
array[
i])) {
357 PyTuple_SET_ITEM(tuple,
i, value);
378 const int len = dims[0];
381 *array_p = (*array_p) +
len;
384 PyObject *tuple = PyTuple_New(dims[0]);
385 const int *dims_next = dims + 1;
386 const int dims_next_len = dims_len - 1;
402 const int len = dims[0];
405 *array_p = (*array_p) +
len;
408 PyObject *tuple = PyTuple_New(dims[0]);
409 const int *dims_next = dims + 1;
410 const int dims_next_len = dims_len - 1;
426 const int len = dims[0];
429 *array_p = (*array_p) +
len;
432 PyObject *tuple = PyTuple_New(dims[0]);
433 const int *dims_next = dims + 1;
434 const int dims_next_len = dims_len - 1;
450 const int len = dims[0];
453 *array_p = (*array_p) +
len;
456 PyObject *tuple = PyTuple_New(dims[0]);
457 const int *dims_next = dims + 1;
458 const int dims_next_len = dims_len - 1;
478 const uint tot = PyTuple_GET_SIZE(tuple);
481 for (
i = 0;
i < tot;
i++) {
482 PyTuple_SET_ITEM(tuple,
i, value);
489 const uint tot = PyList_GET_SIZE(list);
492 for (
i = 0;
i < tot;
i++) {
493 PyList_SET_ITEM(list,
i, value);
506 bool *bool_p =
static_cast<bool *
>(p);
508 if (((value = PyLong_AsLong(o)) == -1) || !
ELEM(value, 0, 1)) {
509 PyErr_Format(PyExc_ValueError,
"expected a bool or int (0/1), got %s", Py_TYPE(o)->tp_name);
513 *bool_p = value ?
true :
false;
520 const char *value = PyUnicode_AsUTF8(o);
521 if (value ==
nullptr) {
522 PyErr_Format(PyExc_ValueError,
"expected a string, got %s", Py_TYPE(o)->tp_name);
526 for (
i = 0;
e->items[
i].id;
i++) {
527 if (
STREQ(
e->items[
i].id, value)) {
528 e->value_found =
e->items[
i].value;
536 PyObject *enum_items = PyTuple_New(
i);
537 for (
i = 0;
e->items[
i].id;
i++) {
538 PyTuple_SET_ITEM(enum_items,
i, PyUnicode_FromString(
e->items[
i].id));
540 PyErr_Format(PyExc_ValueError,
"expected a string in %S, got '%s'", enum_items, value);
541 Py_DECREF(enum_items);
547 for (
int i = 0; items[
i].
id;
i++) {
548 if (items[
i].value == value) {
557 PyObject *dummy_pydict;
558 return PyArg_ParseTuple(args,
"|O!:__deepcopy__", &PyDict_Type, &dummy_pydict) != 0;
563#ifndef MATH_STANDALONE
573 const char *null_str =
"<null>";
574 fprintf(stderr,
"<%s> : ", name);
575 if (var ==
nullptr) {
576 fprintf(stderr,
"%s\n", null_str);
579 PyObject_Print(var, stderr, 0);
580 const PyTypeObject *type = Py_TYPE(var);
582 " ref:%d, ptr:%p, type: %s\n",
585 type ? type->tp_name : null_str);
592 const char *null_str =
"<null>";
593 if (var ==
nullptr) {
597 const PyTypeObject *type = Py_TYPE(var);
598 PyObject *var_str = PyObject_Repr(var);
599 if (var_str ==
nullptr) {
606 " ref=%d, ptr=%p, type=%s, value=%.200s",
609 type ? type->tp_name : null_str,
610 var_str ? PyUnicode_AsUTF8(var_str) :
"<error>");
611 if (var_str !=
nullptr) {
620 const char *filename;
625 fprintf(stderr,
"Python line lookup failed, interpreter inactive\n");
632 fprintf(stderr,
"%s:%d\n", filename, lineno);
639 fprintf(stderr,
"Python line lookup failed, interpreter inactive\n");
644 const PyGILState_STATE gilstate = PyGILState_Ensure();
645 PyRun_SimpleString(
"__import__('traceback').print_stack()");
646 PyGILState_Release(gilstate);
657 PyFrameObject *frame;
661 *r_filename =
nullptr;
667 if (!(frame = PyEval_GetFrame())) {
670 if (!(code = PyFrame_GetCode(frame))) {
676 *r_filename = PyUnicode_AsUTF8(code->co_filename);
680 if (r_filename && *r_filename ==
nullptr) {
683 PyObject *mod_name = PyDict_GetItemString(PyEval_GetGlobals(),
"__name__");
685 PyObject *
mod = PyDict_GetItem(PyImport_GetModuleDict(), mod_name);
687 PyObject *mod_file = PyModule_GetFilenameObject(
mod);
689 *r_filename = PyUnicode_AsUTF8(mod_name);
698 if (*r_filename ==
nullptr) {
699 *r_filename = PyUnicode_AsUTF8(mod_name);
705 *r_lineno = PyFrame_GetLineNumber(frame);
735 for (
i = 0;
i < n;
i++) {
736 attr = va_arg(vargs,
char *);
737 item = PyObject_GetAttrString(item, attr);
764 ret = PyFrozenSet_New(
nullptr);
767 PyObject *py_str = PyUnicode_FromString(*
str);
768 PySet_Add(
ret, py_str);
783 PyObject *error_value_as_unicode =
nullptr;
785 if (PyErr_Occurred()) {
786 PyObject *error_type, *error_value, *error_traceback;
787 PyErr_Fetch(&error_type, &error_value, &error_traceback);
789 if (PyUnicode_Check(error_value)) {
790 error_value_as_unicode = error_value;
791 Py_INCREF(error_value_as_unicode);
794 error_value_as_unicode = PyUnicode_FromFormat(
795 "%.200s(%S)", Py_TYPE(error_value)->tp_name, error_value);
797 PyErr_Restore(error_type, error_value, error_traceback);
803 PyObject *error_value_format = PyUnicode_FromFormatV(
format, args);
806 if (error_value_as_unicode) {
807 if (error_value_format) {
808 PyObject *error_value_format_prev = error_value_format;
809 error_value_format = PyUnicode_FromFormat(
810 "%S, %S", error_value_format, error_value_as_unicode);
811 Py_DECREF(error_value_format_prev);
815 error_value_format = PyUnicode_FromFormat(
"(internal error), %S", error_value_as_unicode);
817 Py_DECREF(error_value_as_unicode);
820 PyErr_SetObject(exception_type_prefix, error_value_format);
821 Py_XDECREF(error_value_format);
835 PyCodeObject *f_code = (PyCodeObject *)PyFunction_GET_CODE(py_func);
841 "File \"%s\", line %d, in %s\n",
842 PyUnicode_AsUTF8(f_code->co_filename),
843 f_code->co_firstlineno,
844 PyUnicode_AsUTF8(((PyFunctionObject *)py_func)->func_name));
871 if (!PyErr_ExceptionMatches(PyExc_SystemExit)) {
876 if (_Py_GetConfig()->inspect) {
904 PyObject *
result =
nullptr;
906 PyObject *error_type, *error_value, *error_traceback;
907 PyErr_Fetch(&error_type, &error_value, &error_traceback);
911 PyErr_NormalizeException(&error_type, &error_value, &error_traceback);
914 PyObject *string_io =
nullptr;
915 PyObject *string_io_mod =
nullptr;
916 PyObject *string_io_getvalue =
nullptr;
917 if ((string_io_mod = PyImport_ImportModule(
"io")) &&
918 (string_io = PyObject_CallMethod(string_io_mod,
"StringIO",
nullptr)) &&
919 (string_io_getvalue = PyObject_GetAttrString(string_io,
"getvalue")))
921 PyObject *stderr_backup = PySys_GetObject(
"stderr");
923 Py_INCREF(stderr_backup);
924 PySys_SetObject(
"stderr", string_io);
926 PyErr_Display(error_type, error_value, error_traceback);
928 result = PyObject_CallObject(string_io_getvalue,
nullptr);
929 PySys_SetObject(
"stderr", stderr_backup);
930 Py_DECREF(stderr_backup);
933 PySys_WriteStderr(
"Internal error creating: io.StringIO()!\n");
937 PyErr_Display(error_type, error_value, error_traceback);
940 Py_XDECREF(string_io_mod);
941 Py_XDECREF(string_io_getvalue);
942 Py_XDECREF(string_io);
945 result = PyObject_Str(error_value);
948 result = PyUnicode_FromFormat(
"<unprintable %s object>", Py_TYPE(error_value)->tp_name);
952 PyErr_Restore(error_type, error_value, error_traceback);
964 PyObject *
result =
nullptr;
966 PyObject *error_type, *error_value, *error_traceback;
968 PyErr_Fetch(&error_type, &error_value, &error_traceback);
970 if (PyErr_GivenExceptionMatches(error_type, PyExc_SyntaxError)) {
974 if (PyTuple_CheckExact(error_value) && PyTuple_GET_SIZE(error_value) >= 1) {
975 result = PyObject_Str(PyTuple_GET_ITEM(error_value, 0));
980 result = PyObject_Str(error_value);
983 result = PyUnicode_FromFormat(
"<unprintable %s object>", Py_TYPE(error_value)->tp_name);
987 PyErr_Restore(error_type, error_value, error_traceback);
1004 result = PyUnicode_AsUTF8AndSize(py_str, r_size);
1014 if (PyBytes_Check(py_str)) {
1015 *r_size = PyBytes_GET_SIZE(py_str);
1016 return PyBytes_AS_STRING(py_str);
1018 if ((*r_coerce = PyUnicode_EncodeFSDefault(py_str))) {
1019 *r_size = PyBytes_GET_SIZE(*r_coerce);
1020 return PyBytes_AS_STRING(*r_coerce);
1031 result = PyUnicode_AsUTF8(py_str);
1041 if (PyBytes_Check(py_str)) {
1042 return PyBytes_AS_STRING(py_str);
1044 if ((*r_coerce = PyUnicode_EncodeFSDefault(py_str))) {
1045 return PyBytes_AS_STRING(*r_coerce);
1082 Py_CLEAR(
data->value_coerce);
1088 if (
data->value ==
nullptr) {
1093 return data->value_coerce ? Py_CLEANUP_SUPPORTED : 1;
1115 PyObject *modules = PyImport_GetModuleDict();
1116 PyObject *builtins = PyEval_GetBuiltins();
1117 PyObject *mod_main = PyModule_New(
"__main__");
1118 PyDict_SetItemString(modules,
"__main__", mod_main);
1119 Py_DECREF(mod_main);
1120 PyModule_AddStringConstant(mod_main,
"__name__",
"__main__");
1126 PyModule_AddObjectRef(mod_main,
"__builtins__", builtins);
1128 return PyModule_GetDict(mod_main);
1133 for (
int i = 0; imports[
i];
i++) {
1134 PyObject *name = PyUnicode_FromString(imports[
i]);
1135 PyObject *
mod = PyImport_ImportModuleLevelObject(name,
nullptr,
nullptr,
nullptr, 0);
1138 PyDict_SetItem(py_dict, name,
mod);
1153 PyObject *modules = PyImport_GetModuleDict();
1154 PyObject *main_mod = PyDict_GetItemString(modules,
"__main__");
1158 Py_INCREF(main_mod);
1165 PyObject *modules = PyImport_GetModuleDict();
1167 PyDict_SetItemString(modules,
"__main__", main_mod);
1168 Py_DECREF(main_mod);
1171 PyDict_DelItemString(modules,
"__main__");
1178 return (PyThreadState_GetDict() !=
nullptr);
1192 FILE *fp = fopen(filepath,
"r");
1195 const PyGILState_STATE gilstate = PyGILState_Ensure();
1199 Py_ssize_t *sizes =
static_cast<Py_ssize_t *
>(PyMem_MALLOC(
sizeof(*sizes) * (n / 2)));
1203 PyObject *values = PyList_New(n / 2);
1205 PyObject *py_result, *
ret;
1207 PyObject *struct_mod = PyImport_ImportModule(
"struct");
1208 PyObject *calcsize = PyObject_GetAttrString(struct_mod,
"calcsize");
1209 PyObject *pack = PyObject_GetAttrString(struct_mod,
"pack");
1210 PyObject *unpack = PyObject_GetAttrString(struct_mod,
"unpack");
1212 Py_DECREF(struct_mod);
1215 for (
i = 0;
i * 2 < n;
i++) {
1216 const char *
format = va_arg(vargs,
char *);
1217 void *
ptr = va_arg(vargs,
void *);
1219 ret = PyObject_CallFunction(calcsize,
"s",
format);
1222 sizes[
i] = PyLong_AsLong(
ret);
1224 ret = PyObject_CallFunction(unpack,
"sy#",
format, (
char *)
ptr, sizes[
i]);
1227 if (
ret ==
nullptr) {
1228 printf(
"%s error, line:%d\n", __func__, __LINE__);
1232 PyList_SET_ITEM(values,
i, Py_NewRef(Py_None));
1237 if (PyTuple_GET_SIZE(
ret) == 1) {
1239 PyObject *tmp = PyTuple_GET_ITEM(
ret, 0);
1245 PyList_SET_ITEM(values,
i,
ret);
1251 PyDict_SetItemString(py_dict,
"values", values);
1254 py_result = PyRun_File(fp, filepath, Py_file_input, py_dict, py_dict);
1262 values = PyDict_GetItemString(py_dict,
"values");
1264 if (values && PyList_Check(values)) {
1267 Py_DECREF(py_result);
1268 py_result =
nullptr;
1272 for (
i = 0;
i * 2 < n;
i++) {
1273 const char *
format = va_arg(vargs,
char *);
1274 void *
ptr = va_arg(vargs,
void *);
1279 item = PyList_GET_ITEM(values,
i);
1280 if (PyTuple_CheckExact(item)) {
1281 int ofs = PyTuple_GET_SIZE(item);
1282 item_new = PyTuple_New(ofs + 1);
1284 PyObject *member = PyTuple_GET_ITEM(item, ofs);
1285 PyTuple_SET_ITEM(item_new, ofs + 1, member);
1289 PyTuple_SET_ITEM(item_new, 0, PyUnicode_FromString(
format));
1292 item_new = Py_BuildValue(
"sO",
format, item);
1295 ret = PyObject_Call(pack, item_new,
nullptr);
1299 memcpy(
ptr, PyBytes_AS_STRING(
ret), sizes[
i]);
1303 printf(
"%s error on arg '%d', line:%d\n", __func__,
i, __LINE__);
1309 Py_DECREF(item_new);
1314 printf(
"%s error, 'values' not a list, line:%d\n", __func__, __LINE__);
1318 printf(
"%s error line:%d\n", __func__, __LINE__);
1323 Py_DECREF(calcsize);
1329 PyGILState_Release(gilstate);
1332 fprintf(stderr,
"%s: '%s' missing\n", __func__, filepath);
1338 PyObject *as_pointer;
1341 if (
STREQ(Py_TYPE(value)->tp_name, type_name) &&
1342 (as_pointer = PyObject_GetAttrString(value,
"as_pointer")) !=
nullptr &&
1343 PyCallable_Check(as_pointer))
1348 pointer = PyObject_CallObject(as_pointer,
nullptr);
1349 Py_DECREF(as_pointer);
1352 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1355 result = PyLong_AsVoidPtr(pointer);
1358 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1364 PyErr_Format(PyExc_TypeError,
1365 "expected '%.200s' type found '%.200s' instead",
1367 Py_TYPE(value)->tp_name);
1381 PyObject *py_items = PyList_New(0);
1383 PyList_APPEND(py_items, PyUnicode_FromString(item->
identifier));
1385 PyObject *py_string = PyObject_Repr(py_items);
1386 Py_DECREF(py_items);
1394 *r_value = item->
value;
1403 const char *identifier,
1405 const char *error_prefix)
1410 PyExc_ValueError,
"%s: '%.200s' not found in (%U)", error_prefix, identifier, enum_str);
1411 Py_DECREF(enum_str);
1421 const char *error_prefix)
1426 if (!PySet_Check(value)) {
1427 PyErr_Format(PyExc_TypeError,
1428 "%.200s expected a set, not %.200s",
1430 Py_TYPE(value)->tp_name);
1436 if (PySet_GET_SIZE(value) > 0) {
1437 PyObject *it = PyObject_GetIter(value);
1439 while ((key = PyIter_Next(it))) {
1443 const char *param = PyUnicode_AsUTF8(key);
1444 if (param ==
nullptr) {
1445 PyErr_Format(PyExc_TypeError,
1446 "%.200s set must contain strings, not %.200s",
1448 Py_TYPE(key)->tp_name);
1459 if (key !=
nullptr) {
1470 PyObject *
ret = PySet_New(
nullptr);
1475 pystr = PyUnicode_FromString(items->
identifier);
1476 PySet_Add(
ret, pystr);
1491 const char *imports_star[],
1493 const char *filename)
1496 const
char *imports_star[],
1498 const
char *filename)
1505 for (
int i = 0; imports_star[
i];
i++) {
1506 PyObject *
mod = PyImport_ImportModule(
"math");
1509 PyDict_Merge(py_dict, PyModule_GetDict(
mod), 0);
1524 retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict);
1534 const char *filename,
1538 const char *imports_star[] = {
"math",
nullptr};
1542 if (PyTuple_Check(retval)) {
1545 for (
int i = 0;
i < PyTuple_GET_SIZE(retval);
i++) {
1546 const double val_item = PyFloat_AsDouble(PyTuple_GET_ITEM(retval,
i));
1547 if (val_item == -1 && PyErr_Occurred()) {
1555 val = PyFloat_AsDouble(retval);
1559 if (val == -1 && PyErr_Occurred()) {
1562 else if (!isfinite(val)) {
1580 const char *filename,
1585 const intptr_t val = intptr_t(PyLong_AsVoidPtr(retval));
1586 if (val == 0 && PyErr_Occurred()) {
1605 const char *filename,
1607 size_t *r_value_size)
1612 const char *val = PyUnicode_AsUTF8AndSize(retval, &val_len);
1613 if (val ==
nullptr && PyErr_Occurred()) {
1618 memcpy(val_alloc, val, (
size_t(val_len) + 1) *
sizeof(*val_alloc));
1619 *r_value = val_alloc;
1620 *r_value_size = val_len;
1634 const char *filename,
1643 const char *filename,
1645 size_t *r_value_size)
1649 if (retval == Py_None) {
1656 const char *val = PyUnicode_AsUTF8AndSize(retval, &val_len);
1657 if (val ==
nullptr && PyErr_Occurred()) {
1662 memcpy(val_alloc, val, (
size_t(val_len) + 1) *
sizeof(val_alloc));
1663 *r_value = val_alloc;
1664 *r_value_size = val_len;
1679 const char *filename,
1709 PyObject *py_flush = PyUnicode_FromString(
"flush");
1711 for (
const char *name : {
"stdout",
"stderr"}) {
1712 PyObject *py_file = PySys_GetObject(name);
1717 PyObject *py_flush_retval = PyObject_CallMethodNoArgs(py_file, py_flush);
1718 if (py_flush_retval) {
1719 Py_DECREF(py_flush_retval);
1725 Py_DECREF(py_flush);
1738#if defined(__GNUC__) && !defined(__clang__)
1739# pragma GCC diagnostic push
1740# pragma GCC diagnostic ignored "-Wtype-limits"
1750 if (value ==
nullptr) {
1752 return PyLong_AsUnsignedLong(value);
1755 if (PyLong_Check(value)) {
1756 return PyLong_AsUnsignedLong(value);
1760 PyObject *value_converted = PyNumber_Index(value);
1761 if (value_converted ==
nullptr) {
1765 ulong to_return = PyLong_AsUnsignedLong(value_converted);
1766 Py_DECREF(value_converted);
1773 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1777 PyErr_SetString(PyExc_TypeError,
"Python number not a bool (0/1)");
1786 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1790 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int8");
1793 return int8_t(test);
1799 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1803 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int16");
1806 return int16_t(test);
1821 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint8");
1824 return uint8_t(test);
1831 return uint16_t(-1);
1834 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint16");
1835 return uint16_t(-1);
1837 return uint16_t(test);
1844 return uint32_t(-1);
1847 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint32");
1848 return uint32_t(-1);
1850 return uint32_t(test);
1855 if (value ==
nullptr) {
1857 return uint64_t(PyLong_AsUnsignedLongLong(value));
1860 if (PyLong_Check(value)) {
1861 return uint64_t(PyLong_AsUnsignedLongLong(value));
1865 PyObject *value_converted = PyNumber_Index(value);
1866 if (value_converted ==
nullptr) {
1872 Py_DECREF(value_converted);
1876#if defined(__GNUC__) && !defined(__clang__)
1877# pragma GCC diagnostic pop
1888 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)
Read Guarded memory(de)allocation.
BMesh const char void * data
ATTR_WARN_UNUSED_RESULT const BMVert const BMEdge * e
unsigned long long int uint64_t
static DBVT_INLINE btScalar size(const btDbvtVolume &a)
VecBase< float, D > constexpr mod(VecOp< float, D >, VecOp< float, D >) RET
float length(VecOp< float, D >) RET
void * MEM_malloc_arrayN(size_t len, size_t size, 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)