29 #define PY_SSIZE_T_CLEAN
32 #include <frameobject.h>
40 #ifndef MATH_STANDALONE
62 const PyTypeObject *
type,
64 const char *error_prefix)
66 const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast);
67 PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast);
70 BLI_assert(PyList_Check(value_fast) || PyTuple_Check(value_fast));
73 PyErr_Format(PyExc_TypeError,
74 "%.200s: invalid sequence length. expected %d, got %d",
82 if (
type == &PyFloat_Type) {
84 double *array_double =
array;
85 for (i = 0; i <
length; i++) {
86 array_double[i] = PyFloat_AsDouble(value_fast_items[i]);
90 float *array_float =
array;
91 for (i = 0; i <
length; i++) {
92 array_float[i] = PyFloat_AsDouble(value_fast_items[i]);
96 else if (
type == &PyLong_Type) {
98 int *array_int =
array;
99 for (i = 0; i <
length; i++) {
100 array_int[i] = PyC_Long_AsI32(value_fast_items[i]);
103 else if (
type == &PyBool_Type) {
104 bool *array_bool =
array;
105 for (i = 0; i <
length; i++) {
106 array_bool[i] = (PyLong_AsLong(value_fast_items[i]) != 0);
110 PyErr_Format(PyExc_TypeError,
"%s: internal error %s is invalid", error_prefix,
type->tp_name);
114 if (PyErr_Occurred()) {
115 PyErr_Format(PyExc_TypeError,
116 "%s: one or more items could not be used as a %s",
128 const PyTypeObject *
type,
129 const bool is_double,
130 const char *error_prefix)
132 PyObject *value_fast;
135 if (!(value_fast = PySequence_Fast(value, error_prefix))) {
140 Py_DECREF(value_fast);
155 PyObject *tuple = PyTuple_New(
len);
156 for (
uint i = 0; i <
len; i++) {
157 PyTuple_SET_ITEM(tuple, i, PyFloat_FromDouble(
array[i]));
164 PyObject *tuple = PyTuple_New(
len);
165 for (
uint i = 0; i <
len; i++) {
166 PyTuple_SET_ITEM(tuple, i, PyFloat_FromDouble(
array[i]));
173 PyObject *tuple = PyTuple_New(
len);
174 for (
uint i = 0; i <
len; i++) {
175 PyTuple_SET_ITEM(tuple, i, PyLong_FromLong(
array[i]));
182 PyObject *tuple = PyTuple_New(
len);
183 for (
uint i = 0; i <
len; i++) {
184 PyTuple_SET_ITEM(tuple, i, PyBool_FromLong(
array[i]));
191 PyObject *tuple = PyTuple_New(
len);
192 for (
uint i = 0; i <
len; i++) {
193 PyTuple_SET_ITEM(tuple, i, PyBool_FromLong(
array[i]));
210 const uint tot = PyTuple_GET_SIZE(tuple);
213 for (i = 0; i < tot; i++) {
214 PyTuple_SET_ITEM(tuple, i, value);
221 const uint tot = PyList_GET_SIZE(list);
224 for (i = 0; i < tot; i++) {
225 PyList_SET_ITEM(list, i, value);
245 if (((value = PyLong_AsLong(o)) == -1) || !
ELEM(value, 0, 1)) {
246 PyErr_Format(PyExc_ValueError,
"expected a bool or int (0/1), got %s", Py_TYPE(o)->tp_name);
250 *bool_p = value ? true :
false;
260 const char *value = PyUnicode_AsUTF8(o);
262 PyErr_Format(PyExc_ValueError,
"expected a string, got %s", Py_TYPE(o)->tp_name);
266 for (i = 0;
e->items[i].id; i++) {
267 if (
STREQ(
e->items[i].id, value)) {
268 e->value_found =
e->items[i].value;
276 PyObject *enum_items = PyTuple_New(i);
277 for (i = 0;
e->items[i].id; i++) {
278 PyTuple_SET_ITEM(enum_items, i, PyUnicode_FromString(
e->items[i].id));
280 PyErr_Format(PyExc_ValueError,
"expected a string in %S, got '%s'", enum_items, value);
281 Py_DECREF(enum_items);
288 for (
int i = 0;
items[i].
id; i++) {
289 if (
items[i].value == value) {
299 PyObject *dummy_pydict;
300 return PyArg_ParseTuple(args,
"|O!:__deepcopy__", &PyDict_Type, &dummy_pydict) != 0;
305 #ifndef MATH_STANDALONE
316 const char *null_str =
"<null>";
317 fprintf(stderr,
"<%s> : ", name);
319 fprintf(stderr,
"%s\n", null_str);
322 PyObject_Print(var, stderr, 0);
323 const PyTypeObject *
type = Py_TYPE(var);
325 " ref:%d, ptr:%p, type: %s\n",
339 const char *null_str =
"<null>";
344 const PyTypeObject *
type = Py_TYPE(var);
345 PyObject *var_str = PyObject_Repr(var);
346 if (var_str ==
NULL) {
353 " ref=%d, ptr=%p, type=%s, value=%.200s",
357 var_str ? PyUnicode_AsUTF8(var_str) :
"<error>");
358 if (var_str !=
NULL) {
367 const char *filename;
372 fprintf(stderr,
"python line lookup failed, interpreter inactive\n");
379 fprintf(stderr,
"%s:%d\n", filename, lineno);
386 fprintf(stderr,
"python line lookup failed, interpreter inactive\n");
391 const PyGILState_STATE gilstate = PyGILState_Ensure();
392 PyRun_SimpleString(
"__import__('traceback').print_stack()");
393 PyGILState_Release(gilstate);
404 PyFrameObject *frame;
413 if (!(frame = PyThreadState_GET()->frame)) {
419 *r_filename = PyUnicode_AsUTF8(frame->f_code->co_filename);
423 if (r_filename && *r_filename ==
NULL) {
426 PyObject *mod_name = PyDict_GetItemString(PyEval_GetGlobals(),
"__name__");
428 PyObject *
mod = PyDict_GetItem(PyImport_GetModuleDict(), mod_name);
430 PyObject *mod_file = PyModule_GetFilenameObject(
mod);
432 *r_filename = PyUnicode_AsUTF8(mod_name);
441 if (*r_filename ==
NULL) {
442 *r_filename = PyUnicode_AsUTF8(mod_name);
448 *r_lineno = PyFrame_GetLineNumber(frame);
477 for (i = 0; i < n; i++) {
478 attr = va_arg(vargs,
char *);
479 item = PyObject_GetAttrString(item, attr);
509 PyObject *py_str = PyUnicode_FromString(*
str);
510 PySet_Add(
ret, py_str);
532 PyObject *error_value_prefix;
536 error_value_prefix = PyUnicode_FromFormatV(
format, args);
539 if (PyErr_Occurred()) {
540 PyObject *error_type, *error_value, *error_traceback;
541 PyErr_Fetch(&error_type, &error_value, &error_traceback);
543 if (PyUnicode_Check(error_value)) {
544 PyErr_Format(exception_type_prefix,
"%S, %S", error_value_prefix, error_value);
547 PyErr_Format(exception_type_prefix,
550 Py_TYPE(error_value)->tp_name,
555 PyErr_SetObject(exception_type_prefix, error_value_prefix);
558 Py_XDECREF(error_value_prefix);
576 PyCodeObject *f_code = (PyCodeObject *)PyFunction_GET_CODE(py_func);
582 "File \"%s\", line %d, in %s\n",
583 PyUnicode_AsUTF8(f_code->co_filename),
584 f_code->co_firstlineno,
585 PyUnicode_AsUTF8(((PyFunctionObject *)py_func)->func_name));
595 PyObject *error_value,
596 PyObject *error_traceback)
598 if (!PyErr_GivenExceptionMatches(error_type, PyExc_SystemExit)) {
602 if (_Py_GetConfig()->inspect) {
620 PyErr_Restore(error_type, error_value, error_traceback);
631 PyObject *traceback_mod =
NULL;
632 PyObject *format_tb_func =
NULL;
635 if (!(traceback_mod = PyImport_ImportModule(
"traceback"))) {
638 else if (!(format_tb_func = PyObject_GetAttrString(traceback_mod,
"format_exc"))) {
642 ret = PyObject_CallObject(format_tb_func,
NULL);
644 if (
ret == Py_None) {
651 Py_XDECREF(traceback_mod);
652 Py_XDECREF(format_tb_func);
659 PyObject *stdout_backup = PySys_GetObject(
"stdout");
660 PyObject *stderr_backup = PySys_GetObject(
"stderr");
661 PyObject *string_io =
NULL;
662 PyObject *string_io_buf =
NULL;
663 PyObject *string_io_mod =
NULL;
664 PyObject *string_io_getvalue =
NULL;
666 PyObject *error_type, *error_value, *error_traceback;
668 if (!PyErr_Occurred()) {
672 PyErr_Fetch(&error_type, &error_value, &error_traceback);
682 if (!(string_io_mod = PyImport_ImportModule(
"io"))) {
685 else if (!(string_io = PyObject_CallMethod(string_io_mod,
"StringIO",
NULL))) {
688 else if (!(string_io_getvalue = PyObject_GetAttrString(string_io,
"getvalue"))) {
693 Py_INCREF(stdout_backup);
694 Py_INCREF(stderr_backup);
697 PySys_SetObject(
"stdout", string_io);
698 PySys_SetObject(
"stderr", string_io);
700 PyErr_Restore(error_type, error_value, error_traceback);
704 string_io_buf = PyObject_CallObject(string_io_getvalue,
NULL);
706 PySys_SetObject(
"stdout", stdout_backup);
707 PySys_SetObject(
"stderr", stderr_backup);
709 Py_DECREF(stdout_backup);
710 Py_DECREF(stderr_backup);
712 Py_DECREF(string_io_mod);
713 Py_DECREF(string_io_getvalue);
714 Py_DECREF(string_io);
717 return string_io_buf;
721 Py_XDECREF(string_io_mod);
722 Py_XDECREF(string_io);
724 PyErr_Restore(error_type, error_value, error_traceback);
734 PyObject *string_io_buf =
NULL;
736 PyObject *error_type, *error_value, *error_traceback;
738 if (!PyErr_Occurred()) {
742 PyErr_Fetch(&error_type, &error_value, &error_traceback);
744 if (error_value ==
NULL) {
753 if (PyErr_GivenExceptionMatches(error_type, PyExc_SyntaxError)) {
757 if (PyTuple_CheckExact(error_value) && PyTuple_GET_SIZE(error_value) >= 1) {
758 string_io_buf = PyObject_Str(PyTuple_GET_ITEM(error_value, 0));
762 if (string_io_buf ==
NULL) {
763 string_io_buf = PyObject_Str(error_value);
768 string_io_buf = PyUnicode_FromFormat(
"<unprintable %s object>", Py_TYPE(error_value)->tp_name);
771 PyErr_Restore(error_type, error_value, error_traceback);
774 return string_io_buf;
790 result = PyUnicode_AsUTF8AndSize(py_str,
size);
800 if (PyBytes_Check(py_str)) {
801 *
size = PyBytes_GET_SIZE(py_str);
802 return PyBytes_AS_STRING(py_str);
804 if ((*coerce = PyUnicode_EncodeFSDefault(py_str))) {
805 *
size = PyBytes_GET_SIZE(*coerce);
806 return PyBytes_AS_STRING(*coerce);
817 result = PyUnicode_AsUTF8(py_str);
827 if (PyBytes_Check(py_str)) {
828 return PyBytes_AS_STRING(py_str);
830 if ((*coerce = PyUnicode_EncodeFSDefault(py_str))) {
831 return PyBytes_AS_STRING(*coerce);
878 PyObject *modules = PyImport_GetModuleDict();
879 PyObject *builtins = PyEval_GetBuiltins();
880 PyObject *mod_main = PyModule_New(
"__main__");
881 PyDict_SetItemString(modules,
"__main__", mod_main);
883 PyModule_AddStringConstant(mod_main,
"__name__",
"__main__");
889 PyModule_AddObject(mod_main,
"__builtins__", builtins);
891 return PyModule_GetDict(mod_main);
896 for (
int i = 0; imports[i]; i++) {
897 PyObject *name = PyUnicode_FromString(imports[i]);
898 PyObject *
mod = PyImport_ImportModuleLevelObject(name,
NULL,
NULL, 0, 0);
901 PyDict_SetItem(py_dict, name,
mod);
917 PyObject *modules = PyImport_GetModuleDict();
918 *r_main_mod = PyDict_GetItemString(modules,
"__main__");
919 Py_XINCREF(*r_main_mod);
924 PyObject *modules = PyImport_GetModuleDict();
925 PyDict_SetItemString(modules,
"__main__", main_mod);
926 Py_XDECREF(main_mod);
932 return (PyThreadState_GetDict() !=
NULL);
946 FILE *fp = fopen(filepath,
"r");
949 const PyGILState_STATE gilstate = PyGILState_Ensure();
953 Py_ssize_t *sizes = PyMem_MALLOC(
sizeof(*sizes) * (n / 2));
957 PyObject *values = PyList_New(n / 2);
959 PyObject *py_result, *
ret;
961 PyObject *struct_mod = PyImport_ImportModule(
"struct");
962 PyObject *calcsize = PyObject_GetAttrString(struct_mod,
"calcsize");
963 PyObject *pack = PyObject_GetAttrString(struct_mod,
"pack");
964 PyObject *unpack = PyObject_GetAttrString(struct_mod,
"unpack");
966 Py_DECREF(struct_mod);
969 for (i = 0; i * 2 < n; i++) {
970 const char *
format = va_arg(vargs,
char *);
971 void *
ptr = va_arg(vargs,
void *);
973 ret = PyObject_CallFunction(calcsize,
"s",
format);
976 sizes[i] = PyLong_AsLong(
ret);
978 ret = PyObject_CallFunction(unpack,
"sy#",
format, (
char *)
ptr, sizes[i]);
982 printf(
"%s error, line:%d\n", __func__, __LINE__);
986 PyList_SET_ITEM(values, i, Py_INCREF_RET(Py_None));
991 if (PyTuple_GET_SIZE(
ret) == 1) {
993 PyObject *tmp = PyTuple_GET_ITEM(
ret, 0);
999 PyList_SET_ITEM(values, i,
ret);
1005 PyDict_SetItemString(py_dict,
"values", values);
1008 py_result = PyRun_File(fp, filepath, Py_file_input, py_dict, py_dict);
1016 values = PyDict_GetItemString(py_dict,
"values");
1018 if (values && PyList_Check(values)) {
1021 Py_DECREF(py_result);
1026 for (i = 0; i * 2 < n; i++) {
1027 const char *
format = va_arg(vargs,
char *);
1028 void *
ptr = va_arg(vargs,
void *);
1033 item = PyList_GET_ITEM(values, i);
1034 if (PyTuple_CheckExact(item)) {
1035 int ofs = PyTuple_GET_SIZE(item);
1036 item_new = PyTuple_New(ofs + 1);
1038 PyObject *member = PyTuple_GET_ITEM(item, ofs);
1039 PyTuple_SET_ITEM(item_new, ofs + 1, member);
1043 PyTuple_SET_ITEM(item_new, 0, PyUnicode_FromString(
format));
1046 item_new = Py_BuildValue(
"sO",
format, item);
1049 ret = PyObject_Call(pack, item_new,
NULL);
1053 memcpy(
ptr, PyBytes_AS_STRING(
ret), sizes[i]);
1057 printf(
"%s error on arg '%d', line:%d\n", __func__, i, __LINE__);
1063 Py_DECREF(item_new);
1068 printf(
"%s error, 'values' not a list, line:%d\n", __func__, __LINE__);
1072 printf(
"%s error line:%d\n", __func__, __LINE__);
1077 Py_DECREF(calcsize);
1083 PyGILState_Release(gilstate);
1086 fprintf(stderr,
"%s: '%s' missing\n", __func__, filepath);
1093 PyObject *as_pointer;
1096 if (
STREQ(Py_TYPE(value)->tp_name, type_name) &&
1097 (as_pointer = PyObject_GetAttrString(value,
"as_pointer")) !=
NULL &&
1098 PyCallable_Check(as_pointer)) {
1102 pointer = PyObject_CallObject(as_pointer,
NULL);
1103 Py_DECREF(as_pointer);
1106 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1109 result = PyLong_AsVoidPtr(pointer);
1112 PyErr_SetString(PyExc_SystemError,
"value.as_pointer() failed");
1118 PyErr_Format(PyExc_TypeError,
1119 "expected '%.200s' type found '%.200s' instead",
1121 Py_TYPE(value)->tp_name);
1135 PyObject *py_items = PyList_New(0);
1137 PyList_APPEND(py_items, PyUnicode_FromString(item->
identifier));
1139 PyObject *py_string = PyObject_Repr(py_items);
1140 Py_DECREF(py_items);
1148 *r_value = item->
value;
1157 const char *identifier,
1159 const char *error_prefix)
1164 PyExc_ValueError,
"%s: '%.200s' not found in (%U)", error_prefix, identifier, enum_str);
1165 Py_DECREF(enum_str);
1175 const char *error_prefix)
1182 Py_ssize_t
hash = 0;
1185 if (!PySet_Check(value)) {
1186 PyErr_Format(PyExc_TypeError,
1187 "%.200s expected a set, not %.200s",
1189 Py_TYPE(value)->tp_name);
1195 while (_PySet_NextEntry(value, &
pos, &key, &
hash)) {
1196 const char *param = PyUnicode_AsUTF8(key);
1198 if (param ==
NULL) {
1199 PyErr_Format(PyExc_TypeError,
1200 "%.200s set must contain strings, not %.200s",
1202 Py_TYPE(key)->tp_name);
1219 PyObject *
ret = PySet_New(
NULL);
1224 pystr = PyUnicode_FromString(
items->identifier);
1225 PySet_Add(
ret, pystr);
1246 const char *filename,
1249 PyObject *py_dict, *
mod, *retval;
1251 PyObject *main_mod =
NULL;
1257 mod = PyImport_ImportModule(
"math");
1259 PyDict_Merge(py_dict, PyModule_GetDict(
mod), 0);
1270 else if ((retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict)) ==
NULL) {
1276 if (PyTuple_Check(retval)) {
1282 for (i = 0; i < PyTuple_GET_SIZE(retval); i++) {
1283 const double val_item = PyFloat_AsDouble(PyTuple_GET_ITEM(retval, i));
1284 if (val_item == -1 && PyErr_Occurred()) {
1292 val = PyFloat_AsDouble(retval);
1296 if (val == -1 && PyErr_Occurred()) {
1314 const char *filename,
1317 PyObject *py_dict, *retval;
1319 PyObject *main_mod =
NULL;
1328 else if ((retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict)) ==
NULL) {
1334 val = (
intptr_t)PyLong_AsVoidPtr(retval);
1335 if (val == 0 && PyErr_Occurred()) {
1352 const char *filename,
1354 size_t *r_value_size)
1356 PyObject *py_dict, *retval;
1358 PyObject *main_mod =
NULL;
1367 else if ((retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict)) ==
NULL) {
1374 val = PyUnicode_AsUTF8AndSize(retval, &val_len);
1375 if (val ==
NULL && PyErr_Occurred()) {
1379 char *val_alloc =
MEM_mallocN(val_len + 1, __func__);
1380 memcpy(val_alloc, val, val_len + 1);
1381 *r_value = val_alloc;
1382 *r_value_size = val_len;
1395 const char *filename,
1415 # pragma warning(push)
1416 # pragma GCC diagnostic ignored "-Wtype-limits"
1424 const int test = _PyLong_AsInt(value);
1426 PyErr_SetString(PyExc_TypeError,
"Python number not a bool (0/1)");
1434 const int test = _PyLong_AsInt(value);
1436 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int8");
1444 const int test = _PyLong_AsInt(value);
1446 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C int16");
1459 const ulong test = PyLong_AsUnsignedLong(value);
1461 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint8");
1469 const ulong test = PyLong_AsUnsignedLong(value);
1471 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint16");
1479 const ulong test = PyLong_AsUnsignedLong(value);
1481 PyErr_SetString(PyExc_OverflowError,
"Python int too large to convert to C uint32");
1492 # pragma warning(pop)
1503 switch (typestr[0]) {
size_t BLI_snprintf(char *__restrict dst, size_t maxncpy, const char *__restrict format,...) ATTR_NONNULL(1
_GL_VOID GLfloat value _GL_VOID_RET _GL_VOID const GLuint GLboolean *residences _GL_BOOL_RET _GL_VOID GLsizei GLfloat GLfloat GLfloat GLfloat const GLubyte *bitmap _GL_VOID_RET _GL_VOID GLenum type
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.
void *(* MEM_mallocN)(size_t len, const char *str)
int16_t PyC_Long_AsI16(PyObject *value)
char PyC_StructFmt_type_from_str(const char *typestr)
PyObject * PyC_DefaultNameSpace(const char *filename)
const char * PyC_UnicodeAsByte(PyObject *py_str, PyObject **coerce)
PyObject * PyC_FlagSet_FromBitfield(PyC_FlagSet *items, int flag)
int PyC_FlagSet_ToBitfield(PyC_FlagSet *items, PyObject *value, int *r_value, const char *error_prefix)
bool PyC_StructFmt_type_is_bool(char format)
uint8_t PyC_Long_AsU8(PyObject *value)
void PyC_ObSpit(const char *name, PyObject *var)
int PyC_FlagSet_ValueFromID(PyC_FlagSet *item, const char *identifier, int *r_value, const char *error_prefix)
int8_t PyC_Long_AsI8(PyObject *value)
int PyC_FlagSet_ValueFromID_int(PyC_FlagSet *item, const char *identifier, int *r_value)
void PyC_RunQuicky(const char *filepath, int n,...)
bool PyC_RunString_AsString(const char *imports[], const char *expr, const char *filename, char **r_value)
PyObject * PyC_Tuple_PackArray_Bool(const bool *array, uint len)
static void pyc_exception_buffer_handle_system_exit(PyObject *error_type, PyObject *error_value, PyObject *error_traceback)
int PyC_CheckArgs_DeepCopy(PyObject *args)
PyObject * PyC_Tuple_PackArray_I32FromBool(const int *array, uint len)
int PyC_ParseStringEnum(PyObject *o, void *p)
PyObject * PyC_UnicodeFromByteAndSize(const char *str, Py_ssize_t size)
PyObject * PyC_Err_SetString_Prefix(PyObject *exception_type_prefix, const char *str)
bool PyC_StructFmt_type_is_int_any(char format)
void * PyC_RNA_AsPointer(PyObject *value, const char *type_name)
PyObject * PyC_ExceptionBuffer(void)
int PyC_Long_AsBool(PyObject *value)
PyObject * PyC_Err_Format_Prefix(PyObject *exception_type_prefix, const char *format,...)
PyObject * PyC_Tuple_PackArray_F32(const float *array, uint len)
const char * PyC_StringEnum_FindIDFromValue(const struct PyC_StringEnumItems *items, const int value)
bool PyC_RunString_AsNumber(const char *imports[], const char *expr, const char *filename, double *r_value)
bool PyC_StructFmt_type_is_byte(char format)
PyObject * PyC_ExceptionBuffer_Simple(void)
PyObject * PyC_Tuple_PackArray_I32(const int *array, uint len)
PyObject * PyC_Object_GetAttrStringArgs(PyObject *o, Py_ssize_t n,...)
int PyC_AsArray_FAST(void *array, PyObject *value_fast, const Py_ssize_t length, const PyTypeObject *type, const bool is_double, const char *error_prefix)
void PyC_MainModule_Backup(PyObject **r_main_mod)
bool PyC_RunString_AsStringAndSize(const char *imports[], const char *expr, const char *filename, char **r_value, size_t *r_value_size)
const char * PyC_UnicodeAsByteAndSize(PyObject *py_str, Py_ssize_t *size, PyObject **coerce)
void PyC_FileAndNum_Safe(const char **r_filename, int *r_lineno)
bool PyC_IsInterpreterActive(void)
uint32_t PyC_Long_AsU32(PyObject *value)
PyObject * PyC_FlagSet_AsString(PyC_FlagSet *item)
bool PyC_NameSpace_ImportArray(PyObject *py_dict, const char *imports[])
void PyC_FileAndNum(const char **r_filename, int *r_lineno)
void PyC_List_Fill(PyObject *list, PyObject *value)
uint16_t PyC_Long_AsU16(PyObject *value)
void PyC_Err_PrintWithFunc(PyObject *py_func)
void PyC_MainModule_Restore(PyObject *main_mod)
PyObject * PyC_FrozenSetFromStrings(const char **strings)
PyObject * PyC_Tuple_PackArray_F64(const double *array, uint len)
PyObject * PyC_UnicodeFromByte(const char *str)
int PyC_ParseBool(PyObject *o, void *p)
void PyC_ObSpitStr(char *result, size_t result_len, PyObject *var)
void PyC_Tuple_Fill(PyObject *tuple, PyObject *value)
bool PyC_StructFmt_type_is_float_any(char format)
int PyC_AsArray(void *array, PyObject *value, const Py_ssize_t length, const PyTypeObject *type, const bool is_double, const char *error_prefix)
bool PyC_RunString_AsIntPtr(const char *imports[], const char *expr, const char *filename, intptr_t *r_value)
const struct PyC_StringEnumItems * items
ccl_device_inline int mod(int x, int m)