diff options
-rw-r--r-- | graphics/Blender/Blender.SlackBuild | 5 | ||||
-rw-r--r-- | graphics/Blender/Blender.info | 6 | ||||
-rw-r--r-- | graphics/Blender/buildinfo-2.75a.diff | 18 | ||||
-rw-r--r-- | graphics/Blender/buildinfo-2.76b.diff | 18 | ||||
-rw-r--r-- | graphics/Blender/buildinfo-2.77a.diff (renamed from graphics/Blender/buildinfo-2.74.diff) | 6 | ||||
-rw-r--r-- | graphics/Blender/patch-2.74-use-python35.diff | 318 | ||||
-rw-r--r-- | graphics/Blender/patch-2.76b-use-python35.diff | 170 |
7 files changed, 8 insertions, 533 deletions
diff --git a/graphics/Blender/Blender.SlackBuild b/graphics/Blender/Blender.SlackBuild index 07bfc679ad322..3b640490f6819 100644 --- a/graphics/Blender/Blender.SlackBuild +++ b/graphics/Blender/Blender.SlackBuild @@ -24,8 +24,8 @@ SRCNAM=blender PKGNAM=Blender -VERSION=${VERSION:-2.74} -BUILD=${BUILD:-3} +VERSION=${VERSION:-2.77a} +BUILD=${BUILD:-1} TAG=${TAG:-_SBo} PYTHON_VERSION=$(python3 -c "import sys; print(sys.version[:3])") @@ -72,7 +72,6 @@ find -L . \ -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \; patch -p0 < $CWD/buildinfo-$VERSION.diff -patch -p0 < $CWD/patch-${VERSION}-use-python35.diff patch -p1 < $CWD/use-libopenmj2-for-openjpeg.diff mkdir -p build diff --git a/graphics/Blender/Blender.info b/graphics/Blender/Blender.info index 9805c7c9316d3..c476b53aceff2 100644 --- a/graphics/Blender/Blender.info +++ b/graphics/Blender/Blender.info @@ -1,8 +1,8 @@ PRGNAM="Blender" -VERSION="2.74" +VERSION="2.77a" HOMEPAGE="http://blender.org" -DOWNLOAD="http://mirror.cs.umn.edu/blender.org/source/blender-2.74.tar.gz" -MD5SUM="488151953d69d63bedd8ed59f92daf3b" +DOWNLOAD="http://mirror.cs.umn.edu/blender.org/source/blender-2.77a.tar.gz" +MD5SUM="bb192274fe5957ce62bce9f0557ea4b4" DOWNLOAD_x86_64="" MD5SUM_x86_64="" REQUIRES="ffmpeg jack-audio-connection-kit opencollada python-requests valgrind numpy3 SDL2 openimageio freealut" diff --git a/graphics/Blender/buildinfo-2.75a.diff b/graphics/Blender/buildinfo-2.75a.diff deleted file mode 100644 index 21d9da6115daa..0000000000000 --- a/graphics/Blender/buildinfo-2.75a.diff +++ /dev/null @@ -1,18 +0,0 @@ ---- build_files/cmake/buildinfo.cmake.orig 2015-07-28 11:59:14.020100604 +0000 -+++ build_files/cmake/buildinfo.cmake 2015-07-28 12:18:20.021045004 +0000 -@@ -138,11 +138,12 @@ - execute_process(COMMAND cmd /c time /t OUTPUT_VARIABLE BUILD_TIME OUTPUT_STRIP_TRAILING_WHITESPACE) - endif() - -+# Timestamp from $(date --date='TZ="UTC" 16:56 07-Jul-15' +%s) - time & date of commit - # Write a file with the BUILD_HASH define - file(WRITE buildinfo.h.txt -- "#define BUILD_HASH \"${MY_WC_HASH}\"\n" -- "#define BUILD_COMMIT_TIMESTAMP ${MY_WC_COMMIT_TIMESTAMP}\n" -- "#define BUILD_BRANCH \"${MY_WC_BRANCH}\"\n" -+ "#define BUILD_HASH \"rBc27589e19fc0\"\n" -+ "#define BUILD_COMMIT_TIMESTAMP 1436288160\n" -+ "#define BUILD_BRANCH \"master\"\n" - "#define BUILD_DATE \"${BUILD_DATE}\"\n" - "#define BUILD_TIME \"${BUILD_TIME}\"\n" - ) diff --git a/graphics/Blender/buildinfo-2.76b.diff b/graphics/Blender/buildinfo-2.76b.diff deleted file mode 100644 index ccb7c2380ed45..0000000000000 --- a/graphics/Blender/buildinfo-2.76b.diff +++ /dev/null @@ -1,18 +0,0 @@ ---- build_files/cmake/buildinfo.cmake.orig 2015-07-28 11:59:14.020100604 +0000 -+++ build_files/cmake/buildinfo.cmake 2015-07-28 12:18:20.021045004 +0000 -@@ -138,11 +138,12 @@ - execute_process(COMMAND cmd /c time /t OUTPUT_VARIABLE BUILD_TIME OUTPUT_STRIP_TRAILING_WHITESPACE) - endif() - -+# Timestamp from $(date --date='TZ="UTC" 10:59 04-Nov-15' +%s) - time & date of commit - # Write a file with the BUILD_HASH define - file(WRITE buildinfo.h.txt -- "#define BUILD_HASH \"${MY_WC_HASH}\"\n" -- "#define BUILD_COMMIT_TIMESTAMP ${MY_WC_COMMIT_TIMESTAMP}\n" -- "#define BUILD_BRANCH \"${MY_WC_BRANCH}\"\n" -+ "#define BUILD_HASH \"rBf337feaf5a1d\"\n" -+ "#define BUILD_COMMIT_TIMESTAMP 1446634740\n" -+ "#define BUILD_BRANCH \"master\"\n" - "#define BUILD_DATE \"${BUILD_DATE}\"\n" - "#define BUILD_TIME \"${BUILD_TIME}\"\n" - ) diff --git a/graphics/Blender/buildinfo-2.74.diff b/graphics/Blender/buildinfo-2.77a.diff index 4bac93d751666..f82cc16ae4bc4 100644 --- a/graphics/Blender/buildinfo-2.74.diff +++ b/graphics/Blender/buildinfo-2.77a.diff @@ -4,14 +4,14 @@ execute_process(COMMAND cmd /c time /t OUTPUT_VARIABLE BUILD_TIME OUTPUT_STRIP_TRAILING_WHITESPACE) endif() -+# Timestamp from $(date --date='TZ="UTC" 16:56 07-Jul-15' +%s) - time & date of commit ++# Timestamp from $(date --date='TZ="UTC" 15:42 07-Apr-16' +%s) - time & date of commit # Write a file with the BUILD_HASH define file(WRITE buildinfo.h.txt - "#define BUILD_HASH \"${MY_WC_HASH}\"\n" - "#define BUILD_COMMIT_TIMESTAMP ${MY_WC_COMMIT_TIMESTAMP}\n" - "#define BUILD_BRANCH \"${MY_WC_BRANCH}\"\n" -+ "#define BUILD_HASH \"rB000dfc03190d\"\n" -+ "#define BUILD_COMMIT_TIMESTAMP 1427816340\n" ++ "#define BUILD_HASH \"rBabf6f081c4cd\"\n" ++ "#define BUILD_COMMIT_TIMESTAMP 1460043720\n" + "#define BUILD_BRANCH \"master\"\n" "#define BUILD_DATE \"${BUILD_DATE}\"\n" "#define BUILD_TIME \"${BUILD_TIME}\"\n" diff --git a/graphics/Blender/patch-2.74-use-python35.diff b/graphics/Blender/patch-2.74-use-python35.diff deleted file mode 100644 index b10942bf38093..0000000000000 --- a/graphics/Blender/patch-2.74-use-python35.diff +++ /dev/null @@ -1,318 +0,0 @@ ---- source/blender/python/generic/py_capi_utils.h.orig 2015-03-25 21:01:17.000000000 +1000 -+++ source/blender/python/generic/py_capi_utils.h 2016-01-07 23:41:12.118573813 +1000 -@@ -32,13 +32,18 @@ - void PyC_LineSpit(void); - void PyC_StackSpit(void); - PyObject * PyC_ExceptionBuffer(void); -+PyObject * PyC_ExceptionBuffer_Simple(void); - PyObject * PyC_Object_GetAttrStringArgs(PyObject *o, Py_ssize_t n, ...); - PyObject * PyC_FrozenSetFromStrings(const char **strings); - PyObject * PyC_Err_Format_Prefix(PyObject *exception_type_prefix, const char *format, ...); - void PyC_FileAndNum(const char **filename, int *lineno); - void PyC_FileAndNum_Safe(const char **filename, int *lineno); /* checks python is running */ --int PyC_AsArray(void *array, PyObject *value, const Py_ssize_t length, -- const PyTypeObject *type, const bool is_double, const char *error_prefix); -+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); -+int PyC_AsArray( -+ void *array, PyObject *value, const Py_ssize_t length, -+ const PyTypeObject *type, const bool is_double, const char *error_prefix); - PyObject * PyC_FromArray(const void *array, int length, const PyTypeObject *type, - const bool is_double, const char *error_prefix); - void PyC_Tuple_Fill(PyObject *tuple, PyObject *value); -@@ -74,6 +79,8 @@ - int PyC_FlagSet_ToBitfield(PyC_FlagSet *items, PyObject *value, int *r_value, const char *error_prefix); - PyObject *PyC_FlagSet_FromBitfield(PyC_FlagSet *items, int flag); - --int PyC_RunString_AsNumber(const char *expr, double *value, const char *filename); -+bool PyC_RunString_AsNumber(const char *expr, double *value, const char *filename); -+ -+int PyC_ParseBool(PyObject *o, void *p); - - #endif /* __PY_CAPI_UTILS_H__ */ ---- source/blender/python/generic/py_capi_utils.c.orig 2015-03-25 21:01:17.000000000 +1000 -+++ source/blender/python/generic/py_capi_utils.c 2016-01-07 23:41:12.114573720 +1000 -@@ -29,7 +29,6 @@ - * BLI_string_utf8() for unicode conversion. - */ - -- - #include <Python.h> - #include <frameobject.h> - -@@ -37,10 +36,12 @@ - - #include "py_capi_utils.h" - --#include "../generic/python_utildefines.h" -+#include "python_utildefines.h" - -+#ifndef MATH_STANDALONE - /* only for BLI_strncpy_wchar_from_utf8, should replace with py funcs but too late in release now */ - #include "BLI_string_utf8.h" -+#endif - - #ifdef _WIN32 - #include "BLI_path_util.h" /* BLI_setenv() */ -@@ -48,21 +49,17 @@ - #endif - - /* array utility function */ --int PyC_AsArray(void *array, PyObject *value, const Py_ssize_t length, -- const PyTypeObject *type, const bool is_double, const char *error_prefix) -+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) - { -- PyObject *value_fast; -- Py_ssize_t value_len; -+ const Py_ssize_t value_len = PySequence_Fast_GET_SIZE(value_fast); -+ PyObject **value_fast_items = PySequence_Fast_ITEMS(value_fast); - Py_ssize_t i; - -- if (!(value_fast = PySequence_Fast(value, error_prefix))) { -- return -1; -- } -- -- value_len = PySequence_Fast_GET_SIZE(value_fast); -+ BLI_assert(PyList_Check(value_fast) || PyTuple_Check(value_fast)); - - if (value_len != length) { -- Py_DECREF(value); - PyErr_Format(PyExc_TypeError, - "%.200s: invalid sequence length. expected %d, got %d", - error_prefix, length, value_len); -@@ -74,13 +71,13 @@ - if (is_double) { - double *array_double = array; - for (i = 0; i < length; i++) { -- array_double[i] = PyFloat_AsDouble(PySequence_Fast_GET_ITEM(value_fast, i)); -+ array_double[i] = PyFloat_AsDouble(value_fast_items[i]); - } - } - else { - float *array_float = array; - for (i = 0; i < length; i++) { -- array_float[i] = PyFloat_AsDouble(PySequence_Fast_GET_ITEM(value_fast, i)); -+ array_float[i] = PyFloat_AsDouble(value_fast_items[i]); - } - } - } -@@ -88,25 +85,22 @@ - /* could use is_double for 'long int' but no use now */ - int *array_int = array; - for (i = 0; i < length; i++) { -- array_int[i] = PyLong_AsLong(PySequence_Fast_GET_ITEM(value_fast, i)); -+ array_int[i] = PyLong_AsLong(value_fast_items[i]); - } - } - else if (type == &PyBool_Type) { - int *array_bool = array; - for (i = 0; i < length; i++) { -- array_bool[i] = (PyLong_AsLong(PySequence_Fast_GET_ITEM(value_fast, i)) != 0); -+ array_bool[i] = (PyLong_AsLong(value_fast_items[i]) != 0); - } - } - else { -- Py_DECREF(value_fast); - PyErr_Format(PyExc_TypeError, - "%s: internal error %s is invalid", - error_prefix, type->tp_name); - return -1; - } - -- Py_DECREF(value_fast); -- - if (PyErr_Occurred()) { - PyErr_Format(PyExc_TypeError, - "%s: one or more items could not be used as a %s", -@@ -117,6 +111,22 @@ - return 0; - } - -+int PyC_AsArray( -+ void *array, PyObject *value, const Py_ssize_t length, -+ const PyTypeObject *type, const bool is_double, const char *error_prefix) -+{ -+ PyObject *value_fast; -+ int ret; -+ -+ if (!(value_fast = PySequence_Fast(value, error_prefix))) { -+ return -1; -+ } -+ -+ ret = PyC_AsArray_FAST(array, value_fast, length, type, is_double, error_prefix); -+ Py_DECREF(value_fast); -+ return ret; -+} -+ - /* array utility function */ - PyObject *PyC_FromArray(const void *array, int length, const PyTypeObject *type, - const bool is_double, const char *error_prefix) -@@ -191,6 +201,27 @@ - } - } - -+/** -+ * Use with PyArg_ParseTuple's "O&" formatting. -+ */ -+int PyC_ParseBool(PyObject *o, void *p) -+{ -+ bool *bool_p = p; -+ long value; -+ if (((value = PyLong_AsLong(o)) == -1) || !ELEM(value, 0, 1)) { -+ PyErr_Format(PyExc_ValueError, -+ "expected a bool or int (0/1), got %s", -+ Py_TYPE(o)->tp_name); -+ return 0; -+ } -+ -+ *bool_p = value ? true : false; -+ return 1; -+} -+ -+ -+#ifndef MATH_STANDALONE -+ - /* for debugging */ - void PyC_ObSpit(const char *name, PyObject *var) - { -@@ -478,6 +509,34 @@ - } - #endif - -+PyObject *PyC_ExceptionBuffer_Simple(void) -+{ -+ PyObject *string_io_buf; -+ -+ PyObject *error_type, *error_value, *error_traceback; -+ -+ if (!PyErr_Occurred()) -+ return NULL; -+ -+ PyErr_Fetch(&error_type, &error_value, &error_traceback); -+ -+ if (error_value == NULL) { -+ return NULL; -+ } -+ -+ string_io_buf = PyObject_Str(error_value); -+ /* Python does this too */ -+ if (UNLIKELY(string_io_buf == NULL)) { -+ string_io_buf = PyUnicode_FromFormat( -+ "<unprintable %s object>", Py_TYPE(error_value)->tp_name); -+ } -+ -+ PyErr_Restore(error_type, error_value, error_traceback); -+ -+ PyErr_Print(); -+ PyErr_Clear(); -+ return string_io_buf; -+} - - /* string conversion, escape non-unicode chars, coerce must be set to NULL */ - const char *PyC_UnicodeAsByte(PyObject *py_str, PyObject **coerce) -@@ -497,15 +556,6 @@ - if (PyBytes_Check(py_str)) { - return PyBytes_AS_STRING(py_str); - } --#ifdef WIN32 -- /* bug [#31856] oddly enough, Python3.2 --> 3.3 on Windows will throw an -- * exception here this needs to be fixed in python: -- * see: bugs.python.org/issue15859 */ -- else if (!PyUnicode_Check(py_str)) { -- PyErr_BadArgument(); -- return NULL; -- } --#endif - else if ((*coerce = PyUnicode_EncodeFSDefault(py_str))) { - return PyBytes_AS_STRING(*coerce); - } -@@ -629,7 +679,8 @@ - - bool PyC_IsInterpreterActive(void) - { -- return (((PyThreadState *)_Py_atomic_load_relaxed(&_PyThreadState_Current)) != NULL); -+ /* instead of PyThreadState_Get, which calls Py_FatalError */ -+ return (PyThreadState_GetDict() != NULL); - } - - /* Would be nice if python had this built in -@@ -673,7 +724,7 @@ - } - - if (ret == NULL) { -- printf("PyC_InlineRun error, line:%d\n", __LINE__); -+ printf("%s error, line:%d\n", __func__, __LINE__); - PyErr_Print(); - PyErr_Clear(); - -@@ -747,7 +798,7 @@ - Py_DECREF(ret); - } - else { -- printf("PyC_InlineRun error on arg '%d', line:%d\n", i, __LINE__); -+ printf("%s error on arg '%d', line:%d\n", __func__, i, __LINE__); - PyC_ObSpit("failed converting:", item_new); - PyErr_Print(); - PyErr_Clear(); -@@ -758,11 +809,11 @@ - va_end(vargs); - } - else { -- printf("PyC_InlineRun error, 'values' not a list, line:%d\n", __LINE__); -+ printf("%s error, 'values' not a list, line:%d\n", __func__, __LINE__); - } - } - else { -- printf("PyC_InlineRun error line:%d\n", __LINE__); -+ printf("%s error line:%d\n", __func__, __LINE__); - PyErr_Print(); - PyErr_Clear(); - } -@@ -920,14 +971,14 @@ - - - /** -- * \return -1 on error, else 0 -+ * \return success - * - * \note it is caller's responsibility to acquire & release GIL! - */ --int PyC_RunString_AsNumber(const char *expr, double *value, const char *filename) -+bool PyC_RunString_AsNumber(const char *expr, double *value, const char *filename) - { - PyObject *py_dict, *mod, *retval; -- int error_ret = 0; -+ bool ok = true; - PyObject *main_mod = NULL; - - PyC_MainModule_Backup(&main_mod); -@@ -947,7 +998,7 @@ - retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict); - - if (retval == NULL) { -- error_ret = -1; -+ ok = false; - } - else { - double val; -@@ -973,7 +1024,7 @@ - Py_DECREF(retval); - - if (val == -1 && PyErr_Occurred()) { -- error_ret = -1; -+ ok = false; - } - else if (!finite(val)) { - *value = 0.0; -@@ -985,5 +1036,7 @@ - - PyC_MainModule_Restore(main_mod); - -- return error_ret; -+ return ok; - } -+ -+#endif /* #ifndef MATH_STANDALONE */ diff --git a/graphics/Blender/patch-2.76b-use-python35.diff b/graphics/Blender/patch-2.76b-use-python35.diff deleted file mode 100644 index 176908b59e937..0000000000000 --- a/graphics/Blender/patch-2.76b-use-python35.diff +++ /dev/null @@ -1,170 +0,0 @@ ---- source/blender/python/generic/py_capi_utils.h.orig 2015-11-02 23:25:38.000000000 +1000 -+++ source/blender/python/generic/py_capi_utils.h 2016-01-08 19:16:13.796355344 +1000 -@@ -79,7 +79,7 @@ - int PyC_FlagSet_ToBitfield(PyC_FlagSet *items, PyObject *value, int *r_value, const char *error_prefix); - PyObject *PyC_FlagSet_FromBitfield(PyC_FlagSet *items, int flag); - --int PyC_RunString_AsNumber(const char *expr, double *value, const char *filename); -+bool PyC_RunString_AsNumber(const char *expr, double *value, const char *filename); - - int PyC_ParseBool(PyObject *o, void *p); - ---- source/blender/python/generic/py_capi_utils.c.orig 2015-11-04 20:02:15.000000000 +1000 -+++ source/blender/python/generic/py_capi_utils.c 2016-01-08 19:16:13.784355344 +1000 -@@ -29,7 +29,6 @@ - * BLI_string_utf8() for unicode conversion. - */ - -- - #include <Python.h> - #include <frameobject.h> - -@@ -39,8 +38,10 @@ - - #include "python_utildefines.h" - -+#ifndef MATH_STANDALONE - /* only for BLI_strncpy_wchar_from_utf8, should replace with py funcs but too late in release now */ - #include "BLI_string_utf8.h" -+#endif - - #ifdef _WIN32 - #include "BLI_path_util.h" /* BLI_setenv() */ -@@ -200,6 +201,27 @@ - } - } - -+/** -+ * Use with PyArg_ParseTuple's "O&" formatting. -+ */ -+int PyC_ParseBool(PyObject *o, void *p) -+{ -+ bool *bool_p = p; -+ long value; -+ if (((value = PyLong_AsLong(o)) == -1) || !ELEM(value, 0, 1)) { -+ PyErr_Format(PyExc_ValueError, -+ "expected a bool or int (0/1), got %s", -+ Py_TYPE(o)->tp_name); -+ return 0; -+ } -+ -+ *bool_p = value ? true : false; -+ return 1; -+} -+ -+ -+#ifndef MATH_STANDALONE -+ - /* for debugging */ - void PyC_ObSpit(const char *name, PyObject *var) - { -@@ -534,15 +556,6 @@ - if (PyBytes_Check(py_str)) { - return PyBytes_AS_STRING(py_str); - } --#ifdef WIN32 -- /* bug [#31856] oddly enough, Python3.2 --> 3.3 on Windows will throw an -- * exception here this needs to be fixed in python: -- * see: bugs.python.org/issue15859 */ -- else if (!PyUnicode_Check(py_str)) { -- PyErr_BadArgument(); -- return NULL; -- } --#endif - else if ((*coerce = PyUnicode_EncodeFSDefault(py_str))) { - return PyBytes_AS_STRING(*coerce); - } -@@ -711,7 +724,7 @@ - } - - if (ret == NULL) { -- printf("PyC_InlineRun error, line:%d\n", __LINE__); -+ printf("%s error, line:%d\n", __func__, __LINE__); - PyErr_Print(); - PyErr_Clear(); - -@@ -785,7 +798,7 @@ - Py_DECREF(ret); - } - else { -- printf("PyC_InlineRun error on arg '%d', line:%d\n", i, __LINE__); -+ printf("%s error on arg '%d', line:%d\n", __func__, i, __LINE__); - PyC_ObSpit("failed converting:", item_new); - PyErr_Print(); - PyErr_Clear(); -@@ -796,11 +809,11 @@ - va_end(vargs); - } - else { -- printf("PyC_InlineRun error, 'values' not a list, line:%d\n", __LINE__); -+ printf("%s error, 'values' not a list, line:%d\n", __func__, __LINE__); - } - } - else { -- printf("PyC_InlineRun error line:%d\n", __LINE__); -+ printf("%s error line:%d\n", __func__, __LINE__); - PyErr_Print(); - PyErr_Clear(); - } -@@ -958,14 +971,14 @@ - - - /** -- * \return -1 on error, else 0 -+ * \return success - * - * \note it is caller's responsibility to acquire & release GIL! - */ --int PyC_RunString_AsNumber(const char *expr, double *value, const char *filename) -+bool PyC_RunString_AsNumber(const char *expr, double *value, const char *filename) - { - PyObject *py_dict, *mod, *retval; -- int error_ret = 0; -+ bool ok = true; - PyObject *main_mod = NULL; - - PyC_MainModule_Backup(&main_mod); -@@ -985,7 +998,7 @@ - retval = PyRun_String(expr, Py_eval_input, py_dict, py_dict); - - if (retval == NULL) { -- error_ret = -1; -+ ok = false; - } - else { - double val; -@@ -1011,7 +1024,7 @@ - Py_DECREF(retval); - - if (val == -1 && PyErr_Occurred()) { -- error_ret = -1; -+ ok = false; - } - else if (!finite(val)) { - *value = 0.0; -@@ -1023,23 +1036,7 @@ - - PyC_MainModule_Restore(main_mod); - -- return error_ret; -+ return ok; - } - --/** -- * Use with PyArg_ParseTuple's "O&" formatting. -- */ --int PyC_ParseBool(PyObject *o, void *p) --{ -- bool *bool_p = p; -- long value; -- if (((value = PyLong_AsLong(o)) == -1) || !ELEM(value, 0, 1)) { -- PyErr_Format(PyExc_ValueError, -- "expected a bool or int (0/1), got %s", -- Py_TYPE(o)->tp_name); -- return 0; -- } -- -- *bool_p = value ? true : false; -- return 1; --} -+#endif /* #ifndef MATH_STANDALONE */ |