2023-09-08T09:01:21,672 Created temporary directory: /tmp/pip-build-tracker-oftqb7al 2023-09-08T09:01:21,673 Initialized build tracking at /tmp/pip-build-tracker-oftqb7al 2023-09-08T09:01:21,673 Created build tracker: /tmp/pip-build-tracker-oftqb7al 2023-09-08T09:01:21,674 Entered build tracker: /tmp/pip-build-tracker-oftqb7al 2023-09-08T09:01:21,675 Created temporary directory: /tmp/pip-wheel-6rxkt9rq 2023-09-08T09:01:21,678 Created temporary directory: /tmp/pip-ephem-wheel-cache-3iry_5h1 2023-09-08T09:01:21,699 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2023-09-08T09:01:21,703 2 location(s) to search for versions of quaternion-algebra: 2023-09-08T09:01:21,703 * https://pypi.org/simple/quaternion-algebra/ 2023-09-08T09:01:21,703 * https://www.piwheels.org/simple/quaternion-algebra/ 2023-09-08T09:01:21,704 Fetching project page and analyzing links: https://pypi.org/simple/quaternion-algebra/ 2023-09-08T09:01:21,704 Getting page https://pypi.org/simple/quaternion-algebra/ 2023-09-08T09:01:21,706 Found index url https://pypi.org/simple/ 2023-09-08T09:01:21,924 Fetched page https://pypi.org/simple/quaternion-algebra/ as application/vnd.pypi.simple.v1+json 2023-09-08T09:01:21,926 Found link https://files.pythonhosted.org/packages/5a/32/76c60f33820b5ad6bb1947037f07099f63e9201803b1d04e8316f9d46a06/quaternion-algebra-1.0.tar.gz (from https://pypi.org/simple/quaternion-algebra/), version: 1.0 2023-09-08T09:01:21,926 Found link https://files.pythonhosted.org/packages/fa/8c/33aae81422632d8d878103dddd6508d832136ac1b58a9b4ae02c79f3face/quaternion-algebra-1.0.1.tar.gz (from https://pypi.org/simple/quaternion-algebra/), version: 1.0.1 2023-09-08T09:01:21,927 Fetching project page and analyzing links: https://www.piwheels.org/simple/quaternion-algebra/ 2023-09-08T09:01:21,928 Getting page https://www.piwheels.org/simple/quaternion-algebra/ 2023-09-08T09:01:21,929 Found index url https://www.piwheels.org/simple/ 2023-09-08T09:01:25,143 Fetched page https://www.piwheels.org/simple/quaternion-algebra/ as text/html 2023-09-08T09:01:25,144 Skipping link: not a file: https://www.piwheels.org/simple/quaternion-algebra/ 2023-09-08T09:01:25,145 Skipping link: not a file: https://pypi.org/simple/quaternion-algebra/ 2023-09-08T09:01:25,180 Given no hashes to check 1 links for project 'quaternion-algebra': discarding no candidates 2023-09-08T09:01:25,213 Collecting quaternion-algebra==1.0 2023-09-08T09:01:25,216 Created temporary directory: /tmp/pip-unpack-uq_h4_bs 2023-09-08T09:01:25,437 Downloading quaternion-algebra-1.0.tar.gz (16 kB) 2023-09-08T09:01:25,473 Added quaternion-algebra==1.0 from https://files.pythonhosted.org/packages/5a/32/76c60f33820b5ad6bb1947037f07099f63e9201803b1d04e8316f9d46a06/quaternion-algebra-1.0.tar.gz to build tracker '/tmp/pip-build-tracker-oftqb7al' 2023-09-08T09:01:25,475 Running setup.py (path:/tmp/pip-wheel-6rxkt9rq/quaternion-algebra_8954dafb3f8440c698365534aae8fc44/setup.py) egg_info for package quaternion-algebra 2023-09-08T09:01:25,476 Created temporary directory: /tmp/pip-pip-egg-info-j106jyx4 2023-09-08T09:01:25,476 Preparing metadata (setup.py): started 2023-09-08T09:01:25,478 Running command python setup.py egg_info 2023-09-08T09:01:26,489 running egg_info 2023-09-08T09:01:26,491 creating /tmp/pip-pip-egg-info-j106jyx4/quaternion_algebra.egg-info 2023-09-08T09:01:26,514 writing /tmp/pip-pip-egg-info-j106jyx4/quaternion_algebra.egg-info/PKG-INFO 2023-09-08T09:01:26,517 writing dependency_links to /tmp/pip-pip-egg-info-j106jyx4/quaternion_algebra.egg-info/dependency_links.txt 2023-09-08T09:01:26,519 writing top-level names to /tmp/pip-pip-egg-info-j106jyx4/quaternion_algebra.egg-info/top_level.txt 2023-09-08T09:01:26,521 writing manifest file '/tmp/pip-pip-egg-info-j106jyx4/quaternion_algebra.egg-info/SOURCES.txt' 2023-09-08T09:01:26,616 reading manifest file '/tmp/pip-pip-egg-info-j106jyx4/quaternion_algebra.egg-info/SOURCES.txt' 2023-09-08T09:01:26,618 reading manifest template 'MANIFEST.in' 2023-09-08T09:01:26,632 warning: no previously-included files matching '*.pyc' found anywhere in distribution 2023-09-08T09:01:26,632 warning: no previously-included files matching '*.so' found anywhere in distribution 2023-09-08T09:01:26,634 writing manifest file '/tmp/pip-pip-egg-info-j106jyx4/quaternion_algebra.egg-info/SOURCES.txt' 2023-09-08T09:01:26,746 Preparing metadata (setup.py): finished with status 'done' 2023-09-08T09:01:26,749 Source in /tmp/pip-wheel-6rxkt9rq/quaternion-algebra_8954dafb3f8440c698365534aae8fc44 has version 1.0, which satisfies requirement quaternion-algebra==1.0 from https://files.pythonhosted.org/packages/5a/32/76c60f33820b5ad6bb1947037f07099f63e9201803b1d04e8316f9d46a06/quaternion-algebra-1.0.tar.gz 2023-09-08T09:01:26,750 Removed quaternion-algebra==1.0 from https://files.pythonhosted.org/packages/5a/32/76c60f33820b5ad6bb1947037f07099f63e9201803b1d04e8316f9d46a06/quaternion-algebra-1.0.tar.gz from build tracker '/tmp/pip-build-tracker-oftqb7al' 2023-09-08T09:01:26,753 Created temporary directory: /tmp/pip-unpack-b2sks5lo 2023-09-08T09:01:26,754 Created temporary directory: /tmp/pip-unpack-goj7yi2t 2023-09-08T09:01:26,757 Building wheels for collected packages: quaternion-algebra 2023-09-08T09:01:26,761 Created temporary directory: /tmp/pip-wheel-ryj_cwjp 2023-09-08T09:01:26,761 Building wheel for quaternion-algebra (setup.py): started 2023-09-08T09:01:26,762 Destination directory: /tmp/pip-wheel-ryj_cwjp 2023-09-08T09:01:26,763 Running command python setup.py bdist_wheel 2023-09-08T09:01:27,746 running bdist_wheel 2023-09-08T09:01:27,838 running build 2023-09-08T09:01:27,839 running build_py 2023-09-08T09:01:27,865 creating build 2023-09-08T09:01:27,866 creating build/lib.linux-armv7l-cpython-311 2023-09-08T09:01:27,867 creating build/lib.linux-armv7l-cpython-311/quaternion 2023-09-08T09:01:27,868 copying src/quaternion/quaternion.py -> build/lib.linux-armv7l-cpython-311/quaternion 2023-09-08T09:01:27,870 copying src/quaternion/__init__.py -> build/lib.linux-armv7l-cpython-311/quaternion 2023-09-08T09:01:27,872 running build_ext 2023-09-08T09:01:28,381 building 'quaternion._quaternion' extension 2023-09-08T09:01:28,381 creating build/temp.linux-armv7l-cpython-311 2023-09-08T09:01:28,382 creating build/temp.linux-armv7l-cpython-311/src 2023-09-08T09:01:28,383 creating build/temp.linux-armv7l-cpython-311/src/quaternion 2023-09-08T09:01:28,384 arm-linux-gnueabihf-gcc -Wsign-compare -DNDEBUG -g -fwrapv -O2 -Wall -g -fstack-protector-strong -Wformat -Werror=format-security -g -fwrapv -O2 -fPIC -I/usr/include/python3.11 -c src/quaternion/quaternion.c -o build/temp.linux-armv7l-cpython-311/src/quaternion/quaternion.o 2023-09-08T09:01:28,742 src/quaternion/quaternion.c: In function ‘Quaternion_dealloc’: 2023-09-08T09:01:28,742 src/quaternion/quaternion.c:11:9: error: ‘Quaternion’ has no member named ‘ob_type’ 2023-09-08T09:01:28,743 11 | self->ob_type->tp_free((PyObject*)self); 2023-09-08T09:01:28,744 | ^~ 2023-09-08T09:01:28,757 src/quaternion/quaternion.c: In function ‘Quaternion_str’: 2023-09-08T09:01:28,758 src/quaternion/quaternion.c:90:18: warning: implicit declaration of function ‘PyString_FromString’; did you mean ‘PyLong_FromString’? [-Wimplicit-function-declaration] 2023-09-08T09:01:28,758 90 | format = PyString_FromString("(%s%s %s %si %s %sj %s %sk)"); 2023-09-08T09:01:28,759 | ^~~~~~~~~~~~~~~~~~~ 2023-09-08T09:01:28,759 | PyLong_FromString 2023-09-08T09:01:28,760 src/quaternion/quaternion.c:90:16: warning: assignment to ‘PyObject *’ {aka ‘struct _object *’} from ‘int’ makes pointer from integer without a cast [-Wint-conversion] 2023-09-08T09:01:28,760 90 | format = PyString_FromString("(%s%s %s %si %s %sj %s %sk)"); 2023-09-08T09:01:28,761 | ^ 2023-09-08T09:01:28,771 src/quaternion/quaternion.c:97:14: warning: implicit declaration of function ‘PyString_Format’; did you mean ‘PyErr_Format’? [-Wimplicit-function-declaration] 2023-09-08T09:01:28,772 97 | result = PyString_Format(format, args); 2023-09-08T09:01:28,773 | ^~~~~~~~~~~~~~~ 2023-09-08T09:01:28,774 | PyErr_Format 2023-09-08T09:01:28,775 src/quaternion/quaternion.c:97:12: warning: assignment to ‘PyObject *’ {aka ‘struct _object *’} from ‘int’ makes pointer from integer without a cast [-Wint-conversion] 2023-09-08T09:01:28,775 97 | result = PyString_Format(format, args); 2023-09-08T09:01:28,776 | ^ 2023-09-08T09:01:28,777 src/quaternion/quaternion.c: At top level: 2023-09-08T09:01:28,777 src/quaternion/quaternion.c:197:5: warning: initialization of ‘int (*)(PyObject *)’ {aka ‘int (*)(struct _object *)’} from incompatible pointer type ‘PyObject * (*)(PyObject *)’ {aka ‘struct _object * (*)(struct _object *)’} [-Wincompatible-pointer-types] 2023-09-08T09:01:28,778 197 | (unaryfunc)Quaternion_absolute, /* nb_absolute */ 2023-09-08T09:01:28,779 | ^ 2023-09-08T09:01:28,779 src/quaternion/quaternion.c:197:5: note: (near initialization for ‘Quaternion_as_number.nb_bool’) 2023-09-08T09:01:28,780 src/quaternion/quaternion.c:224:5: warning: excess elements in struct initializer 2023-09-08T09:01:28,781 224 | 0, /* nb_inplace_floor_divide */ 2023-09-08T09:01:28,781 | ^ 2023-09-08T09:01:28,782 src/quaternion/quaternion.c:224:5: note: (near initialization for ‘Quaternion_as_number’) 2023-09-08T09:01:28,782 src/quaternion/quaternion.c:225:5: warning: excess elements in struct initializer 2023-09-08T09:01:28,783 225 | 0, /* nb_inplace_true_divide */ 2023-09-08T09:01:28,783 | ^ 2023-09-08T09:01:28,784 src/quaternion/quaternion.c:225:5: note: (near initialization for ‘Quaternion_as_number’) 2023-09-08T09:01:28,785 src/quaternion/quaternion.c:226:5: warning: excess elements in struct initializer 2023-09-08T09:01:28,785 226 | 0, /* nb_index */ 2023-09-08T09:01:28,786 | ^ 2023-09-08T09:01:28,787 src/quaternion/quaternion.c:226:5: note: (near initialization for ‘Quaternion_as_number’) 2023-09-08T09:01:28,788 src/quaternion/quaternion.c:230:38: warning: missing braces around initializer [-Wmissing-braces] 2023-09-08T09:01:28,788 230 | static PyTypeObject QuaternionType = { 2023-09-08T09:01:28,789 | ^ 2023-09-08T09:01:28,790 src/quaternion/quaternion.c:233:5: warning: initialization of ‘int’ from ‘char *’ makes integer from pointer without a cast [-Wint-conversion] 2023-09-08T09:01:28,791 233 | "_quaternion.Quaternion", /* tp_name */ 2023-09-08T09:01:28,791 | ^~~~~~~~~~~~~~~~~~~~~~~~ 2023-09-08T09:01:28,792 src/quaternion/quaternion.c:233:5: note: (near initialization for ‘QuaternionType.tp_basicsize’) 2023-09-08T09:01:28,793 src/quaternion/quaternion.c:236:5: warning: initialization of ‘int’ from ‘void (*)(PyObject *)’ {aka ‘void (*)(struct _object *)’} makes integer from pointer without a cast [-Wint-conversion] 2023-09-08T09:01:28,794 236 | (destructor)Quaternion_dealloc, /* tp_dealloc */ 2023-09-08T09:01:28,795 | ^ 2023-09-08T09:01:28,795 src/quaternion/quaternion.c:236:5: note: (near initialization for ‘QuaternionType.tp_vectorcall_offset’) 2023-09-08T09:01:28,796 src/quaternion/quaternion.c:242:5: warning: initialization of ‘PySequenceMethods *’ from incompatible pointer type ‘PyNumberMethods *’ [-Wincompatible-pointer-types] 2023-09-08T09:01:28,797 242 | &Quaternion_as_number, /* tp_as_number */ 2023-09-08T09:01:28,797 | ^ 2023-09-08T09:01:28,798 src/quaternion/quaternion.c:242:5: note: (near initialization for ‘QuaternionType.tp_as_sequence’) 2023-09-08T09:01:28,799 src/quaternion/quaternion.c:247:5: warning: initialization of ‘PyObject * (*)(PyObject *, PyObject *)’ {aka ‘struct _object * (*)(struct _object *, struct _object *)’} from incompatible pointer type ‘PyObject * (*)(PyObject *)’ {aka ‘struct _object * (*)(struct _object *)’} [-Wincompatible-pointer-types] 2023-09-08T09:01:28,800 247 | (reprfunc)Quaternion_str, /* tp_str */ 2023-09-08T09:01:28,801 | ^ 2023-09-08T09:01:28,801 src/quaternion/quaternion.c:247:5: note: (near initialization for ‘QuaternionType.tp_getattro’) 2023-09-08T09:01:28,802 In file included from /usr/include/python3.11/Python.h:44, 2023-09-08T09:01:28,802 from src/quaternion/quaternion.c:1: 2023-09-08T09:01:28,803 /usr/include/python3.11/object.h:422:29: warning: initialization of ‘const char *’ from ‘long unsigned int’ makes pointer from integer without a cast [-Wint-conversion] 2023-09-08T09:01:28,803 422 | #define Py_TPFLAGS_DEFAULT ( \ 2023-09-08T09:01:28,804 | ^ 2023-09-08T09:01:28,805 src/quaternion/quaternion.c:251:5: note: in expansion of macro ‘Py_TPFLAGS_DEFAULT’ 2023-09-08T09:01:28,805 251 | Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */ 2023-09-08T09:01:28,807 | ^~~~~~~~~~~~~~~~~~ 2023-09-08T09:01:28,808 /usr/include/python3.11/object.h:422:29: note: (near initialization for ‘QuaternionType.tp_doc’) 2023-09-08T09:01:28,809 422 | #define Py_TPFLAGS_DEFAULT ( \ 2023-09-08T09:01:28,810 | ^ 2023-09-08T09:01:28,811 src/quaternion/quaternion.c:251:5: note: in expansion of macro ‘Py_TPFLAGS_DEFAULT’ 2023-09-08T09:01:28,812 251 | Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */ 2023-09-08T09:01:28,812 | ^~~~~~~~~~~~~~~~~~ 2023-09-08T09:01:28,813 src/quaternion/quaternion.c:252:5: warning: initialization of ‘int (*)(PyObject *, int (*)(PyObject *, void *), void *)’ {aka ‘int (*)(struct _object *, int (*)(struct _object *, void *), void *)’} from incompatible pointer type ‘char *’ [-Wincompatible-pointer-types] 2023-09-08T09:01:28,814 252 | "Quaternion object", /* tp_doc */ 2023-09-08T09:01:28,815 | ^~~~~~~~~~~~~~~~~~~ 2023-09-08T09:01:28,816 src/quaternion/quaternion.c:252:5: note: (near initialization for ‘QuaternionType.tp_traverse’) 2023-09-08T09:01:28,816 src/quaternion/quaternion.c:259:5: warning: initialization of ‘PyMemberDef *’ from incompatible pointer type ‘PyMethodDef *’ [-Wincompatible-pointer-types] 2023-09-08T09:01:28,817 259 | Quaternion_methods, /* tp_methods */ 2023-09-08T09:01:28,818 | ^~~~~~~~~~~~~~~~~~ 2023-09-08T09:01:28,819 src/quaternion/quaternion.c:259:5: note: (near initialization for ‘QuaternionType.tp_members’) 2023-09-08T09:01:28,820 src/quaternion/quaternion.c:260:5: warning: initialization of ‘PyGetSetDef *’ from incompatible pointer type ‘PyMemberDef *’ [-Wincompatible-pointer-types] 2023-09-08T09:01:28,821 260 | Quaternion_members, /* tp_members */ 2023-09-08T09:01:28,821 | ^~~~~~~~~~~~~~~~~~ 2023-09-08T09:01:28,822 src/quaternion/quaternion.c:260:5: note: (near initialization for ‘QuaternionType.tp_getset’) 2023-09-08T09:01:28,823 src/quaternion/quaternion.c:267:5: warning: initialization of ‘PyObject * (*)(PyTypeObject *, Py_ssize_t)’ {aka ‘struct _object * (*)(struct _typeobject *, int)’} from incompatible pointer type ‘int (*)(PyObject *, PyObject *, PyObject *)’ {aka ‘int (*)(struct _object *, struct _object *, struct _object *)’} [-Wincompatible-pointer-types] 2023-09-08T09:01:28,824 267 | (initproc)Quaternion_init, /* tp_init */ 2023-09-08T09:01:28,826 | ^ 2023-09-08T09:01:28,827 src/quaternion/quaternion.c:267:5: note: (near initialization for ‘QuaternionType.tp_alloc’) 2023-09-08T09:01:28,828 src/quaternion/quaternion.c:269:5: warning: initialization of ‘void (*)(void *)’ from incompatible pointer type ‘PyObject * (*)(PyTypeObject *, PyObject *, PyObject *)’ {aka ‘struct _object * (*)(struct _typeobject *, struct _object *, struct _object *)’} [-Wincompatible-pointer-types] 2023-09-08T09:01:28,829 269 | Quaternion_new, /* tp_new */ 2023-09-08T09:01:28,830 | ^~~~~~~~~~~~~~ 2023-09-08T09:01:28,831 src/quaternion/quaternion.c:269:5: note: (near initialization for ‘QuaternionType.tp_free’) 2023-09-08T09:01:28,831 src/quaternion/quaternion.c:230:38: warning: missing braces around initializer [-Wmissing-braces] 2023-09-08T09:01:28,832 230 | static PyTypeObject QuaternionType = { 2023-09-08T09:01:28,833 | ^ 2023-09-08T09:01:28,833 src/quaternion/quaternion.c: In function ‘init_quaternion’: 2023-09-08T09:01:28,834 src/quaternion/quaternion.c:283:44: warning: ‘return’ with no value, in function returning non-void [-Wreturn-type] 2023-09-08T09:01:28,835 283 | if (PyType_Ready(&QuaternionType) < 0) return; 2023-09-08T09:01:28,836 | ^~~~~~ 2023-09-08T09:01:28,837 src/quaternion/quaternion.c:279:1: note: declared here 2023-09-08T09:01:28,837 279 | init_quaternion(void) 2023-09-08T09:01:28,838 | ^~~~~~~~~~~~~~~ 2023-09-08T09:01:28,839 src/quaternion/quaternion.c:285:9: warning: implicit declaration of function ‘Py_InitModule’ [-Wimplicit-function-declaration] 2023-09-08T09:01:28,840 285 | m = Py_InitModule("_quaternion", quaternion_funcs); 2023-09-08T09:01:28,841 | ^~~~~~~~~~~~~ 2023-09-08T09:01:28,841 src/quaternion/quaternion.c:285:7: warning: assignment to ‘PyObject *’ {aka ‘struct _object *’} from ‘int’ makes pointer from integer without a cast [-Wint-conversion] 2023-09-08T09:01:28,842 285 | m = Py_InitModule("_quaternion", quaternion_funcs); 2023-09-08T09:01:28,843 | ^ 2023-09-08T09:01:28,844 src/quaternion/quaternion.c:287:20: warning: ‘return’ with no value, in function returning non-void [-Wreturn-type] 2023-09-08T09:01:28,845 287 | if (m == NULL) return; 2023-09-08T09:01:28,845 | ^~~~~~ 2023-09-08T09:01:28,846 src/quaternion/quaternion.c:279:1: note: declared here 2023-09-08T09:01:28,847 279 | init_quaternion(void) 2023-09-08T09:01:28,848 | ^~~~~~~~~~~~~~~ 2023-09-08T09:01:28,849 error: command '/usr/bin/arm-linux-gnueabihf-gcc' failed with exit code 1 2023-09-08T09:01:28,979 ERROR: [present-rich] python setup.py bdist_wheel exited with 1 2023-09-08T09:01:28,992 [bold magenta]full command[/]: [blue]/usr/bin/python3 -u -c ' 2023-09-08T09:01:28,992 exec(compile('"'"''"'"''"'"' 2023-09-08T09:01:28,992 # This is -- a caller that pip uses to run setup.py 2023-09-08T09:01:28,992 # 2023-09-08T09:01:28,992 # - It imports setuptools before invoking setup.py, to enable projects that directly 2023-09-08T09:01:28,992 # import from `distutils.core` to work with newer packaging standards. 2023-09-08T09:01:28,992 # - It provides a clear error message when setuptools is not installed. 2023-09-08T09:01:28,992 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2023-09-08T09:01:28,992 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2023-09-08T09:01:28,992 # manifest_maker: standard file '"'"'-c'"'"' not found". 2023-09-08T09:01:28,992 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2023-09-08T09:01:28,992 import os, sys, tokenize 2023-09-08T09:01:28,992 2023-09-08T09:01:28,992 try: 2023-09-08T09:01:28,992 import setuptools 2023-09-08T09:01:28,992 except ImportError as error: 2023-09-08T09:01:28,992 print( 2023-09-08T09:01:28,992 "ERROR: Can not execute `setup.py` since setuptools is not available in " 2023-09-08T09:01:28,992 "the build environment.", 2023-09-08T09:01:28,992 file=sys.stderr, 2023-09-08T09:01:28,992 ) 2023-09-08T09:01:28,992 sys.exit(1) 2023-09-08T09:01:28,992 2023-09-08T09:01:28,992 __file__ = %r 2023-09-08T09:01:28,992 sys.argv[0] = __file__ 2023-09-08T09:01:28,992 2023-09-08T09:01:28,992 if os.path.exists(__file__): 2023-09-08T09:01:28,992 filename = __file__ 2023-09-08T09:01:28,992 with tokenize.open(__file__) as f: 2023-09-08T09:01:28,992 setup_py_code = f.read() 2023-09-08T09:01:28,992 else: 2023-09-08T09:01:28,992 filename = "" 2023-09-08T09:01:28,992 setup_py_code = "from setuptools import setup; setup()" 2023-09-08T09:01:28,992 2023-09-08T09:01:28,992 exec(compile(setup_py_code, filename, "exec")) 2023-09-08T09:01:28,992 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-6rxkt9rq/quaternion-algebra_8954dafb3f8440c698365534aae8fc44/setup.py'"'"',), "", "exec"))' bdist_wheel -d /tmp/pip-wheel-ryj_cwjp[/] 2023-09-08T09:01:28,993 [bold magenta]cwd[/]: /tmp/pip-wheel-6rxkt9rq/quaternion-algebra_8954dafb3f8440c698365534aae8fc44/ 2023-09-08T09:01:28,994 Building wheel for quaternion-algebra (setup.py): finished with status 'error' 2023-09-08T09:01:28,995 ERROR: Failed building wheel for quaternion-algebra 2023-09-08T09:01:28,997 Running setup.py clean for quaternion-algebra 2023-09-08T09:01:28,998 Running command python setup.py clean 2023-09-08T09:01:29,964 running clean 2023-09-08T09:01:30,009 removing 'build/temp.linux-armv7l-cpython-311' (and everything under it) 2023-09-08T09:01:30,011 removing 'build/lib.linux-armv7l-cpython-311' (and everything under it) 2023-09-08T09:01:30,013 'build/bdist.linux-armv7l' does not exist -- can't clean it 2023-09-08T09:01:30,014 'build/scripts-3.11' does not exist -- can't clean it 2023-09-08T09:01:30,014 removing 'build' 2023-09-08T09:01:30,125 Failed to build quaternion-algebra 2023-09-08T09:01:30,126 ERROR: Failed to build one or more wheels 2023-09-08T09:01:30,127 Exception information: 2023-09-08T09:01:30,127 Traceback (most recent call last): 2023-09-08T09:01:30,127 File "/usr/local/lib/python3.11/dist-packages/pip/_internal/cli/base_command.py", line 180, in exc_logging_wrapper 2023-09-08T09:01:30,127 status = run_func(*args) 2023-09-08T09:01:30,127 ^^^^^^^^^^^^^^^ 2023-09-08T09:01:30,127 File "/usr/local/lib/python3.11/dist-packages/pip/_internal/cli/req_command.py", line 248, in wrapper 2023-09-08T09:01:30,127 return func(self, options, args) 2023-09-08T09:01:30,127 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2023-09-08T09:01:30,127 File "/usr/local/lib/python3.11/dist-packages/pip/_internal/commands/wheel.py", line 181, in run 2023-09-08T09:01:30,127 raise CommandError("Failed to build one or more wheels") 2023-09-08T09:01:30,127 pip._internal.exceptions.CommandError: Failed to build one or more wheels 2023-09-08T09:01:30,130 Removed build tracker: '/tmp/pip-build-tracker-oftqb7al'