2025-09-09T22:53:46,674 Created temporary directory: /tmp/pip-build-tracker-wagk6iv8 2025-09-09T22:53:46,674 Initialized build tracking at /tmp/pip-build-tracker-wagk6iv8 2025-09-09T22:53:46,674 Created build tracker: /tmp/pip-build-tracker-wagk6iv8 2025-09-09T22:53:46,675 Entered build tracker: /tmp/pip-build-tracker-wagk6iv8 2025-09-09T22:53:46,675 Created temporary directory: /tmp/pip-wheel-h963945s 2025-09-09T22:53:46,678 Created temporary directory: /tmp/pip-ephem-wheel-cache-prpis215 2025-09-09T22:53:46,737 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-09T22:53:46,740 2 location(s) to search for versions of clip-by-openai: 2025-09-09T22:53:46,740 * https://pypi.org/simple/clip-by-openai/ 2025-09-09T22:53:46,740 * https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T22:53:46,740 Fetching project page and analyzing links: https://pypi.org/simple/clip-by-openai/ 2025-09-09T22:53:46,741 Getting page https://pypi.org/simple/clip-by-openai/ 2025-09-09T22:53:46,742 Found index url https://pypi.org/simple/ 2025-09-09T22:53:46,894 Fetched page https://pypi.org/simple/clip-by-openai/ as application/vnd.pypi.simple.v1+json 2025-09-09T22:53:46,897 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/f7/0e/c92a68a203e084f0ced605c833cf1d168c55e3fb4d8040034bc5bf8e58fb/clip_by_openai-0.1.0-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,898 Found link https://files.pythonhosted.org/packages/63/78/a1a76fa119eb0d864975427a03fd680f1c0bc0f87630f2ef451220cab36e/clip_by_openai-0.1.0.tar.gz (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3), version: 0.1.0 2025-09-09T22:53:46,898 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/6a/ec/12e62b8de68bc82821eb5acecaf5b6df72a24e20e3660176c4129d9ab69c/clip_by_openai-0.1.1-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,898 Found link https://files.pythonhosted.org/packages/6e/76/f4bf09eac139acc1060a48e5c8c39677bd7cb8f8627d0dfb87ddd3d51d76/clip_by_openai-0.1.1.tar.gz (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3), version: 0.1.1 2025-09-09T22:53:46,898 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/cb/d4/397b6955bda84a65256657faacdab130e4a0ac0d1e02a2d75a76ca58939e/clip_by_openai-0.1.1.2-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,899 Found link https://files.pythonhosted.org/packages/36/dd/683c325b83ffcc412e9ea1a85b09946cb684848322b257569eddeec4fecd/clip_by_openai-0.1.1.2.tar.gz (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3), version: 0.1.1.2 2025-09-09T22:53:46,899 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/1e/30/55bfb65dcd4c01372bb316a44ce95dd06e9650d24ccdf4a1b7e6fa178e68/clip_by_openai-0.1.1.3-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,899 Found link https://files.pythonhosted.org/packages/13/5d/ddbb075b02eaa75643dd4f3a5f0d41362ccfc2ad1639d128e801d2cc9413/clip_by_openai-0.1.1.3.tar.gz (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3), version: 0.1.1.3 2025-09-09T22:53:46,899 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/c9/6a/2d986362b142511c518520e1c736e2f0f7c0f90a602ae28d81d5c5671321/clip_by_openai-0.1.1.4-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,900 Found link https://files.pythonhosted.org/packages/16/dd/bd19caa41369af44b515b74f31e7ba1d94bcfa842f99ed628b505b370911/clip_by_openai-0.1.1.4.tar.gz (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3), version: 0.1.1.4 2025-09-09T22:53:46,900 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/88/ae/c76c076e211c6849b4ce66246d4dbd1863ae95c3821fabb7f6743bb7bbf7/clip_by_openai-0.1.1.5-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,900 Found link https://files.pythonhosted.org/packages/29/73/34e0a7e75578c284a79198e8f2bfe0292609af4f092b5d37ae8da07b1127/clip_by_openai-0.1.1.5.tar.gz (from https://pypi.org/simple/clip-by-openai/) (requires-python:>=3), version: 0.1.1.5 2025-09-09T22:53:46,900 Found link https://files.pythonhosted.org/packages/dd/80/d490a5b37228f871c16faae706e20bc536d8299f2ae41d0dd2fbf568668a/clip-by-openai-1.0.1.tar.gz (from https://pypi.org/simple/clip-by-openai/), version: 1.0.1 2025-09-09T22:53:46,901 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/f8/b6/838c4f3425dd6ce41ed512070ecc821d3d15f10685992772227404e538b0/clip_by_openai-1.0.1-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) 2025-09-09T22:53:46,901 Found link https://files.pythonhosted.org/packages/e7/e8/62bf743dad602357a028551a183aada03e59d66805cabeb8c3b8a2d52fa3/clip-by-openai-1.1.tar.gz (from https://pypi.org/simple/clip-by-openai/), version: 1.1 2025-09-09T22:53:46,901 Skipping link: No binaries permitted for clip-by-openai: https://files.pythonhosted.org/packages/41/98/717ed5852dba899bcd09864b7628ca617219b5a00d95f257b5bece052794/clip_by_openai-1.1-py3-none-any.whl (from https://pypi.org/simple/clip-by-openai/) 2025-09-09T22:53:46,901 Fetching project page and analyzing links: https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T22:53:46,902 Getting page https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T22:53:46,903 Found index url https://www.piwheels.org/simple/ 2025-09-09T22:53:46,996 Fetched page https://www.piwheels.org/simple/clip-by-openai/ as text/html 2025-09-09T22:53:46,998 Skipping link: No binaries permitted for clip-by-openai: https://archive1.piwheels.org/simple/clip-by-openai/clip_by_openai-0.1.1.5-py3-none-any.whl#sha256=59339aed3ec4fcfb1b5ee1898df6d348f314df914c85ada27ec70f988c0b97b9 (from https://www.piwheels.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,998 Skipping link: No binaries permitted for clip-by-openai: https://archive1.piwheels.org/simple/clip-by-openai/clip_by_openai-0.1.1.4-py3-none-any.whl#sha256=3008a20782398e3bc61a72298f0e53852bf9cde5cd87e467757982dff9552ef9 (from https://www.piwheels.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,998 Skipping link: No binaries permitted for clip-by-openai: https://archive1.piwheels.org/simple/clip-by-openai/clip_by_openai-0.1.1.3-py3-none-any.whl#sha256=cf207974fbe96be0c53d67da70cedcd6b541867973f55c8b6caea1bef07100be (from https://www.piwheels.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,998 Skipping link: No binaries permitted for clip-by-openai: https://archive1.piwheels.org/simple/clip-by-openai/clip_by_openai-0.1.1.2-py3-none-any.whl#sha256=73766c960573bd2f5f3c2de051f601863309ddc04b14100a7e3cf70c44f8f22a (from https://www.piwheels.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,999 Skipping link: No binaries permitted for clip-by-openai: https://archive1.piwheels.org/simple/clip-by-openai/clip_by_openai-0.1.1-py3-none-any.whl#sha256=8ee02756eaa844bbbb93d0fc4358c6ba8d6bd2c5ddf5537fb1bb9f7579e43012 (from https://www.piwheels.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,999 Skipping link: No binaries permitted for clip-by-openai: https://archive1.piwheels.org/simple/clip-by-openai/clip_by_openai-0.1.0-py3-none-any.whl#sha256=d92ae9f28d81fe50eca31fc18ab9f3474d1f4aa4db149c398cc4dafb8b2e26e2 (from https://www.piwheels.org/simple/clip-by-openai/) (requires-python:>=3) 2025-09-09T22:53:46,999 Skipping link: not a file: https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T22:53:46,999 Skipping link: not a file: https://pypi.org/simple/clip-by-openai/ 2025-09-09T22:53:47,024 Given no hashes to check 1 links for project 'clip-by-openai': discarding no candidates 2025-09-09T22:53:47,026 Collecting clip-by-openai==1.1 2025-09-09T22:53:47,027 Created temporary directory: /tmp/pip-unpack-bquix95w 2025-09-09T22:53:47,305 Downloading clip-by-openai-1.1.tar.gz (1.4 MB) 2025-09-09T22:53:47,490 Added clip-by-openai==1.1 from https://files.pythonhosted.org/packages/e7/e8/62bf743dad602357a028551a183aada03e59d66805cabeb8c3b8a2d52fa3/clip-by-openai-1.1.tar.gz to build tracker '/tmp/pip-build-tracker-wagk6iv8' 2025-09-09T22:53:47,491 Running setup.py (path:/tmp/pip-wheel-h963945s/clip-by-openai_c4d095872f864b19bc987473ea353ac9/setup.py) egg_info for package clip-by-openai 2025-09-09T22:53:47,491 Created temporary directory: /tmp/pip-pip-egg-info-byl5g978 2025-09-09T22:53:47,491 Preparing metadata (setup.py): started 2025-09-09T22:53:47,492 Running command python setup.py egg_info 2025-09-09T22:53:48,068 /tmp/pip-wheel-h963945s/clip-by-openai_c4d095872f864b19bc987473ea353ac9/setup.py:3: UserWarning: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html. The pkg_resources package is slated for removal as early as 2025-11-30. Refrain from using this package or pin to Setuptools<81. 2025-09-09T22:53:48,068 import pkg_resources 2025-09-09T22:53:48,435 Traceback (most recent call last): 2025-09-09T22:53:48,437 File "", line 2, in 2025-09-09T22:53:48,438 exec(compile(''' 2025-09-09T22:53:48,438 ~~~~^^^^^^^^^^^^ 2025-09-09T22:53:48,438 # This is -- a caller that pip uses to run setup.py 2025-09-09T22:53:48,438 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,438 ...<32 lines>... 2025-09-09T22:53:48,438 exec(compile(setup_py_code, filename, "exec")) 2025-09-09T22:53:48,439 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,439 ''' % ('/tmp/pip-wheel-h963945s/clip-by-openai_c4d095872f864b19bc987473ea353ac9/setup.py',), "", "exec")) 2025-09-09T22:53:48,439 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,439 File "", line 35, in 2025-09-09T22:53:48,439 File "/tmp/pip-wheel-h963945s/clip-by-openai_c4d095872f864b19bc987473ea353ac9/setup.py", line 16, in 2025-09-09T22:53:48,440 open(os.path.join(os.path.dirname(__file__), "requirements.txt")) 2025-09-09T22:53:48,440 ~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,440 FileNotFoundError: [Errno 2] No such file or directory: '/tmp/pip-wheel-h963945s/clip-by-openai_c4d095872f864b19bc987473ea353ac9/requirements.txt' 2025-09-09T22:53:48,546 ERROR: python setup.py egg_info exited with 1 2025-09-09T22:53:48,559 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-09T22:53:48,559 exec(compile('"'"''"'"''"'"' 2025-09-09T22:53:48,559 # This is -- a caller that pip uses to run setup.py 2025-09-09T22:53:48,559 # 2025-09-09T22:53:48,559 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-09T22:53:48,559 # import from `distutils.core` to work with newer packaging standards. 2025-09-09T22:53:48,559 # - It provides a clear error message when setuptools is not installed. 2025-09-09T22:53:48,559 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-09T22:53:48,559 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-09T22:53:48,559 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-09T22:53:48,559 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-09T22:53:48,559 import os, sys, tokenize, traceback 2025-09-09T22:53:48,559 2025-09-09T22:53:48,559 try: 2025-09-09T22:53:48,559 import setuptools 2025-09-09T22:53:48,559 except ImportError: 2025-09-09T22:53:48,559 print( 2025-09-09T22:53:48,559 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-09T22:53:48,559 "the build environment with exception:", 2025-09-09T22:53:48,559 file=sys.stderr, 2025-09-09T22:53:48,559 ) 2025-09-09T22:53:48,559 traceback.print_exc() 2025-09-09T22:53:48,559 sys.exit(1) 2025-09-09T22:53:48,559 2025-09-09T22:53:48,559 __file__ = %r 2025-09-09T22:53:48,559 sys.argv[0] = __file__ 2025-09-09T22:53:48,559 2025-09-09T22:53:48,559 if os.path.exists(__file__): 2025-09-09T22:53:48,559 filename = __file__ 2025-09-09T22:53:48,559 with tokenize.open(__file__) as f: 2025-09-09T22:53:48,559 setup_py_code = f.read() 2025-09-09T22:53:48,559 else: 2025-09-09T22:53:48,559 filename = "" 2025-09-09T22:53:48,559 setup_py_code = "from setuptools import setup; setup()" 2025-09-09T22:53:48,559 2025-09-09T22:53:48,559 exec(compile(setup_py_code, filename, "exec")) 2025-09-09T22:53:48,559 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-h963945s/clip-by-openai_c4d095872f864b19bc987473ea353ac9/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-byl5g978[/] 2025-09-09T22:53:48,559 [bold magenta]cwd[/]: /tmp/pip-wheel-h963945s/clip-by-openai_c4d095872f864b19bc987473ea353ac9/ 2025-09-09T22:53:48,559 Preparing metadata (setup.py): finished with status 'error' 2025-09-09T22:53:48,560 ERROR: metadata generation failed 2025-09-09T22:53:48,566 Exception information: 2025-09-09T22:53:48,566 Traceback (most recent call last): 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-09T22:53:48,566 call_subprocess( 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~^ 2025-09-09T22:53:48,566 args, 2025-09-09T22:53:48,566 ^^^^^ 2025-09-09T22:53:48,566 ...<2 lines>... 2025-09-09T22:53:48,566 spinner=spinner, 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 ^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-09T22:53:48,566 raise error 2025-09-09T22:53:48,566 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-09T22:53:48,566 2025-09-09T22:53:48,566 The above exception was the direct cause of the following exception: 2025-09-09T22:53:48,566 2025-09-09T22:53:48,566 Traceback (most recent call last): 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-09T22:53:48,566 status = _inner_run() 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-09T22:53:48,566 return self.run(options, args) 2025-09-09T22:53:48,566 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-09T22:53:48,566 return func(self, options, args) 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-09T22:53:48,566 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-09T22:53:48,566 result = self._result = resolver.resolve( 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~^ 2025-09-09T22:53:48,566 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 ^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-09T22:53:48,566 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-09T22:53:48,566 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-09T22:53:48,566 if not criterion.candidates: 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-09T22:53:48,566 return bool(self._sequence) 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-09T22:53:48,566 self._bool = any(self) 2025-09-09T22:53:48,566 ~~~^^^^^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-09T22:53:48,566 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-09T22:53:48,566 ^^^^^^^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-09T22:53:48,566 candidate = func() 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-09T22:53:48,566 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T22:53:48,566 link, template, name, version 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 ^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-09T22:53:48,566 self._link_candidate_cache[link] = LinkCandidate( 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~^ 2025-09-09T22:53:48,566 link, 2025-09-09T22:53:48,566 ^^^^^ 2025-09-09T22:53:48,566 ...<3 lines>... 2025-09-09T22:53:48,566 version=version, 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 ^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-09T22:53:48,566 super().__init__( 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~^ 2025-09-09T22:53:48,566 link=link, 2025-09-09T22:53:48,566 ^^^^^^^^^^ 2025-09-09T22:53:48,566 ...<4 lines>... 2025-09-09T22:53:48,566 version=version, 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 ^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-09T22:53:48,566 self.dist = self._prepare() 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-09T22:53:48,566 dist = self._prepare_distribution() 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-09T22:53:48,566 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-09T22:53:48,566 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-09T22:53:48,566 dist = _get_prepared_distribution( 2025-09-09T22:53:48,566 req, 2025-09-09T22:53:48,566 ...<3 lines>... 2025-09-09T22:53:48,566 self.check_build_deps, 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-09T22:53:48,566 abstract_dist.prepare_distribution_metadata( 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T22:53:48,566 finder, build_isolation, check_build_deps 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 ^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-09T22:53:48,566 self.req.prepare_metadata() 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-09T22:53:48,566 self.metadata_directory = generate_metadata_legacy( 2025-09-09T22:53:48,566 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T22:53:48,566 build_env=self.build_env, 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ...<3 lines>... 2025-09-09T22:53:48,566 details=details, 2025-09-09T22:53:48,566 ^^^^^^^^^^^^^^^^ 2025-09-09T22:53:48,566 ) 2025-09-09T22:53:48,566 ^ 2025-09-09T22:53:48,566 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-09T22:53:48,566 raise MetadataGenerationFailed(package_details=details) from error 2025-09-09T22:53:48,566 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-09T22:53:48,589 Removed clip-by-openai==1.1 from https://files.pythonhosted.org/packages/e7/e8/62bf743dad602357a028551a183aada03e59d66805cabeb8c3b8a2d52fa3/clip-by-openai-1.1.tar.gz from build tracker '/tmp/pip-build-tracker-wagk6iv8' 2025-09-09T22:53:48,590 Removed build tracker: '/tmp/pip-build-tracker-wagk6iv8'