2025-09-09T20:47:10,154 Created temporary directory: /tmp/pip-build-tracker-pkregl8p 2025-09-09T20:47:10,155 Initialized build tracking at /tmp/pip-build-tracker-pkregl8p 2025-09-09T20:47:10,155 Created build tracker: /tmp/pip-build-tracker-pkregl8p 2025-09-09T20:47:10,155 Entered build tracker: /tmp/pip-build-tracker-pkregl8p 2025-09-09T20:47:10,155 Created temporary directory: /tmp/pip-wheel-gblatx84 2025-09-09T20:47:10,158 Created temporary directory: /tmp/pip-ephem-wheel-cache-xyad_4uk 2025-09-09T20:47:10,217 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-09T20:47:10,220 2 location(s) to search for versions of clip-by-openai: 2025-09-09T20:47:10,220 * https://pypi.org/simple/clip-by-openai/ 2025-09-09T20:47:10,220 * https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T20:47:10,220 Fetching project page and analyzing links: https://pypi.org/simple/clip-by-openai/ 2025-09-09T20:47:10,220 Getting page https://pypi.org/simple/clip-by-openai/ 2025-09-09T20:47:10,222 Found index url https://pypi.org/simple/ 2025-09-09T20:47:10,371 Fetched page https://pypi.org/simple/clip-by-openai/ as application/vnd.pypi.simple.v1+json 2025-09-09T20:47:10,376 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-09T20:47:10,378 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-09T20:47:10,378 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-09T20:47:10,379 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-09T20:47:10,379 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-09T20:47:10,380 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-09T20:47:10,380 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-09T20:47:10,381 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-09T20:47:10,381 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-09T20:47:10,381 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-09T20:47:10,382 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-09T20:47:10,382 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-09T20:47:10,383 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-09T20:47:10,383 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-09T20:47:10,384 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-09T20:47:10,384 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-09T20:47:10,385 Fetching project page and analyzing links: https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T20:47:10,385 Getting page https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T20:47:10,387 Found index url https://www.piwheels.org/simple/ 2025-09-09T20:47:10,480 Fetched page https://www.piwheels.org/simple/clip-by-openai/ as text/html 2025-09-09T20:47:10,482 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-09T20:47:10,482 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-09T20:47:10,482 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-09T20:47:10,482 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-09T20:47:10,482 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-09T20:47:10,482 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-09T20:47:10,483 Skipping link: not a file: https://www.piwheels.org/simple/clip-by-openai/ 2025-09-09T20:47:10,483 Skipping link: not a file: https://pypi.org/simple/clip-by-openai/ 2025-09-09T20:47:10,510 Given no hashes to check 1 links for project 'clip-by-openai': discarding no candidates 2025-09-09T20:47:10,511 Collecting clip-by-openai==1.0.1 2025-09-09T20:47:10,513 Created temporary directory: /tmp/pip-unpack-h_p_bkwg 2025-09-09T20:47:10,658 Downloading clip-by-openai-1.0.1.tar.gz (1.4 MB) 2025-09-09T20:47:10,846 Added clip-by-openai==1.0.1 from https://files.pythonhosted.org/packages/dd/80/d490a5b37228f871c16faae706e20bc536d8299f2ae41d0dd2fbf568668a/clip-by-openai-1.0.1.tar.gz to build tracker '/tmp/pip-build-tracker-pkregl8p' 2025-09-09T20:47:10,847 Running setup.py (path:/tmp/pip-wheel-gblatx84/clip-by-openai_8d98779b37144966a029a7682d60072c/setup.py) egg_info for package clip-by-openai 2025-09-09T20:47:10,848 Created temporary directory: /tmp/pip-pip-egg-info-fcz6wjc7 2025-09-09T20:47:10,848 Preparing metadata (setup.py): started 2025-09-09T20:47:10,849 Running command python setup.py egg_info 2025-09-09T20:47:11,421 /tmp/pip-wheel-gblatx84/clip-by-openai_8d98779b37144966a029a7682d60072c/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-09T20:47:11,421 import pkg_resources 2025-09-09T20:47:11,764 Traceback (most recent call last): 2025-09-09T20:47:11,766 File "", line 2, in 2025-09-09T20:47:11,766 exec(compile(''' 2025-09-09T20:47:11,767 ~~~~^^^^^^^^^^^^ 2025-09-09T20:47:11,767 # This is -- a caller that pip uses to run setup.py 2025-09-09T20:47:11,767 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,767 ...<32 lines>... 2025-09-09T20:47:11,767 exec(compile(setup_py_code, filename, "exec")) 2025-09-09T20:47:11,767 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,768 ''' % ('/tmp/pip-wheel-gblatx84/clip-by-openai_8d98779b37144966a029a7682d60072c/setup.py',), "", "exec")) 2025-09-09T20:47:11,768 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,768 File "", line 35, in 2025-09-09T20:47:11,768 File "/tmp/pip-wheel-gblatx84/clip-by-openai_8d98779b37144966a029a7682d60072c/setup.py", line 16, in 2025-09-09T20:47:11,768 open(os.path.join(os.path.dirname(__file__), "requirements.txt")) 2025-09-09T20:47:11,768 ~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,768 FileNotFoundError: [Errno 2] No such file or directory: '/tmp/pip-wheel-gblatx84/clip-by-openai_8d98779b37144966a029a7682d60072c/requirements.txt' 2025-09-09T20:47:11,861 ERROR: python setup.py egg_info exited with 1 2025-09-09T20:47:11,872 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-09T20:47:11,872 exec(compile('"'"''"'"''"'"' 2025-09-09T20:47:11,872 # This is -- a caller that pip uses to run setup.py 2025-09-09T20:47:11,872 # 2025-09-09T20:47:11,872 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-09T20:47:11,872 # import from `distutils.core` to work with newer packaging standards. 2025-09-09T20:47:11,872 # - It provides a clear error message when setuptools is not installed. 2025-09-09T20:47:11,872 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-09T20:47:11,872 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-09T20:47:11,872 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-09T20:47:11,872 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-09T20:47:11,872 import os, sys, tokenize, traceback 2025-09-09T20:47:11,872 2025-09-09T20:47:11,872 try: 2025-09-09T20:47:11,872 import setuptools 2025-09-09T20:47:11,872 except ImportError: 2025-09-09T20:47:11,872 print( 2025-09-09T20:47:11,872 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-09T20:47:11,872 "the build environment with exception:", 2025-09-09T20:47:11,872 file=sys.stderr, 2025-09-09T20:47:11,872 ) 2025-09-09T20:47:11,872 traceback.print_exc() 2025-09-09T20:47:11,872 sys.exit(1) 2025-09-09T20:47:11,872 2025-09-09T20:47:11,872 __file__ = %r 2025-09-09T20:47:11,872 sys.argv[0] = __file__ 2025-09-09T20:47:11,872 2025-09-09T20:47:11,872 if os.path.exists(__file__): 2025-09-09T20:47:11,872 filename = __file__ 2025-09-09T20:47:11,872 with tokenize.open(__file__) as f: 2025-09-09T20:47:11,872 setup_py_code = f.read() 2025-09-09T20:47:11,872 else: 2025-09-09T20:47:11,872 filename = "" 2025-09-09T20:47:11,872 setup_py_code = "from setuptools import setup; setup()" 2025-09-09T20:47:11,872 2025-09-09T20:47:11,872 exec(compile(setup_py_code, filename, "exec")) 2025-09-09T20:47:11,872 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-gblatx84/clip-by-openai_8d98779b37144966a029a7682d60072c/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-fcz6wjc7[/] 2025-09-09T20:47:11,872 [bold magenta]cwd[/]: /tmp/pip-wheel-gblatx84/clip-by-openai_8d98779b37144966a029a7682d60072c/ 2025-09-09T20:47:11,873 Preparing metadata (setup.py): finished with status 'error' 2025-09-09T20:47:11,874 ERROR: metadata generation failed 2025-09-09T20:47:11,878 Exception information: 2025-09-09T20:47:11,878 Traceback (most recent call last): 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-09T20:47:11,878 call_subprocess( 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~^ 2025-09-09T20:47:11,878 args, 2025-09-09T20:47:11,878 ^^^^^ 2025-09-09T20:47:11,878 ...<2 lines>... 2025-09-09T20:47:11,878 spinner=spinner, 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 ^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-09T20:47:11,878 raise error 2025-09-09T20:47:11,878 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-09T20:47:11,878 2025-09-09T20:47:11,878 The above exception was the direct cause of the following exception: 2025-09-09T20:47:11,878 2025-09-09T20:47:11,878 Traceback (most recent call last): 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-09T20:47:11,878 status = _inner_run() 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-09T20:47:11,878 return self.run(options, args) 2025-09-09T20:47:11,878 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-09T20:47:11,878 return func(self, options, args) 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-09T20:47:11,878 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-09T20:47:11,878 result = self._result = resolver.resolve( 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~^ 2025-09-09T20:47:11,878 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 ^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-09T20:47:11,878 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-09T20:47:11,878 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-09T20:47:11,878 if not criterion.candidates: 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-09T20:47:11,878 return bool(self._sequence) 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-09T20:47:11,878 self._bool = any(self) 2025-09-09T20:47:11,878 ~~~^^^^^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-09T20:47:11,878 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-09T20:47:11,878 ^^^^^^^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-09T20:47:11,878 candidate = func() 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-09T20:47:11,878 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T20:47:11,878 link, template, name, version 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 ^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-09T20:47:11,878 self._link_candidate_cache[link] = LinkCandidate( 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~^ 2025-09-09T20:47:11,878 link, 2025-09-09T20:47:11,878 ^^^^^ 2025-09-09T20:47:11,878 ...<3 lines>... 2025-09-09T20:47:11,878 version=version, 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 ^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-09T20:47:11,878 super().__init__( 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~^ 2025-09-09T20:47:11,878 link=link, 2025-09-09T20:47:11,878 ^^^^^^^^^^ 2025-09-09T20:47:11,878 ...<4 lines>... 2025-09-09T20:47:11,878 version=version, 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 ^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-09T20:47:11,878 self.dist = self._prepare() 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-09T20:47:11,878 dist = self._prepare_distribution() 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-09T20:47:11,878 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-09T20:47:11,878 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-09T20:47:11,878 dist = _get_prepared_distribution( 2025-09-09T20:47:11,878 req, 2025-09-09T20:47:11,878 ...<3 lines>... 2025-09-09T20:47:11,878 self.check_build_deps, 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-09T20:47:11,878 abstract_dist.prepare_distribution_metadata( 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T20:47:11,878 finder, build_isolation, check_build_deps 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 ^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-09T20:47:11,878 self.req.prepare_metadata() 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-09T20:47:11,878 self.metadata_directory = generate_metadata_legacy( 2025-09-09T20:47:11,878 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-09T20:47:11,878 build_env=self.build_env, 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ...<3 lines>... 2025-09-09T20:47:11,878 details=details, 2025-09-09T20:47:11,878 ^^^^^^^^^^^^^^^^ 2025-09-09T20:47:11,878 ) 2025-09-09T20:47:11,878 ^ 2025-09-09T20:47:11,878 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-09T20:47:11,878 raise MetadataGenerationFailed(package_details=details) from error 2025-09-09T20:47:11,878 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-09T20:47:11,902 Removed clip-by-openai==1.0.1 from https://files.pythonhosted.org/packages/dd/80/d490a5b37228f871c16faae706e20bc536d8299f2ae41d0dd2fbf568668a/clip-by-openai-1.0.1.tar.gz from build tracker '/tmp/pip-build-tracker-pkregl8p' 2025-09-09T20:47:11,902 Removed build tracker: '/tmp/pip-build-tracker-pkregl8p'