2025-09-07T20:27:45,166 Created temporary directory: /tmp/pip-build-tracker-_4903ehv 2025-09-07T20:27:45,166 Initialized build tracking at /tmp/pip-build-tracker-_4903ehv 2025-09-07T20:27:45,166 Created build tracker: /tmp/pip-build-tracker-_4903ehv 2025-09-07T20:27:45,167 Entered build tracker: /tmp/pip-build-tracker-_4903ehv 2025-09-07T20:27:45,167 Created temporary directory: /tmp/pip-wheel-y8demxu9 2025-09-07T20:27:45,170 Created temporary directory: /tmp/pip-ephem-wheel-cache-8tnxfza3 2025-09-07T20:27:45,229 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-07T20:27:45,232 2 location(s) to search for versions of mycaptcha: 2025-09-07T20:27:45,232 * https://pypi.org/simple/mycaptcha/ 2025-09-07T20:27:45,232 * https://www.piwheels.org/simple/mycaptcha/ 2025-09-07T20:27:45,232 Fetching project page and analyzing links: https://pypi.org/simple/mycaptcha/ 2025-09-07T20:27:45,232 Getting page https://pypi.org/simple/mycaptcha/ 2025-09-07T20:27:45,234 Found index url https://pypi.org/simple/ 2025-09-07T20:27:45,381 Fetched page https://pypi.org/simple/mycaptcha/ as application/vnd.pypi.simple.v1+json 2025-09-07T20:27:45,383 Found link https://files.pythonhosted.org/packages/5b/18/a99dabce0bb631f58fcb5616fa662fa0b4a75c9c0afa09adc0eacbac2bfc/mycaptcha-1.9.tar.gz (from https://pypi.org/simple/mycaptcha/), version: 1.9 2025-09-07T20:27:45,384 Fetching project page and analyzing links: https://www.piwheels.org/simple/mycaptcha/ 2025-09-07T20:27:45,384 Getting page https://www.piwheels.org/simple/mycaptcha/ 2025-09-07T20:27:45,386 Found index url https://www.piwheels.org/simple/ 2025-09-07T20:27:45,486 Fetched page https://www.piwheels.org/simple/mycaptcha/ as text/html 2025-09-07T20:27:45,487 Skipping link: not a file: https://www.piwheels.org/simple/mycaptcha/ 2025-09-07T20:27:45,487 Skipping link: not a file: https://pypi.org/simple/mycaptcha/ 2025-09-07T20:27:45,513 Given no hashes to check 1 links for project 'mycaptcha': discarding no candidates 2025-09-07T20:27:45,515 Collecting mycaptcha==1.9 2025-09-07T20:27:45,516 Created temporary directory: /tmp/pip-unpack-iwwa0ibk 2025-09-07T20:27:45,657 Downloading mycaptcha-1.9.tar.gz (32 kB) 2025-09-07T20:27:45,689 Added mycaptcha==1.9 from https://files.pythonhosted.org/packages/5b/18/a99dabce0bb631f58fcb5616fa662fa0b4a75c9c0afa09adc0eacbac2bfc/mycaptcha-1.9.tar.gz to build tracker '/tmp/pip-build-tracker-_4903ehv' 2025-09-07T20:27:45,690 Running setup.py (path:/tmp/pip-wheel-y8demxu9/mycaptcha_aa2034102e274bcba8f16c05ecedc70d/setup.py) egg_info for package mycaptcha 2025-09-07T20:27:45,691 Created temporary directory: /tmp/pip-pip-egg-info-2uzdhm5c 2025-09-07T20:27:45,691 Preparing metadata (setup.py): started 2025-09-07T20:27:45,692 Running command python setup.py egg_info 2025-09-07T20:27:46,850 /usr/local/lib/python3.13/dist-packages/setuptools/dist.py:759: SetuptoolsDeprecationWarning: License classifiers are deprecated. 2025-09-07T20:27:46,850 !! 2025-09-07T20:27:46,851 ******************************************************************************** 2025-09-07T20:27:46,851 Please consider removing the following classifiers in favor of a SPDX license expression: 2025-09-07T20:27:46,851 License :: Public Domain 2025-09-07T20:27:46,851 See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details. 2025-09-07T20:27:46,851 ******************************************************************************** 2025-09-07T20:27:46,851 !! 2025-09-07T20:27:46,851 self._finalize_license_expression() 2025-09-07T20:27:46,924 running egg_info 2025-09-07T20:27:47,000 creating /tmp/pip-pip-egg-info-2uzdhm5c/mycaptcha.egg-info 2025-09-07T20:27:47,000 writing /tmp/pip-pip-egg-info-2uzdhm5c/mycaptcha.egg-info/PKG-INFO 2025-09-07T20:27:47,001 writing dependency_links to /tmp/pip-pip-egg-info-2uzdhm5c/mycaptcha.egg-info/dependency_links.txt 2025-09-07T20:27:47,002 writing top-level names to /tmp/pip-pip-egg-info-2uzdhm5c/mycaptcha.egg-info/top_level.txt 2025-09-07T20:27:47,003 writing manifest file '/tmp/pip-pip-egg-info-2uzdhm5c/mycaptcha.egg-info/SOURCES.txt' 2025-09-07T20:27:47,297 reading manifest file '/tmp/pip-pip-egg-info-2uzdhm5c/mycaptcha.egg-info/SOURCES.txt' 2025-09-07T20:27:47,298 reading manifest template 'MANIFEST.in' 2025-09-07T20:27:47,301 writing manifest file '/tmp/pip-pip-egg-info-2uzdhm5c/mycaptcha.egg-info/SOURCES.txt' 2025-09-07T20:27:47,415 Preparing metadata (setup.py): finished with status 'done' 2025-09-07T20:27:47,419 Source in /tmp/pip-wheel-y8demxu9/mycaptcha_aa2034102e274bcba8f16c05ecedc70d has version 1.9, which satisfies requirement mycaptcha==1.9 from https://files.pythonhosted.org/packages/5b/18/a99dabce0bb631f58fcb5616fa662fa0b4a75c9c0afa09adc0eacbac2bfc/mycaptcha-1.9.tar.gz 2025-09-07T20:27:47,420 Removed mycaptcha==1.9 from https://files.pythonhosted.org/packages/5b/18/a99dabce0bb631f58fcb5616fa662fa0b4a75c9c0afa09adc0eacbac2bfc/mycaptcha-1.9.tar.gz from build tracker '/tmp/pip-build-tracker-_4903ehv' 2025-09-07T20:27:47,422 Created temporary directory: /tmp/pip-unpack-_7_5gxt1 2025-09-07T20:27:47,423 Created temporary directory: /tmp/pip-unpack-3k2n2yhc 2025-09-07T20:27:47,423 Building wheels for collected packages: mycaptcha 2025-09-07T20:27:47,424 Created temporary directory: /tmp/pip-wheel-r61m_cq2 2025-09-07T20:27:47,425 DEPRECATION: Building 'mycaptcha' using the legacy setup.py bdist_wheel mechanism, which will be removed in a future version. pip 25.3 will enforce this behaviour change. A possible replacement is to use the standardized build interface by setting the `--use-pep517` option, (possibly combined with `--no-build-isolation`), or adding a `pyproject.toml` file to the source tree of 'mycaptcha'. Discussion can be found at https://github.com/pypa/pip/issues/6334 2025-09-07T20:27:47,426 Building wheel for mycaptcha (setup.py): started 2025-09-07T20:27:47,426 Destination directory: /tmp/pip-wheel-r61m_cq2 2025-09-07T20:27:47,426 Running command python setup.py bdist_wheel 2025-09-07T20:27:48,503 /usr/local/lib/python3.13/dist-packages/setuptools/dist.py:759: SetuptoolsDeprecationWarning: License classifiers are deprecated. 2025-09-07T20:27:48,503 !! 2025-09-07T20:27:48,503 ******************************************************************************** 2025-09-07T20:27:48,503 Please consider removing the following classifiers in favor of a SPDX license expression: 2025-09-07T20:27:48,503 License :: Public Domain 2025-09-07T20:27:48,503 See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details. 2025-09-07T20:27:48,504 ******************************************************************************** 2025-09-07T20:27:48,504 !! 2025-09-07T20:27:48,504 self._finalize_license_expression() 2025-09-07T20:27:48,504 running bdist_wheel 2025-09-07T20:27:48,876 running build 2025-09-07T20:27:48,876 running build_py 2025-09-07T20:27:48,952 creating build/lib.linux-armv7l-cpython-313/mycaptcha 2025-09-07T20:27:48,953 copying mycaptcha/__init__.py -> build/lib.linux-armv7l-cpython-313/mycaptcha 2025-09-07T20:27:48,953 copying mycaptcha/fake_captchaimage.py -> build/lib.linux-armv7l-cpython-313/mycaptcha 2025-09-07T20:27:48,954 running egg_info 2025-09-07T20:27:49,028 writing mycaptcha.egg-info/PKG-INFO 2025-09-07T20:27:49,029 writing dependency_links to mycaptcha.egg-info/dependency_links.txt 2025-09-07T20:27:49,029 writing top-level names to mycaptcha.egg-info/top_level.txt 2025-09-07T20:27:49,105 reading manifest file 'mycaptcha.egg-info/SOURCES.txt' 2025-09-07T20:27:49,106 reading manifest template 'MANIFEST.in' 2025-09-07T20:27:49,109 writing manifest file 'mycaptcha.egg-info/SOURCES.txt' 2025-09-07T20:27:49,110 copying mycaptcha/font.ttf -> build/lib.linux-armv7l-cpython-313/mycaptcha 2025-09-07T20:27:49,111 running build_ext 2025-09-07T20:27:49,448 building 'captchaimage' extension 2025-09-07T20:27:49,449 creating build/temp.linux-armv7l-cpython-313 2025-09-07T20:27:49,449 arm-linux-gnueabihf-gcc -fno-strict-overflow -Wsign-compare -DNDEBUG -g -O2 -Wall -fPIC -I/usr/include/freetype2 -I/usr/include/python3.13 -c captchaimage.c -o build/temp.linux-armv7l-cpython-313/captchaimage.o 2025-09-07T20:27:49,824 captchaimage.c: In function ‘create_image_internal’: 2025-09-07T20:27:49,824 captchaimage.c:18:40: error: ‘PyExc_StandardError’ undeclared (first use in this function); did you mean ‘PyExc_SyntaxError’? 2025-09-07T20:27:49,824 18 | #define RAISE(message) PyErr_SetString(PyExc_StandardError, message); \ 2025-09-07T20:27:49,825 | ^~~~~~~~~~~~~~~~~~~ 2025-09-07T20:27:49,825 captchaimage.c:89:7: note: in expansion of macro ‘RAISE’ 2025-09-07T20:27:49,825 89 | RAISE("failed to load font face"); 2025-09-07T20:27:49,825 | ^~~~~ 2025-09-07T20:27:49,825 captchaimage.c:18:40: note: each undeclared identifier is reported only once for each function it appears in 2025-09-07T20:27:49,825 18 | #define RAISE(message) PyErr_SetString(PyExc_StandardError, message); \ 2025-09-07T20:27:49,825 | ^~~~~~~~~~~~~~~~~~~ 2025-09-07T20:27:49,825 captchaimage.c:89:7: note: in expansion of macro ‘RAISE’ 2025-09-07T20:27:49,825 89 | RAISE("failed to load font face"); 2025-09-07T20:27:49,825 | ^~~~~ 2025-09-07T20:27:49,827 captchaimage.c:225:35: warning: comparison of integer expressions of different signedness: ‘unsigned int’ and ‘int’ [-Wsign-compare] 2025-09-07T20:27:49,827 225 | int offset_y = bitmap->rows < image_size_y 2025-09-07T20:27:49,827 | ^ 2025-09-07T20:27:49,827 captchaimage.c:228:33: warning: comparison of integer expressions of different signedness: ‘unsigned int’ and ‘int’ [-Wsign-compare] 2025-09-07T20:27:49,827 228 | int x_max = bitmap->width < image_size_x - offset_y 2025-09-07T20:27:49,828 | ^ 2025-09-07T20:27:49,828 captchaimage.c:229:27: warning: operand of ‘?:’ changes signedness from ‘int’ to ‘unsigned int’ due to unsignedness of other operand [-Wsign-compare] 2025-09-07T20:27:49,828 229 | ? bitmap->width : image_size_x - offset_y; 2025-09-07T20:27:49,828 | ^~~~~~~~~~~~~~~~~~~~~~~ 2025-09-07T20:27:49,828 captchaimage.c:230:32: warning: comparison of integer expressions of different signedness: ‘unsigned int’ and ‘int’ [-Wsign-compare] 2025-09-07T20:27:49,828 230 | int y_max = bitmap->rows < image_size_y ? bitmap->rows : image_size_y; 2025-09-07T20:27:49,828 | ^ 2025-09-07T20:27:49,828 captchaimage.c:230:64: warning: operand of ‘?:’ changes signedness from ‘int’ to ‘unsigned int’ due to unsignedness of other operand [-Wsign-compare] 2025-09-07T20:27:49,828 230 | int y_max = bitmap->rows < image_size_y ? bitmap->rows : image_size_y; 2025-09-07T20:27:49,828 | ^~~~~~~~~~~~ 2025-09-07T20:27:49,843 captchaimage.c:279:21: error: implicit declaration of function ‘PyString_FromStringAndSize’; did you mean ‘PyBytes_FromStringAndSize’? [-Wimplicit-function-declaration] 2025-09-07T20:27:49,844 279 | PyObject *value = PyString_FromStringAndSize(cropped_image, 2025-09-07T20:27:49,844 | ^~~~~~~~~~~~~~~~~~~~~~~~~~ 2025-09-07T20:27:49,844 | PyBytes_FromStringAndSize 2025-09-07T20:27:49,844 captchaimage.c:279:21: error: initialization of ‘PyObject *’ {aka ‘struct _object *’} from ‘int’ makes pointer from integer without a cast [-Wint-conversion] 2025-09-07T20:27:49,861 captchaimage.c: In function ‘captchaimage_create_image’: 2025-09-07T20:27:49,862 captchaimage.c:18:40: error: ‘PyExc_StandardError’ undeclared (first use in this function); did you mean ‘PyExc_SyntaxError’? 2025-09-07T20:27:49,862 18 | #define RAISE(message) PyErr_SetString(PyExc_StandardError, message); \ 2025-09-07T20:27:49,862 | ^~~~~~~~~~~~~~~~~~~ 2025-09-07T20:27:49,862 captchaimage.c:307:7: note: in expansion of macro ‘RAISE’ 2025-09-07T20:27:49,862 307 | RAISE("failed to initialize Freetype"); 2025-09-07T20:27:49,862 | ^~~~~ 2025-09-07T20:27:49,873 captchaimage.c: In function ‘initcaptchaimage’: 2025-09-07T20:27:49,873 captchaimage.c:332:3: error: implicit declaration of function ‘Py_InitModule’ [-Wimplicit-function-declaration] 2025-09-07T20:27:49,873 332 | Py_InitModule("captchaimage", captchaimage_methods); 2025-09-07T20:27:49,873 | ^~~~~~~~~~~~~ 2025-09-07T20:27:49,876 captchaimage.c:333:1: warning: control reaches end of non-void function [-Wreturn-type] 2025-09-07T20:27:49,876 333 | } 2025-09-07T20:27:49,877 | ^ 2025-09-07T20:27:49,885 error: command '/usr/bin/arm-linux-gnueabihf-gcc' failed with exit code 1 2025-09-07T20:27:50,033 ERROR: python setup.py bdist_wheel exited with 1 2025-09-07T20:27:50,044 [bold magenta]full command[/]: [blue]/usr/bin/python3 -u -c ' 2025-09-07T20:27:50,044 exec(compile('"'"''"'"''"'"' 2025-09-07T20:27:50,044 # This is -- a caller that pip uses to run setup.py 2025-09-07T20:27:50,044 # 2025-09-07T20:27:50,044 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-07T20:27:50,044 # import from `distutils.core` to work with newer packaging standards. 2025-09-07T20:27:50,044 # - It provides a clear error message when setuptools is not installed. 2025-09-07T20:27:50,044 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-07T20:27:50,044 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-07T20:27:50,044 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-07T20:27:50,044 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-07T20:27:50,044 import os, sys, tokenize, traceback 2025-09-07T20:27:50,044 2025-09-07T20:27:50,044 try: 2025-09-07T20:27:50,044 import setuptools 2025-09-07T20:27:50,044 except ImportError: 2025-09-07T20:27:50,044 print( 2025-09-07T20:27:50,044 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-07T20:27:50,044 "the build environment with exception:", 2025-09-07T20:27:50,044 file=sys.stderr, 2025-09-07T20:27:50,044 ) 2025-09-07T20:27:50,044 traceback.print_exc() 2025-09-07T20:27:50,044 sys.exit(1) 2025-09-07T20:27:50,044 2025-09-07T20:27:50,044 __file__ = %r 2025-09-07T20:27:50,044 sys.argv[0] = __file__ 2025-09-07T20:27:50,044 2025-09-07T20:27:50,044 if os.path.exists(__file__): 2025-09-07T20:27:50,044 filename = __file__ 2025-09-07T20:27:50,044 with tokenize.open(__file__) as f: 2025-09-07T20:27:50,044 setup_py_code = f.read() 2025-09-07T20:27:50,044 else: 2025-09-07T20:27:50,044 filename = "" 2025-09-07T20:27:50,044 setup_py_code = "from setuptools import setup; setup()" 2025-09-07T20:27:50,044 2025-09-07T20:27:50,044 exec(compile(setup_py_code, filename, "exec")) 2025-09-07T20:27:50,044 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-y8demxu9/mycaptcha_aa2034102e274bcba8f16c05ecedc70d/setup.py'"'"',), "", "exec"))' bdist_wheel -d /tmp/pip-wheel-r61m_cq2[/] 2025-09-07T20:27:50,045 [bold magenta]cwd[/]: /tmp/pip-wheel-y8demxu9/mycaptcha_aa2034102e274bcba8f16c05ecedc70d/ 2025-09-07T20:27:50,045 Building wheel for mycaptcha (setup.py): finished with status 'error' 2025-09-07T20:27:50,045 ERROR: Failed building wheel for mycaptcha 2025-09-07T20:27:50,046 Running setup.py clean for mycaptcha 2025-09-07T20:27:50,047 Running command python setup.py clean 2025-09-07T20:27:51,110 /usr/local/lib/python3.13/dist-packages/setuptools/dist.py:759: SetuptoolsDeprecationWarning: License classifiers are deprecated. 2025-09-07T20:27:51,111 !! 2025-09-07T20:27:51,111 ******************************************************************************** 2025-09-07T20:27:51,111 Please consider removing the following classifiers in favor of a SPDX license expression: 2025-09-07T20:27:51,111 License :: Public Domain 2025-09-07T20:27:51,111 See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details. 2025-09-07T20:27:51,112 ******************************************************************************** 2025-09-07T20:27:51,112 !! 2025-09-07T20:27:51,112 self._finalize_license_expression() 2025-09-07T20:27:51,186 running clean 2025-09-07T20:27:51,332 removing 'build/temp.linux-armv7l-cpython-313' (and everything under it) 2025-09-07T20:27:51,332 removing 'build/lib.linux-armv7l-cpython-313' (and everything under it) 2025-09-07T20:27:51,332 'build/bdist.linux-armv7l' does not exist -- can't clean it 2025-09-07T20:27:51,332 'build/scripts-3.13' does not exist -- can't clean it 2025-09-07T20:27:51,333 removing 'build' 2025-09-07T20:27:51,446 Failed to build mycaptcha 2025-09-07T20:27:51,446 ERROR: Failed to build one or more wheels 2025-09-07T20:27:51,447 Exception information: 2025-09-07T20:27:51,447 Traceback (most recent call last): 2025-09-07T20:27:51,447 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-07T20:27:51,447 status = _inner_run() 2025-09-07T20:27:51,447 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-07T20:27:51,447 return self.run(options, args) 2025-09-07T20:27:51,447 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-07T20:27:51,447 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-07T20:27:51,447 return func(self, options, args) 2025-09-07T20:27:51,447 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 180, in run 2025-09-07T20:27:51,447 raise CommandError("Failed to build one or more wheels") 2025-09-07T20:27:51,447 pip._internal.exceptions.CommandError: Failed to build one or more wheels 2025-09-07T20:27:51,451 Removed build tracker: '/tmp/pip-build-tracker-_4903ehv'