2025-09-08T19:51:33,755 Created temporary directory: /tmp/pip-build-tracker-769sri16 2025-09-08T19:51:33,756 Initialized build tracking at /tmp/pip-build-tracker-769sri16 2025-09-08T19:51:33,756 Created build tracker: /tmp/pip-build-tracker-769sri16 2025-09-08T19:51:33,756 Entered build tracker: /tmp/pip-build-tracker-769sri16 2025-09-08T19:51:33,757 Created temporary directory: /tmp/pip-wheel-timz1l5p 2025-09-08T19:51:33,760 Created temporary directory: /tmp/pip-ephem-wheel-cache-_t4fpyxq 2025-09-08T19:51:33,819 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-08T19:51:33,821 2 location(s) to search for versions of zen-quotes: 2025-09-08T19:51:33,821 * https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:33,821 * https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:33,821 Fetching project page and analyzing links: https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:33,822 Getting page https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:33,823 Found index url https://pypi.org/simple/ 2025-09-08T19:51:33,967 Fetched page https://pypi.org/simple/zen-quotes/ as application/vnd.pypi.simple.v1+json 2025-09-08T19:51:33,972 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:33,973 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:33,973 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:33,974 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:33,974 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:33,975 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:33,975 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:33,976 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:33,976 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:33,976 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:33,977 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:33,977 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:33,978 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:33,978 Fetching project page and analyzing links: https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:33,979 Getting page https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:33,981 Found index url https://www.piwheels.org/simple/ 2025-09-08T19:51:34,078 Fetched page https://www.piwheels.org/simple/zen-quotes/ as text/html 2025-09-08T19:51:34,080 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:34,080 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:34,080 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:34,080 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:34,080 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:34,081 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:34,081 Skipping link: not a file: https://www.piwheels.org/simple/zen-quotes/ 2025-09-08T19:51:34,081 Skipping link: not a file: https://pypi.org/simple/zen-quotes/ 2025-09-08T19:51:34,105 Given no hashes to check 1 links for project 'zen-quotes': discarding no candidates 2025-09-08T19:51:34,106 Collecting zen-quotes==1.0.0 2025-09-08T19:51:34,107 Created temporary directory: /tmp/pip-unpack-r5ldo8kv 2025-09-08T19:51:34,249 Downloading zen_quotes-1.0.0.tar.gz (1.1 kB) 2025-09-08T19:51:34,270 Added zen-quotes==1.0.0 from https://files.pythonhosted.org/packages/0e/f7/1eb7098049df10c4d4e2aa43461497117ea5036197ae944dd7e0b9f5889a/zen_quotes-1.0.0.tar.gz to build tracker '/tmp/pip-build-tracker-769sri16' 2025-09-08T19:51:34,272 Running setup.py (path:/tmp/pip-wheel-timz1l5p/zen-quotes_701b18c4802f4710b468aad114e5dfa0/setup.py) egg_info for package zen-quotes 2025-09-08T19:51:34,273 Created temporary directory: /tmp/pip-pip-egg-info-uuqjhcz3 2025-09-08T19:51:34,273 Preparing metadata (setup.py): started 2025-09-08T19:51:34,274 Running command python setup.py egg_info 2025-09-08T19:51:34,801 Traceback (most recent call last): 2025-09-08T19:51:34,802 File "", line 2, in 2025-09-08T19:51:34,802 exec(compile(''' 2025-09-08T19:51:34,802 ~~~~^^^^^^^^^^^^ 2025-09-08T19:51:34,803 # This is -- a caller that pip uses to run setup.py 2025-09-08T19:51:34,803 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,803 ...<32 lines>... 2025-09-08T19:51:34,803 exec(compile(setup_py_code, filename, "exec")) 2025-09-08T19:51:34,803 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,803 ''' % ('/tmp/pip-wheel-timz1l5p/zen-quotes_701b18c4802f4710b468aad114e5dfa0/setup.py',), "", "exec")) 2025-09-08T19:51:34,803 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,803 File "", line 35, in 2025-09-08T19:51:34,804 File "/tmp/pip-wheel-timz1l5p/zen-quotes_701b18c4802f4710b468aad114e5dfa0/setup.py", line 4, in 2025-09-08T19:51:34,804 with open("requirements.txt") as req: 2025-09-08T19:51:34,804 ~~~~^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,804 FileNotFoundError: [Errno 2] No such file or directory: 'requirements.txt' 2025-09-08T19:51:34,888 ERROR: python setup.py egg_info exited with 1 2025-09-08T19:51:34,900 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-08T19:51:34,900 exec(compile('"'"''"'"''"'"' 2025-09-08T19:51:34,900 # This is -- a caller that pip uses to run setup.py 2025-09-08T19:51:34,900 # 2025-09-08T19:51:34,900 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-08T19:51:34,900 # import from `distutils.core` to work with newer packaging standards. 2025-09-08T19:51:34,900 # - It provides a clear error message when setuptools is not installed. 2025-09-08T19:51:34,900 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-08T19:51:34,900 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-08T19:51:34,900 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-08T19:51:34,900 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-08T19:51:34,900 import os, sys, tokenize, traceback 2025-09-08T19:51:34,900 2025-09-08T19:51:34,900 try: 2025-09-08T19:51:34,900 import setuptools 2025-09-08T19:51:34,900 except ImportError: 2025-09-08T19:51:34,900 print( 2025-09-08T19:51:34,900 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-08T19:51:34,900 "the build environment with exception:", 2025-09-08T19:51:34,900 file=sys.stderr, 2025-09-08T19:51:34,900 ) 2025-09-08T19:51:34,900 traceback.print_exc() 2025-09-08T19:51:34,900 sys.exit(1) 2025-09-08T19:51:34,900 2025-09-08T19:51:34,900 __file__ = %r 2025-09-08T19:51:34,900 sys.argv[0] = __file__ 2025-09-08T19:51:34,900 2025-09-08T19:51:34,900 if os.path.exists(__file__): 2025-09-08T19:51:34,900 filename = __file__ 2025-09-08T19:51:34,900 with tokenize.open(__file__) as f: 2025-09-08T19:51:34,900 setup_py_code = f.read() 2025-09-08T19:51:34,900 else: 2025-09-08T19:51:34,900 filename = "" 2025-09-08T19:51:34,900 setup_py_code = "from setuptools import setup; setup()" 2025-09-08T19:51:34,900 2025-09-08T19:51:34,900 exec(compile(setup_py_code, filename, "exec")) 2025-09-08T19:51:34,900 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-timz1l5p/zen-quotes_701b18c4802f4710b468aad114e5dfa0/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-uuqjhcz3[/] 2025-09-08T19:51:34,901 [bold magenta]cwd[/]: /tmp/pip-wheel-timz1l5p/zen-quotes_701b18c4802f4710b468aad114e5dfa0/ 2025-09-08T19:51:34,901 Preparing metadata (setup.py): finished with status 'error' 2025-09-08T19:51:34,902 ERROR: metadata generation failed 2025-09-08T19:51:34,907 Exception information: 2025-09-08T19:51:34,907 Traceback (most recent call last): 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-08T19:51:34,907 call_subprocess( 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~^ 2025-09-08T19:51:34,907 args, 2025-09-08T19:51:34,907 ^^^^^ 2025-09-08T19:51:34,907 ...<2 lines>... 2025-09-08T19:51:34,907 spinner=spinner, 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 ^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-08T19:51:34,907 raise error 2025-09-08T19:51:34,907 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-08T19:51:34,907 2025-09-08T19:51:34,907 The above exception was the direct cause of the following exception: 2025-09-08T19:51:34,907 2025-09-08T19:51:34,907 Traceback (most recent call last): 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-08T19:51:34,907 status = _inner_run() 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-08T19:51:34,907 return self.run(options, args) 2025-09-08T19:51:34,907 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-08T19:51:34,907 return func(self, options, args) 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-08T19:51:34,907 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-08T19:51:34,907 result = self._result = resolver.resolve( 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:34,907 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 ^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-08T19:51:34,907 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-08T19:51:34,907 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-08T19:51:34,907 if not criterion.candidates: 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-08T19:51:34,907 return bool(self._sequence) 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-08T19:51:34,907 self._bool = any(self) 2025-09-08T19:51:34,907 ~~~^^^^^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-08T19:51:34,907 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-08T19:51:34,907 ^^^^^^^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-08T19:51:34,907 candidate = func() 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-08T19:51:34,907 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:34,907 link, template, name, version 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 ^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-08T19:51:34,907 self._link_candidate_cache[link] = LinkCandidate( 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~^ 2025-09-08T19:51:34,907 link, 2025-09-08T19:51:34,907 ^^^^^ 2025-09-08T19:51:34,907 ...<3 lines>... 2025-09-08T19:51:34,907 version=version, 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 ^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-08T19:51:34,907 super().__init__( 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:34,907 link=link, 2025-09-08T19:51:34,907 ^^^^^^^^^^ 2025-09-08T19:51:34,907 ...<4 lines>... 2025-09-08T19:51:34,907 version=version, 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 ^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-08T19:51:34,907 self.dist = self._prepare() 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-08T19:51:34,907 dist = self._prepare_distribution() 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-08T19:51:34,907 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-08T19:51:34,907 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-08T19:51:34,907 dist = _get_prepared_distribution( 2025-09-08T19:51:34,907 req, 2025-09-08T19:51:34,907 ...<3 lines>... 2025-09-08T19:51:34,907 self.check_build_deps, 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-08T19:51:34,907 abstract_dist.prepare_distribution_metadata( 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:34,907 finder, build_isolation, check_build_deps 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 ^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-08T19:51:34,907 self.req.prepare_metadata() 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-08T19:51:34,907 self.metadata_directory = generate_metadata_legacy( 2025-09-08T19:51:34,907 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-08T19:51:34,907 build_env=self.build_env, 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ...<3 lines>... 2025-09-08T19:51:34,907 details=details, 2025-09-08T19:51:34,907 ^^^^^^^^^^^^^^^^ 2025-09-08T19:51:34,907 ) 2025-09-08T19:51:34,907 ^ 2025-09-08T19:51:34,907 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-08T19:51:34,907 raise MetadataGenerationFailed(package_details=details) from error 2025-09-08T19:51:34,907 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-08T19:51:34,928 Removed zen-quotes==1.0.0 from https://files.pythonhosted.org/packages/0e/f7/1eb7098049df10c4d4e2aa43461497117ea5036197ae944dd7e0b9f5889a/zen_quotes-1.0.0.tar.gz from build tracker '/tmp/pip-build-tracker-769sri16' 2025-09-08T19:51:34,928 Removed build tracker: '/tmp/pip-build-tracker-769sri16'