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
44 const size_t array_item_size,
47 const PyTypeObject *type,
48 const char *error_prefix)
50 const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast);
51 PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast);
54 BLI_assert(PyList_Check(value_fast) || PyTuple_Check(value_fast));
57 PyErr_Format(PyExc_TypeError,
58 "%.200s: invalid sequence length. expected %d, got %d",
66 if (type == &PyFloat_Type) {
67 switch (array_item_size) {
68 case sizeof(double): {
69 double *array_double =
static_cast<double *
>(
array);
71 array_double[
i] = PyFloat_AsDouble(value_fast_items[
i]);
76 float *array_float =
static_cast<float *
>(
array);
78 array_float[
i] = PyFloat_AsDouble(value_fast_items[
i]);
88 else if (type == &PyLong_Type) {
89 switch (array_item_size) {
93 array_int[
i] = PyC_Long_AsI64(value_fast_items[
i]);
100 array_int[
i] = PyC_Long_AsI32(value_fast_items[
i]);
104 case sizeof(int16_t): {
105 int16_t *array_int =
static_cast<int16_t *
>(
array);
111 case sizeof(int8_t): {
112 int8_t *array_int =
static_cast<int8_t *
>(
array);
124 else if (type == &PyBool_Type) {
125 switch (array_item_size) {
129 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
136 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
140 case sizeof(int16_t): {
141 int16_t *array_bool =
static_cast<int16_t *
>(
array);
143 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
147 case sizeof(int8_t): {
148 int8_t *array_bool =
static_cast<int8_t *
>(
array);
150 array_bool[
i] = (PyLong_AsLong(value_fast_items[
i]) != 0);
161 PyErr_Format(PyExc_TypeError,
"%s: internal error %s is invalid", error_prefix, type->tp_name);
165 if (PyErr_Occurred()) {
166 PyErr_Format(PyExc_TypeError,
167 "%s: one or more items could not be used as a %s",
177 const size_t array_item_size,
180 const PyTypeObject *type,
181 const char *error_prefix)
183 PyObject *value_fast;
186 if (!(value_fast = PySequence_Fast(value, error_prefix))) {
196 const size_t array_item_size,
200 const PyTypeObject *type,
201 const char *error_prefix);
204 const size_t array_item_size,
205 PyObject *value_fast,
208 const PyTypeObject *type,
209 const char *error_prefix)
211 const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast);
212 const int length = dims[0];
222 if (value_len !=
length) {
223 PyErr_Format(PyExc_TypeError,
224 "%.200s: invalid sequence length. expected %d, got %d",
231 PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast);
232 const int *dims_next = dims + 1;
233 const int dims_next_len = dims_len - 1;
252 const size_t array_item_size,
256 const PyTypeObject *type,
257 const char *error_prefix)
259 PyObject *value_fast;
262 if (!(value_fast = PySequence_Fast(value, error_prefix))) {
267 array_p, array_item_size, value_fast, dims, dims_len, type, error_prefix);
273 const size_t array_item_size,
274 PyObject *value_fast,
277 const PyTypeObject *type,
278 const char *error_prefix)
281 &
array, array_item_size, value_fast, dims, dims_len, type, error_prefix);
285 const size_t array_item_size,
289 const PyTypeObject *type,
290 const char *error_prefix)
293 &
array, array_item_size, value, dims, dims_len, type, error_prefix);
307 PyObject *tuple = PyTuple_New(
len);
309 PyTuple_SET_ITEM(tuple,
i, PyFloat_FromDouble(
array[
i]));
316 PyObject *tuple = PyTuple_New(
len);
318 PyTuple_SET_ITEM(tuple,
i, PyFloat_FromDouble(
array[
i]));
325 PyObject *tuple = PyTuple_New(
len);
327 PyTuple_SET_ITEM(tuple,
i, PyLong_FromLong(
array[
i]));
334 PyObject *tuple = PyTuple_New(
len);
336 PyTuple_SET_ITEM(tuple,
i, PyBool_FromLong(
array[
i]));
343 PyObject *tuple = PyTuple_New(
len);
345 PyTuple_SET_ITEM(tuple,
i, PyBool_FromLong(
array[
i]));
353 PyObject *tuple = PyTuple_New(
len);
355 if (PyObject *value = PyUnicode_FromString(
array[
i])) {
356 PyTuple_SET_ITEM(tuple,
i, value);
377 const int len = dims[0];
380 *array_p = (*array_p) +
len;
383 PyObject *tuple = PyTuple_New(dims[0]);
384 const int *dims_next = dims + 1;
385 const int dims_next_len = dims_len - 1;
401 const int len = dims[0];
404 *array_p = (*array_p) +
len;
407 PyObject *tuple = PyTuple_New(dims[0]);
408 const int *dims_next = dims + 1;
409 const int dims_next_len = dims_len - 1;
425 const int len = dims[0];
428 *array_p = (*array_p) +
len;
431 PyObject *tuple = PyTuple_New(dims[0]);
432 const int *dims_next = dims + 1;
433 const int dims_next_len = dims_len - 1;
449 const int len = dims[0];
452 *array_p = (*array_p) +
len;
455 PyObject *tuple = PyTuple_New(dims[0]);
456 const int *dims_next = dims + 1;
457 const int dims_next_len = dims_len - 1;
477 const uint tot = PyTuple_GET_SIZE(tuple);
480 for (
i = 0;
i < tot;
i++) {
481 PyTuple_SET_ITEM(tuple,
i, value);
488 const uint tot = PyList_GET_SIZE(list);
491 for (
i = 0;
i < tot;
i++) {
492 PyList_SET_ITEM(list,
i, value);
505 bool *bool_p =
static_cast<bool *
>(p);
507 if (((value = PyLong_AsLong(o)) == -1) || !
ELEM(value, 0, 1)) {
508 PyErr_Format(PyExc_ValueError,
"expected a bool or int (0/1), got %s", Py_TYPE(o)->tp_name);
512 *bool_p = value ?
true :
false;
519 const char *value = PyUnicode_AsUTF8(o);
520 if (value ==
nullptr) {
521 PyErr_Format(PyExc_ValueError,
"expected a string, got %s", Py_TYPE(o)->tp_name);
525 for (
i = 0;
e->items[
i].id;
i++) {
526 if (
STREQ(
e->items[
i].id, value)) {
527 e->value_found =
e->items[
i].value;
535 PyObject *enum_items = PyTuple_New(
i);
536 for (
i = 0;
e->items[
i].id;
i++) {
537 PyTuple_SET_ITEM(enum_items,
i, PyUnicode_FromString(
e->items[
i].id));
539 PyErr_Format(PyExc_ValueError,
"expected a string in %S, got '%s'", enum_items, value);
546 for (
int i = 0; items[
i].
id;
i++) {
547 if (items[
i].value == value) {
556 PyObject *dummy_pydict;
557 return PyArg_ParseTuple(args,
"|O!:__deepcopy__", &PyDict_Type, &dummy_pydict) != 0;
562#ifndef MATH_STANDALONE
572 const char *null_str =
"<null>";
573 fprintf(stderr,
"<%s> : ",
name);
574 if (var ==
nullptr) {
575 fprintf(stderr,
"%s\n", null_str);
578 PyObject_Print(var, stderr, 0);
579 const PyTypeObject *type = Py_TYPE(var);
581 " ref:%d, ptr:%p, type: %s\n",
584 type ? type->tp_name : null_str);
591 const char *null_str =
"<null>";
592 if (var ==
nullptr) {
596 const PyTypeObject *type = Py_TYPE(var);
597 PyObject *var_str = PyObject_Repr(var);
598 if (var_str ==
nullptr) {
605 " ref=%d, ptr=%p, type=%s, value=%.200s",
608 type ? type->tp_name : null_str,
609 var_str ? PyUnicode_AsUTF8(var_str) :
"<error>");
610 if (var_str !=
nullptr) {
619 const char *filename;
624 fprintf(stderr,
"Python line lookup failed, interpreter inactive\n");
631 fprintf(stderr,
"%s:%d\n", filename, lineno);
638 fprintf(stderr,
"Python line lookup failed, interpreter inactive\n");
643 const PyGILState_STATE gilstate = PyGILState_Ensure();
644 PyRun_SimpleString(
"__import__('traceback').print_stack()");
645 PyGILState_Release(gilstate);
656 PyFrameObject *frame;
660 *r_filename =
nullptr;
666 if (!(frame = PyEval_GetFrame())) {
669 if (!(code = PyFrame_GetCode(frame))) {
675 *r_filename = PyUnicode_AsUTF8(code->co_filename);
679 if (r_filename && *r_filename ==
nullptr) {
682 PyObject *mod_name = PyDict_GetItemString(PyEval_GetGlobals(),
"__name__");
684 PyObject *
mod = PyDict_GetItem(PyImport_GetModuleDict(), mod_name);
686 PyObject *mod_file = PyModule_GetFilenameObject(
mod);
688 *r_filename = PyUnicode_AsUTF8(mod_name);
697 if (*r_filename ==
nullptr) {
698 *r_filename = PyUnicode_AsUTF8(mod_name);
704 *r_lineno = PyFrame_GetLineNumber(frame);
734 for (
i = 0;
i < n;
i++) {
735 attr = va_arg(vargs,
char *);
736 item = PyObject_GetAttrString(item, attr);
763 ret = PyFrozenSet_New(
nullptr);
766 PyObject *py_str = PyUnicode_FromString(*
str);
767 PySet_Add(
ret, py_str);
782 PyObject *error_value_as_unicode =
nullptr;
784 if (PyErr_Occurred()) {
785 PyObject *error_type, *error_value, *error_traceback;
786 PyErr_Fetch(&error_type, &error_value, &error_traceback);
788 if (PyUnicode_Check(error_value)) {
789 error_value_as_unicode = error_value;
790 Py_INCREF(error_value_as_unicode);
793 error_value_as_unicode = PyUnicode_FromFormat(
794 "%.200s(%S)", Py_TYPE(error_value)->tp_name, error_value);
796 PyErr_Restore(error_type, error_value, error_traceback);
802 PyObject *error_value_format = PyUnicode_FromFormatV(
format, args);
805 if (error_value_as_unicode) {
806 if (error_value_format) {
807 PyObject *error_value_format_prev = error_value_format;
808 error_value_format = PyUnicode_FromFormat(
809 "%S, %S", error_value_format, error_value_as_unicode);
814 error_value_format = PyUnicode_FromFormat(
"(internal error), %S", error_value_as_unicode);
819 PyErr_SetObject(exception_type_prefix, error_value_format);
820 Py_XDECREF(error_value_format);
834 PyCodeObject *f_code = (PyCodeObject *)PyFunction_GET_CODE(py_func);
839 "File \"%s\", line %d, in %s\n",
840 PyUnicode_AsUTF8(f_code->co_filename),
841 f_code->co_firstlineno,
842 PyUnicode_AsUTF8(((PyFunctionObject *)py_func)->func_name));
869 if (!PyErr_ExceptionMatches(PyExc_SystemExit)) {
874 if (_Py_GetConfig()->inspect) {
902 PyObject *
result =
nullptr;
904 PyObject *error_type, *error_value, *error_traceback;
905 PyErr_Fetch(&error_type, &error_value, &error_traceback);
909 PyErr_NormalizeException(&error_type, &error_value, &error_traceback);
912 PyObject *string_io =
nullptr;
913 PyObject *string_io_mod =
nullptr;
914 PyObject *string_io_getvalue =
nullptr;
915 if ((string_io_mod = PyImport_ImportModule(
"io")) &&
916 (string_io = PyObject_CallMethod(string_io_mod,
"StringIO",
nullptr)) &&
917 (string_io_getvalue = PyObject_GetAttrString(string_io,
"getvalue")))
919 PyObject *stderr_backup = PySys_GetObject(
"stderr");
921 Py_INCREF(stderr_backup);
922 PySys_SetObject(
"stderr", string_io);
924 PyErr_Display(error_type, error_value, error_traceback);
926 result = PyObject_CallObject(string_io_getvalue,
nullptr);
927 PySys_SetObject(
"stderr", stderr_backup);
931 PySys_WriteStderr(
"Internal error creating: io.StringIO()!\n");
935 PyErr_Display(error_type, error_value, error_traceback);
938 Py_XDECREF(string_io_mod);
939 Py_XDECREF(string_io_getvalue);
940 Py_XDECREF(string_io);
943 result = PyObject_Str(error_value);
946 result = PyUnicode_FromFormat(
"<unprintable %s object>", Py_TYPE(error_value)->tp_name);
950 PyErr_Restore(error_type, error_value, error_traceback);
962 PyObject *
result =
nullptr;
964 PyObject *error_type, *error_value, *error_traceback;
966 PyErr_Fetch(&error_type, &error_value, &error_traceback);
968 if (PyErr_GivenExceptionMatches(error_type, PyExc_SyntaxError)) {
972 if (PyTuple_CheckExact(error_value) && PyTuple_GET_SIZE(error_value) >= 1) {
973 result = PyObject_Str(PyTuple_GET_ITEM(error_value, 0));
978 result = PyObject_Str(error_value);
981 result = PyUnicode_FromFormat(
"<unprintable %s object>", Py_TYPE(error_value)->tp_name);
985 PyErr_Restore(error_type, error_value, error_traceback);
1002 result = PyUnicode_AsUTF8AndSize(py_str, r_size);
1012 if (PyBytes_Check(py_str)) {
1013 *r_size = PyBytes_GET_SIZE(py_str);
1014 return PyBytes_AS_STRING(py_str);
1016 if ((*r_coerce = PyUnicode_EncodeFSDefault(py_str))) {
1017 *r_size = PyBytes_GET_SIZE(*r_coerce);
1018 return PyBytes_AS_STRING(*r_coerce);
1029 result = PyUnicode_AsUTF8(py_str);
1039 if (PyBytes_Check(py_str)) {
1040 return PyBytes_AS_STRING(py_str);
1042 if ((*r_coerce = PyUnicode_EncodeFSDefault(py_str))) {
1043 return PyBytes_AS_STRING(*r_coerce);
1080 Py_CLEAR(
data->value_coerce);
1086 if (
data->value ==
nullptr) {
1091 return data->value_coerce ? Py_CLEANUP_SUPPORTED : 1;
1113 PyObject *modules = PyImport_GetModuleDict();
1114 PyObject *builtins = PyEval_GetBuiltins();
1115 PyObject *mod_main = PyModule_New(
"__main__");
1116 PyDict_SetItemString(modules,
"__main__", mod_main);
1118 PyModule_AddStringConstant(mod_main,
"__name__",
"__main__");
1124 PyModule_AddObjectRef(mod_main,
"__builtins__", builtins);
1126 return PyModule_GetDict(mod_main);
1131 for (
int i = 0; imports[
i];
i++) {
1132 PyObject *
name = PyUnicode_FromString(imports[
i]);
1133 PyObject *
mod = PyImport_ImportModuleLevelObject(
name,
nullptr,
nullptr,
nullptr, 0);
1136 PyDict_SetItem(py_dict,
name,
mod);
1151 PyObject *modules = PyImport_GetModuleDict();
1152 PyObject *main_mod = PyDict_GetItemString(modules,
"__main__");
1156 Py_INCREF(main_mod);
1163 PyObject *modules = PyImport_GetModuleDict();
1165 PyDict_SetItemString(modules,
"__main__", main_mod);
1169 PyDict_DelItemString(modules,
"__main__");
1176 return (PyThreadState_GetDict() !=
nullptr);
1190 FILE *fp = fopen(filepath,
"r");
1193 const PyGILState_STATE gilstate = PyGILState_Ensure();
1197 Py_ssize_t *sizes =
static_cast<Py_ssize_t *
>(PyMem_MALLOC(
sizeof(*sizes) * (n / 2)));
1201 PyObject *values = PyList_New(n / 2);
1203 PyObject *py_result, *
ret;
1205 PyObject *struct_mod = PyImport_ImportModule(
"struct");
1206 PyObject *calcsize = PyObject_GetAttrString(struct_mod,
"calcsize");
1207 PyObject *pack = PyObject_GetAttrString(struct_mod,
"pack");
1208 PyObject *unpack = PyObject_GetAttrString(struct_mod,
"unpack");
1213 for (
i = 0;
i * 2 < n;
i++) {
1214 const char *
format = va_arg(vargs,
char *);
1215 void *
ptr = va_arg(vargs,
void *);
1217 ret = PyObject_CallFunction(calcsize,
"s",
format);
1220 sizes[
i] = PyLong_AsLong(
ret);
1222 ret = PyObject_CallFunction(unpack,
"sy#",
format, (
char *)
ptr, sizes[
i]);
1225 if (
ret ==
nullptr) {
1226 printf(
"%s error, line:%d\n", __func__, __LINE__);
1229 PyList_SET_ITEM(values,
i, Py_NewRef(Py_None));
1234 if (PyTuple_GET_SIZE(
ret) == 1) {
1236 PyObject *tmp = PyTuple_GET_ITEM(
ret, 0);
1242 PyList_SET_ITEM(values,
i,
ret);
1248 PyDict_SetItemString(py_dict,
"values", values);
1251 py_result = PyRun_File(fp, filepath, Py_file_input, py_dict, py_dict);
1259 values = PyDict_GetItemString(py_dict,
"values");
1261 if (values && PyList_Check(values)) {
1265 py_result =
nullptr;
1269 for (
i = 0;
i * 2 < n;
i++) {
1270 const char *
format = va_arg(vargs,
char *);
1271 void *
ptr = va_arg(vargs,
void *);
1276 item = PyList_GET_ITEM(values,
i);
1277 if (PyTuple_CheckExact(item)) {
1278 int ofs = PyTuple_GET_SIZE(item);
1279 item_new = PyTuple_New(ofs + 1);
1281 PyObject *member = PyTuple_GET_ITEM(item, ofs);
1282 PyTuple_SET_ITEM(item_new, ofs + 1, member);
1286 PyTuple_SET_ITEM(item_new, 0, PyUnicode_FromString(
format));
1289 item_new = Py_BuildValue(
"sO",
format, item);
1292 ret = PyObject_Call(pack, item_new,
nullptr);
1296 memcpy(
ptr, PyBytes_AS_STRING(
ret), sizes[
i]);
1300 printf(
"%s error on arg '%d', line:%d\n", __func__,
i, __LINE__);
1310 printf(
"%s error, 'values' not a list, line:%d\n", __func__, __LINE__);
1314 printf(
"%s error line:%d\n", __func__, __LINE__);
1324 PyGILState_Release(gilstate);
1327 fprintf(stderr,
"%s: '%s' missing\n", __func__, filepath);
1333 PyObject *as_pointer;
1336 if (
STREQ(Py_TYPE(value)->tp_name, type_name) &&
1337 (as_pointer = PyObject_GetAttrString(value,
"as_pointer")) !=
nullptr &&
1338 PyCallable_Check(as_pointer))
1343 pointer = PyObject_CallObject(as_pointer,
nullptr);
1347 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1350 result = PyLong_AsVoidPtr(pointer);
1353 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1359 PyErr_Format(PyExc_TypeError,
1360 "expected '%.200s' type found '%.200s' instead",
1362 Py_TYPE(value)->tp_name);
1376 PyObject *py_items = PyList_New(0);
1378 PyList_APPEND(py_items, PyUnicode_FromString(item->
identifier));
1380 PyObject *py_string = PyObject_Repr(py_items);
1389 *r_value = item->
value;
1398 const char *identifier,
1400 const char *error_prefix)
1405 PyExc_ValueError,
"%s: '%.200s' not found in (%U)", error_prefix, identifier, enum_str);
1416 const char *error_prefix)
1421 if (!PySet_Check(value)) {
1422 PyErr_Format(PyExc_TypeError,
1423 "%.200s expected a set, not %.200s",
1425 Py_TYPE(value)->tp_name);
1431 if (PySet_GET_SIZE(value) > 0) {
1432 PyObject *it = PyObject_GetIter(value);
1434 while ((key = PyIter_Next(it))) {
1438 const char *param = PyUnicode_AsUTF8(key);
1439 if (param ==
nullptr) {
1440 PyErr_Format(PyExc_TypeError,
1441 "%.200s set must contain strings, not %.200s",
1443 Py_TYPE(key)->tp_name);
1454 if (key !=
nullptr) {
1465 PyObject *
ret = PySet_New(
nullptr);
1470 pystr = PyUnicode_FromString(items->
identifier);
1471 PySet_Add(
ret, pystr);
1486 const char *imports_star[],
1488 const char *filename)
1491 const char *imports_star[],
1493 const char *filename)
1500 for (
int i = 0; imports_star[
i];
i++) {
1501 PyObject *
mod = PyImport_ImportModule(
"math");
1504 PyDict_Merge(py_dict, PyModule_GetDict(
mod), 0);
1518 retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict);
1528 const char *filename,
1532 const char *imports_star[] = {
"math",
nullptr};
1536 if (PyTuple_Check(retval)) {
1539 for (
int i = 0;
i < PyTuple_GET_SIZE(retval);
i++) {
1540 const double val_item = PyFloat_AsDouble(PyTuple_GET_ITEM(retval,
i));
1541 if (val_item == -1 && PyErr_Occurred()) {
1549 val = PyFloat_AsDouble(retval);
1553 if (val == -1 && PyErr_Occurred()) {
1556 else if (!isfinite(val)) {
1574 const char *filename,
1579 const intptr_t val = intptr_t(PyLong_AsVoidPtr(retval));
1580 if (val == 0 && PyErr_Occurred()) {
1599 const char *filename,
1601 size_t *r_value_size)
1606 const char *val = PyUnicode_AsUTF8AndSize(retval, &val_len);
1607 if (val ==
nullptr && PyErr_Occurred()) {
1612 memcpy(val_alloc, val, (
size_t(val_len) + 1) *
sizeof(*val_alloc));
1613 *r_value = val_alloc;
1614 *r_value_size = val_len;
1628 const char *filename,
1637 const char *filename,
1639 size_t *r_value_size)
1643 if (retval == Py_None) {
1650 const char *val = PyUnicode_AsUTF8AndSize(retval, &val_len);
1651 if (val ==
nullptr && PyErr_Occurred()) {
1656 memcpy(val_alloc, val, (
size_t(val_len) + 1) *
sizeof(val_alloc));
1657 *r_value = val_alloc;
1658 *r_value_size = val_len;
1673 const char *filename,
1703 PyObject *py_flush = PyUnicode_FromString(
"flush");
1705 for (
const char *
name : {
"stdout",
"stderr"}) {
1706 PyObject *py_file = PySys_GetObject(
name);
1711 PyObject *py_flush_retval = PyObject_CallMethodNoArgs(py_file, py_flush);
1712 if (py_flush_retval) {
1732#if defined(__GNUC__) && !defined(__clang__)
1733# pragma GCC diagnostic push
1734# pragma GCC diagnostic ignored "-Wtype-limits"
1744 if (value ==
nullptr) {
1746 return PyLong_AsUnsignedLong(value);
1749 if (PyLong_Check(value)) {
1750 return PyLong_AsUnsignedLong(value);
1754 PyObject *value_converted = PyNumber_Index(value);
1755 if (value_converted ==
nullptr) {
1759 ulong to_return = PyLong_AsUnsignedLong(value_converted);
1767 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1771 PyErr_SetString(PyExc_TypeError,
"Python number not a bool (0/1)");
1780 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1784 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int8");
1787 return int8_t(test);
1793 if (
UNLIKELY(test == -1 && PyErr_Occurred())) {
1797 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int16");
1800 return int16_t(test);
1815 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint8");
1818 return uint8_t(test);
1825 return uint16_t(-1);
1828 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint16");
1829 return uint16_t(-1);
1831 return uint16_t(test);
1838 return uint32_t(-1);
1841 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint32");
1842 return uint32_t(-1);
1844 return uint32_t(test);
1849 if (value ==
nullptr) {
1851 return uint64_t(PyLong_AsUnsignedLongLong(value));
1854 if (PyLong_Check(value)) {
1855 return uint64_t(PyLong_AsUnsignedLongLong(value));
1859 PyObject *value_converted = PyNumber_Index(value);
1860 if (value_converted ==
nullptr) {
1870#if defined(__GNUC__) && !defined(__clang__)
1871# pragma GCC diagnostic pop
1882 switch (typestr[0]) {
#define BLI_assert_unreachable()
#define ATTR_NONNULL(...)
size_t size_t size_t BLI_snprintf_utf8(char *__restrict dst, size_t dst_maxncpy, const char *__restrict format,...) ATTR_NONNULL(1
char * BLI_strncpy_utf8(char *__restrict dst, const char *__restrict src, size_t dst_maxncpy) 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)
static PyObject * pyc_run_string_as_py_object(const char *imports[], const char *imports_star[], const char *expr, const char *filename) ATTR_NONNULL(3
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)
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)