2025-09-11T18:54:33,870 Created temporary directory: /tmp/pip-build-tracker-8942dzks 2025-09-11T18:54:33,871 Initialized build tracking at /tmp/pip-build-tracker-8942dzks 2025-09-11T18:54:33,871 Created build tracker: /tmp/pip-build-tracker-8942dzks 2025-09-11T18:54:33,871 Entered build tracker: /tmp/pip-build-tracker-8942dzks 2025-09-11T18:54:33,871 Created temporary directory: /tmp/pip-wheel-q5xi6kfx 2025-09-11T18:54:33,874 Created temporary directory: /tmp/pip-ephem-wheel-cache-g2dn7ho9 2025-09-11T18:54:33,946 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-11T18:54:33,949 2 location(s) to search for versions of spafe: 2025-09-11T18:54:33,949 * https://pypi.org/simple/spafe/ 2025-09-11T18:54:33,949 * https://www.piwheels.org/simple/spafe/ 2025-09-11T18:54:33,950 Fetching project page and analyzing links: https://pypi.org/simple/spafe/ 2025-09-11T18:54:33,950 Getting page https://pypi.org/simple/spafe/ 2025-09-11T18:54:33,952 Found index url https://pypi.org/simple/ 2025-09-11T18:54:34,112 Fetched page https://pypi.org/simple/spafe/ as application/vnd.pypi.simple.v1+json 2025-09-11T18:54:34,115 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/4f/dc/0b61ac2a24d3e9bb931ce42cc2fa7434dbe79a10a60c8ccadf7d53eacc08/spafe-0.1.0-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,115 Found link https://files.pythonhosted.org/packages/de/f8/cd467bf63f4bec35724a05530bc68d96067c9bf465ceb794400bd3e18b31/spafe-0.1.0.tar.gz (from https://pypi.org/simple/spafe/), version: 0.1.0 2025-09-11T18:54:34,116 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/5d/72/9a25cb3f117e1751c66e1f3368d9a787f7ad2c226078b884b6d218a4c5eb/spafe-0.1.1-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,116 Found link https://files.pythonhosted.org/packages/66/7f/afa84bf97927b4e25608c11851e9ea6f024109cad24e47c6b09cd32bfb7a/spafe-0.1.1.tar.gz (from https://pypi.org/simple/spafe/), version: 0.1.1 2025-09-11T18:54:34,116 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/a9/d9/d92807657a5125318639aa1636c0a76fb87222d48b5c290996ed9d5be1b6/spafe-0.1.2-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,117 Found link https://files.pythonhosted.org/packages/03/bf/d761c5fc9d23ed92604c0f5c0b0644cbeb180d2e014090a27a8ecd3605c2/spafe-0.1.2.tar.gz (from https://pypi.org/simple/spafe/), version: 0.1.2 2025-09-11T18:54:34,117 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/a2/fe/0458e49f3a96bfb35acb913515fd1fdfe6d4d1a2b2fa522a6eb65525ae12/spafe-0.2.0-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,117 Found link https://files.pythonhosted.org/packages/93/23/79ceee53e9b75dac5def896406f2e5cf8c29520c3469abb28a15fbf2372b/spafe-0.2.0.tar.gz (from https://pypi.org/simple/spafe/), version: 0.2.0 2025-09-11T18:54:34,117 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/a2/34/0956d0181c62c227402a787f2afdd3a1b5d9a99da7077b9fd0e05b68d754/spafe-0.3.0-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,118 Skipping link: unsupported archive format: .egg: https://files.pythonhosted.org/packages/a0/7d/3b75d5f284af7a62d99482be0115f5c27a6a98bd195b7303b2ee8156720c/spafe-0.3.0-py3.9.egg (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,118 Found link https://files.pythonhosted.org/packages/98/40/4341759fc423fb66cb382737fc83596cbe58b621ac08c616be0aaa79b29b/spafe-0.3.0.tar.gz (from https://pypi.org/simple/spafe/), version: 0.3.0 2025-09-11T18:54:34,118 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/97/cf/0bc358d014c5c0ffb7b045d48cb8e0383b0a22382cd6bd86da0cbb84b1d3/spafe-0.3.1-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,118 Skipping link: unsupported archive format: .egg: https://files.pythonhosted.org/packages/09/a4/70fdb7c8b50cda49b0c0f73c61634a25ed971efc590af328d413a6f23b46/spafe-0.3.1-py3.8.egg (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,119 Found link https://files.pythonhosted.org/packages/a4/d5/57e0cef4a1716180451420a06e5393f2c7113b9f1d5dbad7d0551cec3986/spafe-0.3.1.tar.gz (from https://pypi.org/simple/spafe/), version: 0.3.1 2025-09-11T18:54:34,119 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/3c/07/10707dae2f307fdcc3c41f28c22dfd3e3d4130b92fe32fc078838814710b/spafe-0.3.2-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,119 Skipping link: unsupported archive format: .egg: https://files.pythonhosted.org/packages/e2/b9/b45384c7b2837e9524e7456c9580995d0b0779a1a557df4703c7af565296/spafe-0.3.2-py3.8.egg (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,119 Found link https://files.pythonhosted.org/packages/b2/8a/cbd93b4b566201231aec81caf688a7c7f9e4432339841e84b4ce2a8d26f4/spafe-0.3.2.tar.gz (from https://pypi.org/simple/spafe/), version: 0.3.2 2025-09-11T18:54:34,120 Skipping link: No binaries permitted for spafe: https://files.pythonhosted.org/packages/7e/b5/7c18d2faac033b928b872a4d69d5c9933c8946dc1df9007ad0f659924fed/spafe-0.3.3-py3-none-any.whl (from https://pypi.org/simple/spafe/) 2025-09-11T18:54:34,120 Found link https://files.pythonhosted.org/packages/3c/eb/86c0433f98b56870bd4a9548463ffa054302f01f6ca75151b7d364a1da7f/spafe-0.3.3.tar.gz (from https://pypi.org/simple/spafe/), version: 0.3.3 2025-09-11T18:54:34,120 Fetching project page and analyzing links: https://www.piwheels.org/simple/spafe/ 2025-09-11T18:54:34,121 Getting page https://www.piwheels.org/simple/spafe/ 2025-09-11T18:54:34,122 Found index url https://www.piwheels.org/simple/ 2025-09-11T18:54:34,223 Fetched page https://www.piwheels.org/simple/spafe/ as text/html 2025-09-11T18:54:34,225 Skipping link: No binaries permitted for spafe: https://archive1.piwheels.org/simple/spafe/spafe-0.2.0-py3-none-any.whl#sha256=2fcb67748b939f169a2c34cd91e8afc150cb245176f5e5df8181b7c51ee056f6 (from https://www.piwheels.org/simple/spafe/) 2025-09-11T18:54:34,225 Skipping link: No binaries permitted for spafe: https://archive1.piwheels.org/simple/spafe/spafe-0.1.2-py3-none-any.whl#sha256=65a33f3cfedb745dd92b839d2db0f39da01d4196b422b05a216c45a73f6df162 (from https://www.piwheels.org/simple/spafe/) 2025-09-11T18:54:34,225 Skipping link: No binaries permitted for spafe: https://archive1.piwheels.org/simple/spafe/spafe-0.1.1-py3-none-any.whl#sha256=6860111115474e0e33447b186f1d5c850e69f5b7f7632d383f133b2a75a8ebf5 (from https://www.piwheels.org/simple/spafe/) 2025-09-11T18:54:34,225 Skipping link: No binaries permitted for spafe: https://archive1.piwheels.org/simple/spafe/spafe-0.1.0-py3-none-any.whl#sha256=96ffd3bcf1e11c19fb82458cab505dce19f6b19740a639c59a93d7878f305bc1 (from https://www.piwheels.org/simple/spafe/) 2025-09-11T18:54:34,226 Skipping link: not a file: https://www.piwheels.org/simple/spafe/ 2025-09-11T18:54:34,226 Skipping link: not a file: https://pypi.org/simple/spafe/ 2025-09-11T18:54:34,255 Given no hashes to check 1 links for project 'spafe': discarding no candidates 2025-09-11T18:54:34,257 Collecting spafe==0.3.0 2025-09-11T18:54:34,258 Created temporary directory: /tmp/pip-unpack-3u917god 2025-09-11T18:54:34,408 Downloading spafe-0.3.0.tar.gz (50 kB) 2025-09-11T18:54:34,491 Added spafe==0.3.0 from https://files.pythonhosted.org/packages/98/40/4341759fc423fb66cb382737fc83596cbe58b621ac08c616be0aaa79b29b/spafe-0.3.0.tar.gz to build tracker '/tmp/pip-build-tracker-8942dzks' 2025-09-11T18:54:34,492 Running setup.py (path:/tmp/pip-wheel-q5xi6kfx/spafe_b0ea17cf337b40f99cbde129e2cab4c6/setup.py) egg_info for package spafe 2025-09-11T18:54:34,493 Created temporary directory: /tmp/pip-pip-egg-info-kzbj9ej_ 2025-09-11T18:54:34,493 Preparing metadata (setup.py): started 2025-09-11T18:54:34,494 Running command python setup.py egg_info 2025-09-11T18:54:35,046 Traceback (most recent call last): 2025-09-11T18:54:35,048 File "", line 2, in 2025-09-11T18:54:35,048 exec(compile(''' 2025-09-11T18:54:35,048 ~~~~^^^^^^^^^^^^ 2025-09-11T18:54:35,048 # This is -- a caller that pip uses to run setup.py 2025-09-11T18:54:35,049 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,049 ...<32 lines>... 2025-09-11T18:54:35,049 exec(compile(setup_py_code, filename, "exec")) 2025-09-11T18:54:35,050 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,050 ''' % ('/tmp/pip-wheel-q5xi6kfx/spafe_b0ea17cf337b40f99cbde129e2cab4c6/setup.py',), "", "exec")) 2025-09-11T18:54:35,050 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,050 File "", line 35, in 2025-09-11T18:54:35,051 File "/tmp/pip-wheel-q5xi6kfx/spafe_b0ea17cf337b40f99cbde129e2cab4c6/setup.py", line 13, in 2025-09-11T18:54:35,051 with open(here / "requirements.txt") as req_file: 2025-09-11T18:54:35,051 ~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,051 FileNotFoundError: [Errno 2] No such file or directory: '/tmp/pip-wheel-q5xi6kfx/spafe_b0ea17cf337b40f99cbde129e2cab4c6/requirements.txt' 2025-09-11T18:54:35,148 ERROR: python setup.py egg_info exited with 1 2025-09-11T18:54:35,162 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-11T18:54:35,162 exec(compile('"'"''"'"''"'"' 2025-09-11T18:54:35,162 # This is -- a caller that pip uses to run setup.py 2025-09-11T18:54:35,162 # 2025-09-11T18:54:35,162 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-11T18:54:35,162 # import from `distutils.core` to work with newer packaging standards. 2025-09-11T18:54:35,162 # - It provides a clear error message when setuptools is not installed. 2025-09-11T18:54:35,162 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-11T18:54:35,162 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-11T18:54:35,162 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-11T18:54:35,162 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-11T18:54:35,162 import os, sys, tokenize, traceback 2025-09-11T18:54:35,162 2025-09-11T18:54:35,162 try: 2025-09-11T18:54:35,162 import setuptools 2025-09-11T18:54:35,162 except ImportError: 2025-09-11T18:54:35,162 print( 2025-09-11T18:54:35,162 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-11T18:54:35,162 "the build environment with exception:", 2025-09-11T18:54:35,162 file=sys.stderr, 2025-09-11T18:54:35,162 ) 2025-09-11T18:54:35,162 traceback.print_exc() 2025-09-11T18:54:35,162 sys.exit(1) 2025-09-11T18:54:35,162 2025-09-11T18:54:35,162 __file__ = %r 2025-09-11T18:54:35,162 sys.argv[0] = __file__ 2025-09-11T18:54:35,162 2025-09-11T18:54:35,162 if os.path.exists(__file__): 2025-09-11T18:54:35,162 filename = __file__ 2025-09-11T18:54:35,162 with tokenize.open(__file__) as f: 2025-09-11T18:54:35,162 setup_py_code = f.read() 2025-09-11T18:54:35,162 else: 2025-09-11T18:54:35,162 filename = "" 2025-09-11T18:54:35,162 setup_py_code = "from setuptools import setup; setup()" 2025-09-11T18:54:35,162 2025-09-11T18:54:35,162 exec(compile(setup_py_code, filename, "exec")) 2025-09-11T18:54:35,162 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-q5xi6kfx/spafe_b0ea17cf337b40f99cbde129e2cab4c6/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-kzbj9ej_[/] 2025-09-11T18:54:35,162 [bold magenta]cwd[/]: /tmp/pip-wheel-q5xi6kfx/spafe_b0ea17cf337b40f99cbde129e2cab4c6/ 2025-09-11T18:54:35,162 Preparing metadata (setup.py): finished with status 'error' 2025-09-11T18:54:35,164 ERROR: metadata generation failed 2025-09-11T18:54:35,171 Exception information: 2025-09-11T18:54:35,171 Traceback (most recent call last): 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-11T18:54:35,171 call_subprocess( 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~^ 2025-09-11T18:54:35,171 args, 2025-09-11T18:54:35,171 ^^^^^ 2025-09-11T18:54:35,171 ...<2 lines>... 2025-09-11T18:54:35,171 spinner=spinner, 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 ^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-11T18:54:35,171 raise error 2025-09-11T18:54:35,171 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-11T18:54:35,171 2025-09-11T18:54:35,171 The above exception was the direct cause of the following exception: 2025-09-11T18:54:35,171 2025-09-11T18:54:35,171 Traceback (most recent call last): 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-11T18:54:35,171 status = _inner_run() 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-11T18:54:35,171 return self.run(options, args) 2025-09-11T18:54:35,171 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-11T18:54:35,171 return func(self, options, args) 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-11T18:54:35,171 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-11T18:54:35,171 result = self._result = resolver.resolve( 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~^ 2025-09-11T18:54:35,171 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 ^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-11T18:54:35,171 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-11T18:54:35,171 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-11T18:54:35,171 if not criterion.candidates: 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-11T18:54:35,171 return bool(self._sequence) 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-11T18:54:35,171 self._bool = any(self) 2025-09-11T18:54:35,171 ~~~^^^^^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-11T18:54:35,171 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-11T18:54:35,171 ^^^^^^^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-11T18:54:35,171 candidate = func() 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-11T18:54:35,171 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-11T18:54:35,171 link, template, name, version 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 ^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-11T18:54:35,171 self._link_candidate_cache[link] = LinkCandidate( 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~^ 2025-09-11T18:54:35,171 link, 2025-09-11T18:54:35,171 ^^^^^ 2025-09-11T18:54:35,171 ...<3 lines>... 2025-09-11T18:54:35,171 version=version, 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 ^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-11T18:54:35,171 super().__init__( 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~^ 2025-09-11T18:54:35,171 link=link, 2025-09-11T18:54:35,171 ^^^^^^^^^^ 2025-09-11T18:54:35,171 ...<4 lines>... 2025-09-11T18:54:35,171 version=version, 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 ^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-11T18:54:35,171 self.dist = self._prepare() 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-11T18:54:35,171 dist = self._prepare_distribution() 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-11T18:54:35,171 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-11T18:54:35,171 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-11T18:54:35,171 dist = _get_prepared_distribution( 2025-09-11T18:54:35,171 req, 2025-09-11T18:54:35,171 ...<3 lines>... 2025-09-11T18:54:35,171 self.check_build_deps, 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-11T18:54:35,171 abstract_dist.prepare_distribution_metadata( 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-11T18:54:35,171 finder, build_isolation, check_build_deps 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 ^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-11T18:54:35,171 self.req.prepare_metadata() 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-11T18:54:35,171 self.metadata_directory = generate_metadata_legacy( 2025-09-11T18:54:35,171 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-11T18:54:35,171 build_env=self.build_env, 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ...<3 lines>... 2025-09-11T18:54:35,171 details=details, 2025-09-11T18:54:35,171 ^^^^^^^^^^^^^^^^ 2025-09-11T18:54:35,171 ) 2025-09-11T18:54:35,171 ^ 2025-09-11T18:54:35,171 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-11T18:54:35,171 raise MetadataGenerationFailed(package_details=details) from error 2025-09-11T18:54:35,171 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-11T18:54:35,197 Removed spafe==0.3.0 from https://files.pythonhosted.org/packages/98/40/4341759fc423fb66cb382737fc83596cbe58b621ac08c616be0aaa79b29b/spafe-0.3.0.tar.gz from build tracker '/tmp/pip-build-tracker-8942dzks' 2025-09-11T18:54:35,197 Removed build tracker: '/tmp/pip-build-tracker-8942dzks'