2025-09-15T20:54:09,223 Created temporary directory: /tmp/pip-build-tracker-cuncpzgt 2025-09-15T20:54:09,223 Initialized build tracking at /tmp/pip-build-tracker-cuncpzgt 2025-09-15T20:54:09,224 Created build tracker: /tmp/pip-build-tracker-cuncpzgt 2025-09-15T20:54:09,224 Entered build tracker: /tmp/pip-build-tracker-cuncpzgt 2025-09-15T20:54:09,224 Created temporary directory: /tmp/pip-wheel-nq56vctv 2025-09-15T20:54:09,228 Created temporary directory: /tmp/pip-ephem-wheel-cache-eh7_brph 2025-09-15T20:54:09,290 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-15T20:54:09,292 2 location(s) to search for versions of media-calc: 2025-09-15T20:54:09,292 * https://pypi.org/simple/media-calc/ 2025-09-15T20:54:09,292 * https://www.piwheels.org/simple/media-calc/ 2025-09-15T20:54:09,293 Fetching project page and analyzing links: https://pypi.org/simple/media-calc/ 2025-09-15T20:54:09,293 Getting page https://pypi.org/simple/media-calc/ 2025-09-15T20:54:09,295 Found index url https://pypi.org/simple/ 2025-09-15T20:54:09,370 Fetched page https://pypi.org/simple/media-calc/ as application/vnd.pypi.simple.v1+json 2025-09-15T20:54:09,372 Found link https://files.pythonhosted.org/packages/d2/2e/8849b0f95439a070a036a65a46d0c8d936b23f78c5f0994c6362d086ef24/media_calc-0.1.0.tar.gz (from https://pypi.org/simple/media-calc/), version: 0.1.0 2025-09-15T20:54:09,373 Found link https://files.pythonhosted.org/packages/82/12/a71771278223edf690f03aa3531e7cf703c61bafc2c1e0bc411925e760ef/media_calc-0.1.1.tar.gz (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6), version: 0.1.1 2025-09-15T20:54:09,373 Found link https://files.pythonhosted.org/packages/93/d6/f484f0b234480c06666882d444374414970bbda682e5defa5de75581c5dd/media_calc-0.1.2.tar.gz (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6), version: 0.1.2 2025-09-15T20:54:09,373 Skipping link: No binaries permitted for media-calc: https://files.pythonhosted.org/packages/5d/a0/ce8559cb446c2098417851c6ea89138044f420a56106da97e68054843948/media_calc-0.2.0-py3-none-any.whl (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,374 Found link https://files.pythonhosted.org/packages/43/0b/d7999a7c87d46c9e164d3c766b1b659e44a4848871478d81b43afa065b5e/media_calc-0.2.0.tar.gz (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6), version: 0.2.0 2025-09-15T20:54:09,374 Skipping link: No binaries permitted for media-calc: https://files.pythonhosted.org/packages/ab/cc/7f16abf086c948ea4cde16480b7f484c4f37291be5d30f69641bf98fe6a4/media_calc-0.2.1-py3-none-any.whl (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,374 Skipping link: No binaries permitted for media-calc: https://files.pythonhosted.org/packages/fe/0e/45de576e333d30fb7dec85581868fd52f9f34d0a8eeb796f5997146866e1/media_calc-0.2.2-py3-none-any.whl (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,374 Skipping link: No binaries permitted for media-calc: https://files.pythonhosted.org/packages/c9/38/a4312ca998ac76d341256600b5d48661fc1eaa23d7861982fdab1bf782ea/media_calc-0.2.3-py3-none-any.whl (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,374 Found link https://files.pythonhosted.org/packages/2e/be/22cb788f5ee0ea3fc9211706472d859f6821037da0adc8bdfae8827dee89/media_calc-0.2.3.tar.gz (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6), version: 0.2.3 2025-09-15T20:54:09,375 Skipping link: No binaries permitted for media-calc: https://files.pythonhosted.org/packages/87/b1/8315fe79455f936d70cf11ab38646d58bf4ecf384b18c8080bafd2964476/media_calc-0.2.4-py3-none-any.whl (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,375 Found link https://files.pythonhosted.org/packages/fc/87/243353742831f689fcec132762142dd50230c1b18598e48bd76b9a780758/media_calc-0.2.4.tar.gz (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6), version: 0.2.4 2025-09-15T20:54:09,375 Skipping link: No binaries permitted for media-calc: https://files.pythonhosted.org/packages/f6/a7/2609ea8cb6f91aec1bdfe8e9854c6ef26dd462f34df88761abdefe3c68f6/media_calc-0.2.5-py3-none-any.whl (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,375 Found link https://files.pythonhosted.org/packages/68/2b/12e09061d37058e78068172079b4f2c4a60aaf881c1826405815f0554902/media_calc-0.2.5.tar.gz (from https://pypi.org/simple/media-calc/) (requires-python:>=3.6), version: 0.2.5 2025-09-15T20:54:09,376 Fetching project page and analyzing links: https://www.piwheels.org/simple/media-calc/ 2025-09-15T20:54:09,376 Getting page https://www.piwheels.org/simple/media-calc/ 2025-09-15T20:54:09,377 Found index url https://www.piwheels.org/simple/ 2025-09-15T20:54:09,464 Fetched page https://www.piwheels.org/simple/media-calc/ as text/html 2025-09-15T20:54:09,466 Skipping link: No binaries permitted for media-calc: https://archive1.piwheels.org/simple/media-calc/media_calc-0.2.5-py3-none-any.whl#sha256=411dfed6183ad64a6c66ae91e57f13bb6f47c6f4cc88502f11bab043bf4b871e (from https://www.piwheels.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,466 Skipping link: No binaries permitted for media-calc: https://archive1.piwheels.org/simple/media-calc/media_calc-0.2.4-py3-none-any.whl#sha256=272856bf7b31948564971d05e6043dcd098cd772e12e687f6c27602274832b3f (from https://www.piwheels.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,466 Skipping link: No binaries permitted for media-calc: https://archive1.piwheels.org/simple/media-calc/media_calc-0.2.3-py3-none-any.whl#sha256=c78813419f1ba495d86ca56a3cd691a3f8d931446836dc71e206096c29369741 (from https://www.piwheels.org/simple/media-calc/) (requires-python:>=3.6) 2025-09-15T20:54:09,466 Skipping link: not a file: https://www.piwheels.org/simple/media-calc/ 2025-09-15T20:54:09,467 Skipping link: not a file: https://pypi.org/simple/media-calc/ 2025-09-15T20:54:09,492 Given no hashes to check 1 links for project 'media-calc': discarding no candidates 2025-09-15T20:54:09,493 Collecting media-calc==0.2.0 2025-09-15T20:54:09,495 Created temporary directory: /tmp/pip-unpack-rx6ejr1r 2025-09-15T20:54:09,637 Downloading media_calc-0.2.0.tar.gz (2.8 kB) 2025-09-15T20:54:09,653 Added media-calc==0.2.0 from https://files.pythonhosted.org/packages/43/0b/d7999a7c87d46c9e164d3c766b1b659e44a4848871478d81b43afa065b5e/media_calc-0.2.0.tar.gz to build tracker '/tmp/pip-build-tracker-cuncpzgt' 2025-09-15T20:54:09,655 Running setup.py (path:/tmp/pip-wheel-nq56vctv/media-calc_2bc487f09063432d82a3378e023000b9/setup.py) egg_info for package media-calc 2025-09-15T20:54:09,655 Created temporary directory: /tmp/pip-pip-egg-info-a0h5qimq 2025-09-15T20:54:09,656 Preparing metadata (setup.py): started 2025-09-15T20:54:09,657 Running command python setup.py egg_info 2025-09-15T20:54:10,239 Traceback (most recent call last): 2025-09-15T20:54:10,242 File "", line 2, in 2025-09-15T20:54:10,242 exec(compile(''' 2025-09-15T20:54:10,242 ~~~~^^^^^^^^^^^^ 2025-09-15T20:54:10,242 # This is -- a caller that pip uses to run setup.py 2025-09-15T20:54:10,243 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,243 ...<32 lines>... 2025-09-15T20:54:10,243 exec(compile(setup_py_code, filename, "exec")) 2025-09-15T20:54:10,243 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,243 ''' % ('/tmp/pip-wheel-nq56vctv/media-calc_2bc487f09063432d82a3378e023000b9/setup.py',), "", "exec")) 2025-09-15T20:54:10,243 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,244 File "", line 35, in 2025-09-15T20:54:10,244 File "/tmp/pip-wheel-nq56vctv/media-calc_2bc487f09063432d82a3378e023000b9/setup.py", line 5, in 2025-09-15T20:54:10,244 README = (HERE / "README.md").read_text(encoding='utf-8') 2025-09-15T20:54:10,244 File "/usr/lib/python3.13/pathlib/_local.py", line 548, in read_text 2025-09-15T20:54:10,244 return PathBase.read_text(self, encoding, errors, newline) 2025-09-15T20:54:10,245 ~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,245 File "/usr/lib/python3.13/pathlib/_abc.py", line 632, in read_text 2025-09-15T20:54:10,245 with self.open(mode='r', encoding=encoding, errors=errors, newline=newline) as f: 2025-09-15T20:54:10,245 ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,245 File "/usr/lib/python3.13/pathlib/_local.py", line 539, in open 2025-09-15T20:54:10,246 return io.open(self, mode, buffering, encoding, errors, newline) 2025-09-15T20:54:10,246 ~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,246 FileNotFoundError: [Errno 2] No such file or directory: '/tmp/pip-wheel-nq56vctv/media-calc_2bc487f09063432d82a3378e023000b9/README.md' 2025-09-15T20:54:10,342 ERROR: python setup.py egg_info exited with 1 2025-09-15T20:54:10,356 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-15T20:54:10,356 exec(compile('"'"''"'"''"'"' 2025-09-15T20:54:10,356 # This is -- a caller that pip uses to run setup.py 2025-09-15T20:54:10,356 # 2025-09-15T20:54:10,356 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-15T20:54:10,356 # import from `distutils.core` to work with newer packaging standards. 2025-09-15T20:54:10,356 # - It provides a clear error message when setuptools is not installed. 2025-09-15T20:54:10,356 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-15T20:54:10,356 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-15T20:54:10,356 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-15T20:54:10,356 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-15T20:54:10,356 import os, sys, tokenize, traceback 2025-09-15T20:54:10,356 2025-09-15T20:54:10,356 try: 2025-09-15T20:54:10,356 import setuptools 2025-09-15T20:54:10,356 except ImportError: 2025-09-15T20:54:10,356 print( 2025-09-15T20:54:10,356 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-15T20:54:10,356 "the build environment with exception:", 2025-09-15T20:54:10,356 file=sys.stderr, 2025-09-15T20:54:10,356 ) 2025-09-15T20:54:10,356 traceback.print_exc() 2025-09-15T20:54:10,356 sys.exit(1) 2025-09-15T20:54:10,356 2025-09-15T20:54:10,356 __file__ = %r 2025-09-15T20:54:10,356 sys.argv[0] = __file__ 2025-09-15T20:54:10,356 2025-09-15T20:54:10,356 if os.path.exists(__file__): 2025-09-15T20:54:10,356 filename = __file__ 2025-09-15T20:54:10,356 with tokenize.open(__file__) as f: 2025-09-15T20:54:10,356 setup_py_code = f.read() 2025-09-15T20:54:10,356 else: 2025-09-15T20:54:10,356 filename = "" 2025-09-15T20:54:10,356 setup_py_code = "from setuptools import setup; setup()" 2025-09-15T20:54:10,356 2025-09-15T20:54:10,356 exec(compile(setup_py_code, filename, "exec")) 2025-09-15T20:54:10,356 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-nq56vctv/media-calc_2bc487f09063432d82a3378e023000b9/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-a0h5qimq[/] 2025-09-15T20:54:10,356 [bold magenta]cwd[/]: /tmp/pip-wheel-nq56vctv/media-calc_2bc487f09063432d82a3378e023000b9/ 2025-09-15T20:54:10,357 Preparing metadata (setup.py): finished with status 'error' 2025-09-15T20:54:10,358 ERROR: metadata generation failed 2025-09-15T20:54:10,364 Exception information: 2025-09-15T20:54:10,364 Traceback (most recent call last): 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-15T20:54:10,364 call_subprocess( 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~^ 2025-09-15T20:54:10,364 args, 2025-09-15T20:54:10,364 ^^^^^ 2025-09-15T20:54:10,364 ...<2 lines>... 2025-09-15T20:54:10,364 spinner=spinner, 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 ^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-15T20:54:10,364 raise error 2025-09-15T20:54:10,364 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-15T20:54:10,364 2025-09-15T20:54:10,364 The above exception was the direct cause of the following exception: 2025-09-15T20:54:10,364 2025-09-15T20:54:10,364 Traceback (most recent call last): 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-15T20:54:10,364 status = _inner_run() 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-15T20:54:10,364 return self.run(options, args) 2025-09-15T20:54:10,364 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-15T20:54:10,364 return func(self, options, args) 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-15T20:54:10,364 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-15T20:54:10,364 result = self._result = resolver.resolve( 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~^ 2025-09-15T20:54:10,364 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 ^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-15T20:54:10,364 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-15T20:54:10,364 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-15T20:54:10,364 if not criterion.candidates: 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-15T20:54:10,364 return bool(self._sequence) 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-15T20:54:10,364 self._bool = any(self) 2025-09-15T20:54:10,364 ~~~^^^^^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-15T20:54:10,364 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-15T20:54:10,364 ^^^^^^^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-15T20:54:10,364 candidate = func() 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-15T20:54:10,364 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-15T20:54:10,364 link, template, name, version 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 ^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-15T20:54:10,364 self._link_candidate_cache[link] = LinkCandidate( 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~^ 2025-09-15T20:54:10,364 link, 2025-09-15T20:54:10,364 ^^^^^ 2025-09-15T20:54:10,364 ...<3 lines>... 2025-09-15T20:54:10,364 version=version, 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 ^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-15T20:54:10,364 super().__init__( 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~^ 2025-09-15T20:54:10,364 link=link, 2025-09-15T20:54:10,364 ^^^^^^^^^^ 2025-09-15T20:54:10,364 ...<4 lines>... 2025-09-15T20:54:10,364 version=version, 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 ^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-15T20:54:10,364 self.dist = self._prepare() 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-15T20:54:10,364 dist = self._prepare_distribution() 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-15T20:54:10,364 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-15T20:54:10,364 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-15T20:54:10,364 dist = _get_prepared_distribution( 2025-09-15T20:54:10,364 req, 2025-09-15T20:54:10,364 ...<3 lines>... 2025-09-15T20:54:10,364 self.check_build_deps, 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-15T20:54:10,364 abstract_dist.prepare_distribution_metadata( 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-15T20:54:10,364 finder, build_isolation, check_build_deps 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 ^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-15T20:54:10,364 self.req.prepare_metadata() 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-15T20:54:10,364 self.metadata_directory = generate_metadata_legacy( 2025-09-15T20:54:10,364 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-15T20:54:10,364 build_env=self.build_env, 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ...<3 lines>... 2025-09-15T20:54:10,364 details=details, 2025-09-15T20:54:10,364 ^^^^^^^^^^^^^^^^ 2025-09-15T20:54:10,364 ) 2025-09-15T20:54:10,364 ^ 2025-09-15T20:54:10,364 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-15T20:54:10,364 raise MetadataGenerationFailed(package_details=details) from error 2025-09-15T20:54:10,364 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-15T20:54:10,388 Removed media-calc==0.2.0 from https://files.pythonhosted.org/packages/43/0b/d7999a7c87d46c9e164d3c766b1b659e44a4848871478d81b43afa065b5e/media_calc-0.2.0.tar.gz from build tracker '/tmp/pip-build-tracker-cuncpzgt' 2025-09-15T20:54:10,388 Removed build tracker: '/tmp/pip-build-tracker-cuncpzgt'