2025-09-08T19:51:36,061 Created temporary directory: /tmp/pip-build-tracker-iu0aauaw 2025-09-08T19:51:36,062 Initialized build tracking at /tmp/pip-build-tracker-iu0aauaw 2025-09-08T19:51:36,062 Created build tracker: /tmp/pip-build-tracker-iu0aauaw 2025-09-08T19:51:36,062 Entered build tracker: /tmp/pip-build-tracker-iu0aauaw 2025-09-08T19:51:36,063 Created temporary directory: /tmp/pip-wheel-zajwpr1m 2025-09-08T19:51:36,066 Created temporary directory: /tmp/pip-ephem-wheel-cache-wyvosx56 2025-09-08T19:51:36,124 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-08T19:51:36,126 2 location(s) to search for versions of zen-quotes: 2025-09-08T19:51:36,126 * https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:36,126 * https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:36,127 Fetching project page and analyzing links: https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:36,127 Getting page https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:36,129 Found index url https://pypi.org/simple/ 2025-09-08T19:51:36,202 Fetched page https://pypi.org/simple/zen-quotes/ as application/vnd.pypi.simple.v1+json 2025-09-08T19:51:36,204 Found link https://files.pythonhosted.org/packages/0e/f7/1eb7098049df10c4d4e2aa43461497117ea5036197ae944dd7e0b9f5889a/zen_quotes-1.0.0.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.0.0 2025-09-08T19:51:36,205 Found link https://files.pythonhosted.org/packages/26/43/cb464ecdd52bf0eb451e13a43b3c96e20c50460d850a6b1069a480c22926/zen_quotes-1.0.1.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.0.1 2025-09-08T19:51:36,205 Found link https://files.pythonhosted.org/packages/9a/57/3591362e1b546752e17bab17e08d35e98cf442790296caa42f808eedb2f4/zen_quotes-1.0.3.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.0.3 2025-09-08T19:51:36,205 Found link https://files.pythonhosted.org/packages/87/93/7af85264e39e537c394e57818bb9ab38b17e5d3cfdbff178927a46d65ff0/zen_quotes-1.0.4.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.0.4 2025-09-08T19:51:36,206 Found link https://files.pythonhosted.org/packages/c9/e6/5b0a9a9dec5e7e4e7ab64d9b55a68502aed512fd4cd1341ff1f6f220b484/zen_quotes-1.0.5.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.0.5 2025-09-08T19:51:36,206 Found link https://files.pythonhosted.org/packages/21/94/d65740e66a0c0a83de836bbb67c2d32b3e14f7a34d16edc3efa3add9f2ae/zen_quotes-1.0.6.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.0.6 2025-09-08T19:51:36,206 Found link https://files.pythonhosted.org/packages/6d/2c/80141631fb0576d82e94abfd7943a771c71e08143e5c62d875f68e415641/zen_quotes-1.0.7.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.0.7 2025-09-08T19:51:36,207 Skipping link: No binaries permitted for zen-quotes: https://files.pythonhosted.org/packages/54/2e/06bb9f64211cf0de87a64fd27d271795b8c50d2184183be7c2372eaa25c7/zen_quotes-1.1.0-py3-none-any.whl (from https://pypi.org/simple/zen-quotes/) 2025-09-08T19:51:36,207 Found link https://files.pythonhosted.org/packages/e3/2e/0d9067308a58ddbae8973ddac341a6b13a7d9dcca5d976057f79a27ba1ac/zen_quotes-1.1.0.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.1.0 2025-09-08T19:51:36,207 Skipping link: No binaries permitted for zen-quotes: https://files.pythonhosted.org/packages/1e/b8/bc622afc08498312b5fc1a412a591996a873eedee790d534cdbe3fa3ea1d/zen_quotes-1.1.1-py3-none-any.whl (from https://pypi.org/simple/zen-quotes/) 2025-09-08T19:51:36,207 Found link https://files.pythonhosted.org/packages/16/b0/e8720de0c230b61941d6ccf278bf57e194cf04c9ba9315cf00ddda4bab65/zen_quotes-1.1.1.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.1.1 2025-09-08T19:51:36,207 Skipping link: No binaries permitted for zen-quotes: https://files.pythonhosted.org/packages/9c/30/579b7d28955a497a428f562ce92854bbba5f9e87f98bcda0c75e685618c8/zen_quotes-1.1.2-py3-none-any.whl (from https://pypi.org/simple/zen-quotes/) 2025-09-08T19:51:36,208 Found link https://files.pythonhosted.org/packages/dc/71/b4f940dd7edbb64a5ac98f460cc48d85cf2b580f57e31a7eb10e955f8b4e/zen_quotes-1.1.2.tar.gz (from https://pypi.org/simple/zen-quotes/), version: 1.1.2 2025-09-08T19:51:36,208 Fetching project page and analyzing links: https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:36,208 Getting page https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:36,209 Found index url https://www.piwheels.org/simple/ 2025-09-08T19:51:36,309 Fetched page https://www.piwheels.org/simple/zen-quotes/ as text/html 2025-09-08T19:51:36,311 Skipping link: No binaries permitted for zen-quotes: https://archive1.piwheels.org/simple/zen-quotes/zen_quotes-1.1.2-py3-none-any.whl#sha256=2efdef9ab71873107a813d93dc180c1ba896371c3449daf868f280a890784f30 (from https://www.piwheels.org/simple/zen-quotes/) 2025-09-08T19:51:36,311 Skipping link: No binaries permitted for zen-quotes: https://archive1.piwheels.org/simple/zen-quotes/zen_quotes-1.1.1-py3-none-any.whl#sha256=b9b83d75c0d6537e516d0df099f3f5c0e30d4dd9abe65385a56927aa2823c849 (from https://www.piwheels.org/simple/zen-quotes/) 2025-09-08T19:51:36,311 Skipping link: No binaries permitted for zen-quotes: https://archive1.piwheels.org/simple/zen-quotes/zen_quotes-1.1.0-py3-none-any.whl#sha256=98a4fba607a749f683ecfa82c7c060df02fc7d3a1039c42dd9187b0bc16b8241 (from https://www.piwheels.org/simple/zen-quotes/) 2025-09-08T19:51:36,311 Skipping link: No binaries permitted for zen-quotes: https://archive1.piwheels.org/simple/zen-quotes/zen_quotes-1.0.7-py3-none-any.whl#sha256=9622b8ee6a8f34eeadc4adfc0e6297a0e84166683b6f56f44a49ed2718fb9ad7 (from https://www.piwheels.org/simple/zen-quotes/) 2025-09-08T19:51:36,311 Skipping link: No binaries permitted for zen-quotes: https://archive1.piwheels.org/simple/zen-quotes/zen_quotes-1.0.6-py3-none-any.whl#sha256=5a0235969b567a1ef053b9799c185254f48ecae39cb141443d1b08b5699a15ac (from https://www.piwheels.org/simple/zen-quotes/) 2025-09-08T19:51:36,311 Skipping link: No binaries permitted for zen-quotes: https://archive1.piwheels.org/simple/zen-quotes/zen_quotes-1.0.1-py3-none-any.whl#sha256=c2d7fd15224a2053e71e3cc8105c390dc704a6757bab8d0294b7701d9bdf3d3f (from https://www.piwheels.org/simple/zen-quotes/) 2025-09-08T19:51:36,311 Skipping link: not a file: https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:36,312 Skipping link: not a file: https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:36,334 Given no hashes to check 1 links for project 'zen-quotes': discarding no candidates 2025-09-08T19:51:36,335 Collecting zen-quotes==1.0.3 2025-09-08T19:51:36,337 Created temporary directory: /tmp/pip-unpack-_o74ddrz 2025-09-08T19:51:36,475 Downloading zen_quotes-1.0.3.tar.gz (780 bytes) 2025-09-08T19:51:36,493 Added zen-quotes==1.0.3 from https://files.pythonhosted.org/packages/9a/57/3591362e1b546752e17bab17e08d35e98cf442790296caa42f808eedb2f4/zen_quotes-1.0.3.tar.gz to build tracker '/tmp/pip-build-tracker-iu0aauaw' 2025-09-08T19:51:36,495 Running setup.py (path:/tmp/pip-wheel-zajwpr1m/zen-quotes_15b56fe1cd08416980f816e7078cbb74/setup.py) egg_info for package zen-quotes 2025-09-08T19:51:36,496 Created temporary directory: /tmp/pip-pip-egg-info-hom70sxn 2025-09-08T19:51:36,496 Preparing metadata (setup.py): started 2025-09-08T19:51:36,498 Running command python setup.py egg_info 2025-09-08T19:51:37,014 Traceback (most recent call last): 2025-09-08T19:51:37,015 File "", line 2, in 2025-09-08T19:51:37,015 exec(compile(''' 2025-09-08T19:51:37,015 ~~~~^^^^^^^^^^^^ 2025-09-08T19:51:37,016 # This is -- a caller that pip uses to run setup.py 2025-09-08T19:51:37,016 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,016 ...<32 lines>... 2025-09-08T19:51:37,016 exec(compile(setup_py_code, filename, "exec")) 2025-09-08T19:51:37,016 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,016 ''' % ('/tmp/pip-wheel-zajwpr1m/zen-quotes_15b56fe1cd08416980f816e7078cbb74/setup.py',), "", "exec")) 2025-09-08T19:51:37,016 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,016 File "", line 35, in 2025-09-08T19:51:37,017 File "/tmp/pip-wheel-zajwpr1m/zen-quotes_15b56fe1cd08416980f816e7078cbb74/setup.py", line 4, in 2025-09-08T19:51:37,017 with open("requirements.txt") as req: 2025-09-08T19:51:37,017 ~~~~^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,017 FileNotFoundError: [Errno 2] No such file or directory: 'requirements.txt' 2025-09-08T19:51:37,101 ERROR: python setup.py egg_info exited with 1 2025-09-08T19:51:37,112 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-08T19:51:37,112 exec(compile('"'"''"'"''"'"' 2025-09-08T19:51:37,112 # This is -- a caller that pip uses to run setup.py 2025-09-08T19:51:37,112 # 2025-09-08T19:51:37,112 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-08T19:51:37,112 # import from `distutils.core` to work with newer packaging standards. 2025-09-08T19:51:37,112 # - It provides a clear error message when setuptools is not installed. 2025-09-08T19:51:37,112 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-08T19:51:37,112 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-08T19:51:37,112 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-08T19:51:37,112 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-08T19:51:37,112 import os, sys, tokenize, traceback 2025-09-08T19:51:37,112 2025-09-08T19:51:37,112 try: 2025-09-08T19:51:37,112 import setuptools 2025-09-08T19:51:37,112 except ImportError: 2025-09-08T19:51:37,112 print( 2025-09-08T19:51:37,112 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-08T19:51:37,112 "the build environment with exception:", 2025-09-08T19:51:37,112 file=sys.stderr, 2025-09-08T19:51:37,112 ) 2025-09-08T19:51:37,112 traceback.print_exc() 2025-09-08T19:51:37,112 sys.exit(1) 2025-09-08T19:51:37,112 2025-09-08T19:51:37,112 __file__ = %r 2025-09-08T19:51:37,112 sys.argv[0] = __file__ 2025-09-08T19:51:37,112 2025-09-08T19:51:37,112 if os.path.exists(__file__): 2025-09-08T19:51:37,112 filename = __file__ 2025-09-08T19:51:37,112 with tokenize.open(__file__) as f: 2025-09-08T19:51:37,112 setup_py_code = f.read() 2025-09-08T19:51:37,112 else: 2025-09-08T19:51:37,112 filename = "" 2025-09-08T19:51:37,112 setup_py_code = "from setuptools import setup; setup()" 2025-09-08T19:51:37,112 2025-09-08T19:51:37,112 exec(compile(setup_py_code, filename, "exec")) 2025-09-08T19:51:37,112 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-zajwpr1m/zen-quotes_15b56fe1cd08416980f816e7078cbb74/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-hom70sxn[/] 2025-09-08T19:51:37,112 [bold magenta]cwd[/]: /tmp/pip-wheel-zajwpr1m/zen-quotes_15b56fe1cd08416980f816e7078cbb74/ 2025-09-08T19:51:37,113 Preparing metadata (setup.py): finished with status 'error' 2025-09-08T19:51:37,113 ERROR: metadata generation failed 2025-09-08T19:51:37,118 Exception information: 2025-09-08T19:51:37,118 Traceback (most recent call last): 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-08T19:51:37,118 call_subprocess( 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~^ 2025-09-08T19:51:37,118 args, 2025-09-08T19:51:37,118 ^^^^^ 2025-09-08T19:51:37,118 ...<2 lines>... 2025-09-08T19:51:37,118 spinner=spinner, 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 ^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-08T19:51:37,118 raise error 2025-09-08T19:51:37,118 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-08T19:51:37,118 2025-09-08T19:51:37,118 The above exception was the direct cause of the following exception: 2025-09-08T19:51:37,118 2025-09-08T19:51:37,118 Traceback (most recent call last): 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-08T19:51:37,118 status = _inner_run() 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-08T19:51:37,118 return self.run(options, args) 2025-09-08T19:51:37,118 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-08T19:51:37,118 return func(self, options, args) 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-08T19:51:37,118 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-08T19:51:37,118 result = self._result = resolver.resolve( 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:37,118 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 ^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-08T19:51:37,118 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-08T19:51:37,118 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-08T19:51:37,118 if not criterion.candidates: 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-08T19:51:37,118 return bool(self._sequence) 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-08T19:51:37,118 self._bool = any(self) 2025-09-08T19:51:37,118 ~~~^^^^^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-08T19:51:37,118 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-08T19:51:37,118 ^^^^^^^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-08T19:51:37,118 candidate = func() 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-08T19:51:37,118 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:37,118 link, template, name, version 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 ^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-08T19:51:37,118 self._link_candidate_cache[link] = LinkCandidate( 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~^ 2025-09-08T19:51:37,118 link, 2025-09-08T19:51:37,118 ^^^^^ 2025-09-08T19:51:37,118 ...<3 lines>... 2025-09-08T19:51:37,118 version=version, 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 ^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-08T19:51:37,118 super().__init__( 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:37,118 link=link, 2025-09-08T19:51:37,118 ^^^^^^^^^^ 2025-09-08T19:51:37,118 ...<4 lines>... 2025-09-08T19:51:37,118 version=version, 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 ^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-08T19:51:37,118 self.dist = self._prepare() 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-08T19:51:37,118 dist = self._prepare_distribution() 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-08T19:51:37,118 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-08T19:51:37,118 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-08T19:51:37,118 dist = _get_prepared_distribution( 2025-09-08T19:51:37,118 req, 2025-09-08T19:51:37,118 ...<3 lines>... 2025-09-08T19:51:37,118 self.check_build_deps, 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-08T19:51:37,118 abstract_dist.prepare_distribution_metadata( 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:37,118 finder, build_isolation, check_build_deps 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 ^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-08T19:51:37,118 self.req.prepare_metadata() 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-08T19:51:37,118 self.metadata_directory = generate_metadata_legacy( 2025-09-08T19:51:37,118 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:37,118 build_env=self.build_env, 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ...<3 lines>... 2025-09-08T19:51:37,118 details=details, 2025-09-08T19:51:37,118 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:37,118 ) 2025-09-08T19:51:37,118 ^ 2025-09-08T19:51:37,118 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-08T19:51:37,118 raise MetadataGenerationFailed(package_details=details) from error 2025-09-08T19:51:37,118 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-08T19:51:37,143 Removed zen-quotes==1.0.3 from https://files.pythonhosted.org/packages/9a/57/3591362e1b546752e17bab17e08d35e98cf442790296caa42f808eedb2f4/zen_quotes-1.0.3.tar.gz from build tracker '/tmp/pip-build-tracker-iu0aauaw' 2025-09-08T19:51:37,143 Removed build tracker: '/tmp/pip-build-tracker-iu0aauaw'