2025-09-09T08:00:32,630 Created temporary directory: /tmp/pip-build-tracker-1pzx5woc 2025-09-09T08:00:32,630 Initialized build tracking at /tmp/pip-build-tracker-1pzx5woc 2025-09-09T08:00:32,630 Created build tracker: /tmp/pip-build-tracker-1pzx5woc 2025-09-09T08:00:32,630 Entered build tracker: /tmp/pip-build-tracker-1pzx5woc 2025-09-09T08:00:32,631 Created temporary directory: /tmp/pip-wheel-7olp6uau 2025-09-09T08:00:32,634 Created temporary directory: /tmp/pip-ephem-wheel-cache-ej9tz8ot 2025-09-09T08:00:32,690 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-09T08:00:32,693 2 location(s) to search for versions of py2web: 2025-09-09T08:00:32,693 * https://pypi.org/simple/py2web/ 2025-09-09T08:00:32,693 * https://www.piwheels.org/simple/py2web/ 2025-09-09T08:00:32,693 Fetching project page and analyzing links: https://pypi.org/simple/py2web/ 2025-09-09T08:00:32,693 Getting page https://pypi.org/simple/py2web/ 2025-09-09T08:00:32,694 Found index url https://pypi.org/simple/ 2025-09-09T08:00:32,763 Fetched page https://pypi.org/simple/py2web/ as application/vnd.pypi.simple.v1+json 2025-09-09T08:00:32,765 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/bb/97/956119949808cc8c5608e2fa396bf51b2614a5b4eba41d9ebacee390617b/Py2Web-0.0.1.dev1-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,766 Found link https://files.pythonhosted.org/packages/26/8a/ff681a65ade07e0de35d9bc9d837338aebc0622bc9439a3d6271ae65477a/Py2Web-0.0.1.dev1.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 0.0.1.dev1 2025-09-09T08:00:32,766 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/45/00/d729953c02bd0811d096bb53b276995cd827a317ea847145ead21d0fa092/Py2Web-0.0.2.dev1-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,767 Found link https://files.pythonhosted.org/packages/bf/7b/aa90473b9121353e9ad02028acc127bde77ab56b244d357366992f975d93/Py2Web-0.0.2.dev1.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 0.0.2.dev1 2025-09-09T08:00:32,767 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/9b/20/bf1c795a027b1fb4083caf5b6ca4efb87f358f322f0dc32a92a33af5a1b9/Py2Web-1.0.1-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,767 Found link https://files.pythonhosted.org/packages/16/f6/1164894a3af3d7f580792c390c50183502c95144d48aae9e6d47023099cd/Py2Web-1.0.1.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 1.0.1 2025-09-09T08:00:32,767 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/c7/c9/fb4a50416c67ad9d33ec1d92fd516a7ec0c77dd641ff8cdba6d98b18c01c/Py2Web-1.0.2-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,767 Found link https://files.pythonhosted.org/packages/db/14/1f89b0dff31dec23e5b9ee4b4b7f99c69fb042ed437fe667e613d50230b2/Py2Web-1.0.2.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 1.0.2 2025-09-09T08:00:32,767 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/bb/78/9aad921547bf963556884b6926a011f2bebefdafda10215fc4db6366f4d7/Py2Web-1.0.3-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,768 Found link https://files.pythonhosted.org/packages/2c/2b/d4a046e49f3e8fe396417fe245da5a9a9e4192028bd2894f9b1d7ed1e0cb/Py2Web-1.0.3.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 1.0.3 2025-09-09T08:00:32,768 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/58/7d/08e0f0dadb1b010cb4cf8eb3362b0778d34344ea6fe2572dce5db113f3e1/Py2Web-1.0.4-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,768 Found link https://files.pythonhosted.org/packages/14/8d/7ba9177b1bb921e3e70ef7949ae269b4b814e7792b6f614a75f7a14650f5/Py2Web-1.0.4.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 1.0.4 2025-09-09T08:00:32,768 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/5c/77/1043163dbedce4aa03df20056625c792d40c89301f41d5e71177bd33705e/Py2Web-1.0.5-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,768 Found link https://files.pythonhosted.org/packages/21/c1/852e915762a4381c496ef19562552db13012401cc2373f04ebd6a29c11e1/Py2Web-1.0.5.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 1.0.5 2025-09-09T08:00:32,768 Skipping link: No binaries permitted for py2web: https://files.pythonhosted.org/packages/ab/c0/4899da211c588164eead17f18b0c0590220d11b14715762bc6ca7ceb619e/Py2Web-1.0.6-py3-none-any.whl (from https://pypi.org/simple/py2web/) (requires-python:>=3.8) 2025-09-09T08:00:32,768 Found link https://files.pythonhosted.org/packages/a0/3e/a359340f19187d95ca453caeed2c1dd0802d2af522a6b0e54d4792e7d268/Py2Web-1.0.6.tar.gz (from https://pypi.org/simple/py2web/) (requires-python:>=3.8), version: 1.0.6 2025-09-09T08:00:32,769 Fetching project page and analyzing links: https://www.piwheels.org/simple/py2web/ 2025-09-09T08:00:32,769 Getting page https://www.piwheels.org/simple/py2web/ 2025-09-09T08:00:32,770 Found index url https://www.piwheels.org/simple/ 2025-09-09T08:00:32,864 Fetched page https://www.piwheels.org/simple/py2web/ as text/html 2025-09-09T08:00:32,865 Skipping link: not a file: https://www.piwheels.org/simple/py2web/ 2025-09-09T08:00:32,865 Skipping link: not a file: https://pypi.org/simple/py2web/ 2025-09-09T08:00:32,891 Given no hashes to check 1 links for project 'py2web': discarding no candidates 2025-09-09T08:00:32,892 Collecting py2web==1.0.1 2025-09-09T08:00:32,893 Created temporary directory: /tmp/pip-unpack-xy_rz44p 2025-09-09T08:00:33,030 Downloading Py2Web-1.0.1.tar.gz (3.6 kB) 2025-09-09T08:00:33,059 Added py2web==1.0.1 from https://files.pythonhosted.org/packages/16/f6/1164894a3af3d7f580792c390c50183502c95144d48aae9e6d47023099cd/Py2Web-1.0.1.tar.gz to build tracker '/tmp/pip-build-tracker-1pzx5woc' 2025-09-09T08:00:33,060 Running setup.py (path:/tmp/pip-wheel-7olp6uau/py2web_f78fc5ff7df4456cbcf80cf3936c34f4/setup.py) egg_info for package py2web 2025-09-09T08:00:33,060 Created temporary directory: /tmp/pip-pip-egg-info-e1zja110 2025-09-09T08:00:33,060 Preparing metadata (setup.py): started 2025-09-09T08:00:33,061 Running command python setup.py egg_info 2025-09-09T08:00:33,583 Traceback (most recent call last): 2025-09-09T08:00:33,585 File "", line 2, in 2025-09-09T08:00:33,585 exec(compile(''' 2025-09-09T08:00:33,585 ~~~~^^^^^^^^^^^^ 2025-09-09T08:00:33,585 # This is -- a caller that pip uses to run setup.py 2025-09-09T08:00:33,585 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,585 ...<32 lines>... 2025-09-09T08:00:33,585 exec(compile(setup_py_code, filename, "exec")) 2025-09-09T08:00:33,585 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,586 ''' % ('/tmp/pip-wheel-7olp6uau/py2web_f78fc5ff7df4456cbcf80cf3936c34f4/setup.py',), "", "exec")) 2025-09-09T08:00:33,586 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,586 File "", line 35, in 2025-09-09T08:00:33,586 File "/tmp/pip-wheel-7olp6uau/py2web_f78fc5ff7df4456cbcf80cf3936c34f4/setup.py", line 23, in 2025-09-09T08:00:33,586 install_requires=open("requirements.txt").read().splitlines() 2025-09-09T08:00:33,586 ~~~~^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,586 FileNotFoundError: [Errno 2] No such file or directory: 'requirements.txt' 2025-09-09T08:00:33,670 ERROR: python setup.py egg_info exited with 1 2025-09-09T08:00:33,682 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-09T08:00:33,682 exec(compile('"'"''"'"''"'"' 2025-09-09T08:00:33,682 # This is -- a caller that pip uses to run setup.py 2025-09-09T08:00:33,682 # 2025-09-09T08:00:33,682 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-09T08:00:33,682 # import from `distutils.core` to work with newer packaging standards. 2025-09-09T08:00:33,682 # - It provides a clear error message when setuptools is not installed. 2025-09-09T08:00:33,682 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-09T08:00:33,682 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-09T08:00:33,682 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-09T08:00:33,682 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-09T08:00:33,682 import os, sys, tokenize, traceback 2025-09-09T08:00:33,682 2025-09-09T08:00:33,682 try: 2025-09-09T08:00:33,682 import setuptools 2025-09-09T08:00:33,682 except ImportError: 2025-09-09T08:00:33,682 print( 2025-09-09T08:00:33,682 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-09T08:00:33,682 "the build environment with exception:", 2025-09-09T08:00:33,682 file=sys.stderr, 2025-09-09T08:00:33,682 ) 2025-09-09T08:00:33,682 traceback.print_exc() 2025-09-09T08:00:33,682 sys.exit(1) 2025-09-09T08:00:33,682 2025-09-09T08:00:33,682 __file__ = %r 2025-09-09T08:00:33,682 sys.argv[0] = __file__ 2025-09-09T08:00:33,682 2025-09-09T08:00:33,682 if os.path.exists(__file__): 2025-09-09T08:00:33,682 filename = __file__ 2025-09-09T08:00:33,682 with tokenize.open(__file__) as f: 2025-09-09T08:00:33,682 setup_py_code = f.read() 2025-09-09T08:00:33,682 else: 2025-09-09T08:00:33,682 filename = "" 2025-09-09T08:00:33,682 setup_py_code = "from setuptools import setup; setup()" 2025-09-09T08:00:33,682 2025-09-09T08:00:33,682 exec(compile(setup_py_code, filename, "exec")) 2025-09-09T08:00:33,682 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-7olp6uau/py2web_f78fc5ff7df4456cbcf80cf3936c34f4/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-e1zja110[/] 2025-09-09T08:00:33,682 [bold magenta]cwd[/]: /tmp/pip-wheel-7olp6uau/py2web_f78fc5ff7df4456cbcf80cf3936c34f4/ 2025-09-09T08:00:33,682 Preparing metadata (setup.py): finished with status 'error' 2025-09-09T08:00:33,683 ERROR: metadata generation failed 2025-09-09T08:00:33,690 Exception information: 2025-09-09T08:00:33,690 Traceback (most recent call last): 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-09T08:00:33,690 call_subprocess( 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~^ 2025-09-09T08:00:33,690 args, 2025-09-09T08:00:33,690 ^^^^^ 2025-09-09T08:00:33,690 ...<2 lines>... 2025-09-09T08:00:33,690 spinner=spinner, 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 ^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-09T08:00:33,690 raise error 2025-09-09T08:00:33,690 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-09T08:00:33,690 2025-09-09T08:00:33,690 The above exception was the direct cause of the following exception: 2025-09-09T08:00:33,690 2025-09-09T08:00:33,690 Traceback (most recent call last): 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-09T08:00:33,690 status = _inner_run() 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-09T08:00:33,690 return self.run(options, args) 2025-09-09T08:00:33,690 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-09T08:00:33,690 return func(self, options, args) 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-09T08:00:33,690 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-09T08:00:33,690 result = self._result = resolver.resolve( 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~^ 2025-09-09T08:00:33,690 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 ^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-09T08:00:33,690 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-09T08:00:33,690 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-09T08:00:33,690 if not criterion.candidates: 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-09T08:00:33,690 return bool(self._sequence) 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-09T08:00:33,690 self._bool = any(self) 2025-09-09T08:00:33,690 ~~~^^^^^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-09T08:00:33,690 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-09T08:00:33,690 ^^^^^^^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-09T08:00:33,690 candidate = func() 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-09T08:00:33,690 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T08:00:33,690 link, template, name, version 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 ^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-09T08:00:33,690 self._link_candidate_cache[link] = LinkCandidate( 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~^ 2025-09-09T08:00:33,690 link, 2025-09-09T08:00:33,690 ^^^^^ 2025-09-09T08:00:33,690 ...<3 lines>... 2025-09-09T08:00:33,690 version=version, 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 ^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-09T08:00:33,690 super().__init__( 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~^ 2025-09-09T08:00:33,690 link=link, 2025-09-09T08:00:33,690 ^^^^^^^^^^ 2025-09-09T08:00:33,690 ...<4 lines>... 2025-09-09T08:00:33,690 version=version, 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 ^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-09T08:00:33,690 self.dist = self._prepare() 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-09T08:00:33,690 dist = self._prepare_distribution() 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-09T08:00:33,690 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-09T08:00:33,690 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-09T08:00:33,690 dist = _get_prepared_distribution( 2025-09-09T08:00:33,690 req, 2025-09-09T08:00:33,690 ...<3 lines>... 2025-09-09T08:00:33,690 self.check_build_deps, 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-09T08:00:33,690 abstract_dist.prepare_distribution_metadata( 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T08:00:33,690 finder, build_isolation, check_build_deps 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 ^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-09T08:00:33,690 self.req.prepare_metadata() 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-09T08:00:33,690 self.metadata_directory = generate_metadata_legacy( 2025-09-09T08:00:33,690 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T08:00:33,690 build_env=self.build_env, 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ...<3 lines>... 2025-09-09T08:00:33,690 details=details, 2025-09-09T08:00:33,690 ^^^^^^^^^^^^^^^^ 2025-09-09T08:00:33,690 ) 2025-09-09T08:00:33,690 ^ 2025-09-09T08:00:33,690 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-09T08:00:33,690 raise MetadataGenerationFailed(package_details=details) from error 2025-09-09T08:00:33,690 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-09T08:00:33,713 Removed py2web==1.0.1 from https://files.pythonhosted.org/packages/16/f6/1164894a3af3d7f580792c390c50183502c95144d48aae9e6d47023099cd/Py2Web-1.0.1.tar.gz from build tracker '/tmp/pip-build-tracker-1pzx5woc' 2025-09-09T08:00:33,713 Removed build tracker: '/tmp/pip-build-tracker-1pzx5woc'