2025-09-07T23:20:15,045 Created temporary directory: /tmp/pip-build-tracker-ds5l5mm4 2025-09-07T23:20:15,046 Initialized build tracking at /tmp/pip-build-tracker-ds5l5mm4 2025-09-07T23:20:15,046 Created build tracker: /tmp/pip-build-tracker-ds5l5mm4 2025-09-07T23:20:15,046 Entered build tracker: /tmp/pip-build-tracker-ds5l5mm4 2025-09-07T23:20:15,046 Created temporary directory: /tmp/pip-wheel-f4w0dwgs 2025-09-07T23:20:15,049 Created temporary directory: /tmp/pip-ephem-wheel-cache-bpfkssad 2025-09-07T23:20:15,107 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-07T23:20:15,109 2 location(s) to search for versions of pygrametl: 2025-09-07T23:20:15,109 * https://pypi.org/simple/pygrametl/ 2025-09-07T23:20:15,109 * https://www.piwheels.org/simple/pygrametl/ 2025-09-07T23:20:15,110 Fetching project page and analyzing links: https://pypi.org/simple/pygrametl/ 2025-09-07T23:20:15,110 Getting page https://pypi.org/simple/pygrametl/ 2025-09-07T23:20:15,111 Found index url https://pypi.org/simple/ 2025-09-07T23:20:15,260 Fetched page https://pypi.org/simple/pygrametl/ as application/vnd.pypi.simple.v1+json 2025-09-07T23:20:15,263 Found link https://files.pythonhosted.org/packages/90/ba/80024d0fa596287b918e009d85d11c6b0971a68f518d9e61bace2c426cfd/pygrametl-2.2.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.2 2025-09-07T23:20:15,264 Found link https://files.pythonhosted.org/packages/2d/6d/7617e966040e66e0ea5f307df39395dbe076e42ad1a7ccc9b3ae2ab4f6bd/pygrametl-2.3.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.3 2025-09-07T23:20:15,264 Found link https://files.pythonhosted.org/packages/15/9b/fa02c4e3152dc7a58d6ef4963e2e7519bf486391c83d9deca5d1e205c1ca/pygrametl-2.3.1.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.3.1 2025-09-07T23:20:15,265 Found link https://files.pythonhosted.org/packages/90/e6/4ddca8fdd9f79641b2f507554cd2bc3efa37c0de80698682f0830ce3f666/pygrametl-2.3.2.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.3.2 2025-09-07T23:20:15,265 Found link https://files.pythonhosted.org/packages/08/c2/a12440280655a25c9e9bbb38e8fe33088fe5815330c800ded864acc3d408/pygrametl-2.4.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.4 2025-09-07T23:20:15,266 Found link https://files.pythonhosted.org/packages/85/59/2f314c8d9c876a432b85683b542d221bcceb885fe33a960c2d9be8f5c90c/pygrametl-2.5.0.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.5.0 2025-09-07T23:20:15,266 Found link https://files.pythonhosted.org/packages/06/5a/d3d9a886fc2736d748b4f12defd7c60911021c20b9130f9c8010cf75533d/pygrametl-2.6.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.6 2025-09-07T23:20:15,267 Found link https://files.pythonhosted.org/packages/30/24/c6a81bfaf4b73e468b1cb7673d17f77379e0e0ca1b1fafc416370e787de5/pygrametl-2.7.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.7 2025-09-07T23:20:15,267 Found link https://files.pythonhosted.org/packages/03/bd/dbf62697b341183387b83f836c4e867c3e481c0ca3f8a33928dcfbf7f92e/pygrametl-2.8.tar.gz (from https://pypi.org/simple/pygrametl/), version: 2.8 2025-09-07T23:20:15,268 Fetching project page and analyzing links: https://www.piwheels.org/simple/pygrametl/ 2025-09-07T23:20:15,268 Getting page https://www.piwheels.org/simple/pygrametl/ 2025-09-07T23:20:15,270 Found index url https://www.piwheels.org/simple/ 2025-09-07T23:20:15,382 Fetched page https://www.piwheels.org/simple/pygrametl/ as text/html 2025-09-07T23:20:15,385 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.8-py3-none-any.whl#sha256=08b2a8c587cef538f5c5764da5f69832778288259fce9ff8c30637796e53bfbf (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,385 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.7-py3-none-any.whl#sha256=f9d4047a51229833e055b087c9872418125f6c6bf3f121b09de37e71bc6582b9 (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,385 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.6-py3-none-any.whl#sha256=1d9d75dce2c79a115fa860a7263501bcddf954a0a666f3eef3ac4bea9cc15045 (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,385 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.5-py3-none-any.whl#sha256=e21aaa65e9a7bbbfad44d6b108ad8fbab3ae260e1ff1473afa166d0ef9ef78b8 (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,385 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.4-py3-none-any.whl#sha256=db249453d483ac9294976e368e34615ec6663986be6d5597cebdb64e09acbbd0 (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,385 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.3.2-py3-none-any.whl#sha256=e6abc01472432aa431bb36207214e632dbfbaf11d6d4eb02e75d5d3e70c9a9be (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,385 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.3.1-py3-none-any.whl#sha256=5c3936c7845bd3916f14feef345565b25f2b3e87bb4f9a0428cb552571bb3198 (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,386 Skipping link: No binaries permitted for pygrametl: https://archive1.piwheels.org/simple/pygrametl/pygrametl-2.3-py3-none-any.whl#sha256=b5f5b48ad540f1f5c6c4df025037dfc7d1d332d21793fc0ac08773bf1a85aa14 (from https://www.piwheels.org/simple/pygrametl/) 2025-09-07T23:20:15,386 Skipping link: not a file: https://www.piwheels.org/simple/pygrametl/ 2025-09-07T23:20:15,386 Skipping link: not a file: https://pypi.org/simple/pygrametl/ 2025-09-07T23:20:15,414 Given no hashes to check 1 links for project 'pygrametl': discarding no candidates 2025-09-07T23:20:15,415 Collecting pygrametl==2.2 2025-09-07T23:20:15,416 Created temporary directory: /tmp/pip-unpack-uwxctph8 2025-09-07T23:20:15,561 Downloading pygrametl-2.2.tar.gz (69 kB) 2025-09-07T23:20:15,617 Added pygrametl==2.2 from https://files.pythonhosted.org/packages/90/ba/80024d0fa596287b918e009d85d11c6b0971a68f518d9e61bace2c426cfd/pygrametl-2.2.tar.gz to build tracker '/tmp/pip-build-tracker-ds5l5mm4' 2025-09-07T23:20:15,618 Running setup.py (path:/tmp/pip-wheel-f4w0dwgs/pygrametl_21fcbf63952c461da2452018cf56509a/setup.py) egg_info for package pygrametl 2025-09-07T23:20:15,618 Created temporary directory: /tmp/pip-pip-egg-info-0zfy6pxp 2025-09-07T23:20:15,618 Preparing metadata (setup.py): started 2025-09-07T23:20:15,619 Running command python setup.py egg_info 2025-09-07T23:20:16,139 Traceback (most recent call last): 2025-09-07T23:20:16,140 File "", line 2, in 2025-09-07T23:20:16,141 exec(compile(''' 2025-09-07T23:20:16,141 ~~~~^^^^^^^^^^^^ 2025-09-07T23:20:16,141 # This is -- a caller that pip uses to run setup.py 2025-09-07T23:20:16,141 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,141 ...<32 lines>... 2025-09-07T23:20:16,141 exec(compile(setup_py_code, filename, "exec")) 2025-09-07T23:20:16,141 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,141 ''' % ('/tmp/pip-wheel-f4w0dwgs/pygrametl_21fcbf63952c461da2452018cf56509a/setup.py',), "", "exec")) 2025-09-07T23:20:16,141 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,142 File "", line 35, in 2025-09-07T23:20:16,142 File "/tmp/pip-wheel-f4w0dwgs/pygrametl_21fcbf63952c461da2452018cf56509a/setup.py", line 12, in 2025-09-07T23:20:16,142 version=get_package_version(), 2025-09-07T23:20:16,142 ~~~~~~~~~~~~~~~~~~~^^ 2025-09-07T23:20:16,142 File "/tmp/pip-wheel-f4w0dwgs/pygrametl_21fcbf63952c461da2452018cf56509a/docs/_exts/version.py", line 57, in get_package_version 2025-09-07T23:20:16,142 version = __import__(module_name).__version__ 2025-09-07T23:20:16,143 ~~~~~~~~~~^^^^^^^^^^^^^ 2025-09-07T23:20:16,143 File "/tmp/pip-wheel-f4w0dwgs/pygrametl_21fcbf63952c461da2452018cf56509a/pygrametl/__init__.py", line 283 2025-09-07T23:20:16,143 raise ValueError, "Lists differ in length" 2025-09-07T23:20:16,143 ^ 2025-09-07T23:20:16,143 SyntaxError: invalid syntax 2025-09-07T23:20:16,226 ERROR: python setup.py egg_info exited with 1 2025-09-07T23:20:16,237 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-07T23:20:16,237 exec(compile('"'"''"'"''"'"' 2025-09-07T23:20:16,237 # This is -- a caller that pip uses to run setup.py 2025-09-07T23:20:16,237 # 2025-09-07T23:20:16,237 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-07T23:20:16,237 # import from `distutils.core` to work with newer packaging standards. 2025-09-07T23:20:16,237 # - It provides a clear error message when setuptools is not installed. 2025-09-07T23:20:16,237 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-07T23:20:16,237 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-07T23:20:16,237 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-07T23:20:16,237 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-07T23:20:16,237 import os, sys, tokenize, traceback 2025-09-07T23:20:16,237 2025-09-07T23:20:16,237 try: 2025-09-07T23:20:16,237 import setuptools 2025-09-07T23:20:16,237 except ImportError: 2025-09-07T23:20:16,237 print( 2025-09-07T23:20:16,237 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-07T23:20:16,237 "the build environment with exception:", 2025-09-07T23:20:16,237 file=sys.stderr, 2025-09-07T23:20:16,237 ) 2025-09-07T23:20:16,237 traceback.print_exc() 2025-09-07T23:20:16,237 sys.exit(1) 2025-09-07T23:20:16,237 2025-09-07T23:20:16,237 __file__ = %r 2025-09-07T23:20:16,237 sys.argv[0] = __file__ 2025-09-07T23:20:16,237 2025-09-07T23:20:16,237 if os.path.exists(__file__): 2025-09-07T23:20:16,237 filename = __file__ 2025-09-07T23:20:16,237 with tokenize.open(__file__) as f: 2025-09-07T23:20:16,237 setup_py_code = f.read() 2025-09-07T23:20:16,237 else: 2025-09-07T23:20:16,237 filename = "" 2025-09-07T23:20:16,237 setup_py_code = "from setuptools import setup; setup()" 2025-09-07T23:20:16,237 2025-09-07T23:20:16,237 exec(compile(setup_py_code, filename, "exec")) 2025-09-07T23:20:16,237 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-f4w0dwgs/pygrametl_21fcbf63952c461da2452018cf56509a/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-0zfy6pxp[/] 2025-09-07T23:20:16,238 [bold magenta]cwd[/]: /tmp/pip-wheel-f4w0dwgs/pygrametl_21fcbf63952c461da2452018cf56509a/ 2025-09-07T23:20:16,238 Preparing metadata (setup.py): finished with status 'error' 2025-09-07T23:20:16,239 ERROR: metadata generation failed 2025-09-07T23:20:16,243 Exception information: 2025-09-07T23:20:16,243 Traceback (most recent call last): 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-07T23:20:16,243 call_subprocess( 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~^ 2025-09-07T23:20:16,243 args, 2025-09-07T23:20:16,243 ^^^^^ 2025-09-07T23:20:16,243 ...<2 lines>... 2025-09-07T23:20:16,243 spinner=spinner, 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 ^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-07T23:20:16,243 raise error 2025-09-07T23:20:16,243 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-07T23:20:16,243 2025-09-07T23:20:16,243 The above exception was the direct cause of the following exception: 2025-09-07T23:20:16,243 2025-09-07T23:20:16,243 Traceback (most recent call last): 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-07T23:20:16,243 status = _inner_run() 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-07T23:20:16,243 return self.run(options, args) 2025-09-07T23:20:16,243 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-07T23:20:16,243 return func(self, options, args) 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-07T23:20:16,243 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-07T23:20:16,243 result = self._result = resolver.resolve( 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~^ 2025-09-07T23:20:16,243 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 ^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-07T23:20:16,243 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-07T23:20:16,243 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-07T23:20:16,243 if not criterion.candidates: 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-07T23:20:16,243 return bool(self._sequence) 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-07T23:20:16,243 self._bool = any(self) 2025-09-07T23:20:16,243 ~~~^^^^^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-07T23:20:16,243 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-07T23:20:16,243 ^^^^^^^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-07T23:20:16,243 candidate = func() 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-07T23:20:16,243 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-07T23:20:16,243 link, template, name, version 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 ^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-07T23:20:16,243 self._link_candidate_cache[link] = LinkCandidate( 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~^ 2025-09-07T23:20:16,243 link, 2025-09-07T23:20:16,243 ^^^^^ 2025-09-07T23:20:16,243 ...<3 lines>... 2025-09-07T23:20:16,243 version=version, 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 ^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-07T23:20:16,243 super().__init__( 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~^ 2025-09-07T23:20:16,243 link=link, 2025-09-07T23:20:16,243 ^^^^^^^^^^ 2025-09-07T23:20:16,243 ...<4 lines>... 2025-09-07T23:20:16,243 version=version, 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 ^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-07T23:20:16,243 self.dist = self._prepare() 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-07T23:20:16,243 dist = self._prepare_distribution() 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-07T23:20:16,243 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-07T23:20:16,243 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-07T23:20:16,243 dist = _get_prepared_distribution( 2025-09-07T23:20:16,243 req, 2025-09-07T23:20:16,243 ...<3 lines>... 2025-09-07T23:20:16,243 self.check_build_deps, 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-07T23:20:16,243 abstract_dist.prepare_distribution_metadata( 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-07T23:20:16,243 finder, build_isolation, check_build_deps 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 ^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-07T23:20:16,243 self.req.prepare_metadata() 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-07T23:20:16,243 self.metadata_directory = generate_metadata_legacy( 2025-09-07T23:20:16,243 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-07T23:20:16,243 build_env=self.build_env, 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ...<3 lines>... 2025-09-07T23:20:16,243 details=details, 2025-09-07T23:20:16,243 ^^^^^^^^^^^^^^^^ 2025-09-07T23:20:16,243 ) 2025-09-07T23:20:16,243 ^ 2025-09-07T23:20:16,243 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-07T23:20:16,243 raise MetadataGenerationFailed(package_details=details) from error 2025-09-07T23:20:16,243 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-07T23:20:16,265 Removed pygrametl==2.2 from https://files.pythonhosted.org/packages/90/ba/80024d0fa596287b918e009d85d11c6b0971a68f518d9e61bace2c426cfd/pygrametl-2.2.tar.gz from build tracker '/tmp/pip-build-tracker-ds5l5mm4' 2025-09-07T23:20:16,265 Removed build tracker: '/tmp/pip-build-tracker-ds5l5mm4'