2025-09-11T19:38:08,638 Created temporary directory: /tmp/pip-build-tracker-_0zc9qfz 2025-09-11T19:38:08,639 Initialized build tracking at /tmp/pip-build-tracker-_0zc9qfz 2025-09-11T19:38:08,639 Created build tracker: /tmp/pip-build-tracker-_0zc9qfz 2025-09-11T19:38:08,639 Entered build tracker: /tmp/pip-build-tracker-_0zc9qfz 2025-09-11T19:38:08,640 Created temporary directory: /tmp/pip-wheel-bi_c6el2 2025-09-11T19:38:08,643 Created temporary directory: /tmp/pip-ephem-wheel-cache-ucnyu3lk 2025-09-11T19:38:08,704 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-09-11T19:38:08,707 2 location(s) to search for versions of fritz-advanced-thermostat: 2025-09-11T19:38:08,707 * https://pypi.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,707 * https://www.piwheels.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,707 Fetching project page and analyzing links: https://pypi.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,708 Getting page https://pypi.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,709 Found index url https://pypi.org/simple/ 2025-09-11T19:38:08,786 Fetched page https://pypi.org/simple/fritz-advanced-thermostat/ as application/vnd.pypi.simple.v1+json 2025-09-11T19:38:08,788 Found link https://files.pythonhosted.org/packages/c9/ae/ad2905df9dafcd0bb63972dca6ebb67b544cc582257e6ed2250914caf3aa/fritz-advanced-thermostat-0.1.1.tar.gz (from https://pypi.org/simple/fritz-advanced-thermostat/), version: 0.1.1 2025-09-11T19:38:08,789 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/a7/a8/edbb21582ae69e7457d53668fc7ead834575b65433dbe9a1f2ac5a97718d/fritz_advanced_thermostat-0.1.1-py2.py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,789 Found link https://files.pythonhosted.org/packages/c6/51/80225eda2e8182cf69b1f75d07dee292a872f633c8ca34f311550a5c2a29/fritz-advanced-thermostat-0.2.0.tar.gz (from https://pypi.org/simple/fritz-advanced-thermostat/), version: 0.2.0 2025-09-11T19:38:08,789 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/93/9d/4d160cd7c167e59e40a84efa0ae17e2547bbf9a9f284df0d0d65e7136157/fritz_advanced_thermostat-0.2.0-py2.py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,790 Found link https://files.pythonhosted.org/packages/c8/5a/c2904bd672fc2b8d1eb089de60949eac4bc339c7c7713db9c4954103e1a3/fritz-advanced-thermostat-0.2.1.tar.gz (from https://pypi.org/simple/fritz-advanced-thermostat/), version: 0.2.1 2025-09-11T19:38:08,790 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/66/cc/01b88c214d5886befd993f404027d4d8b2e87bd847454ee6118b12757bce/fritz_advanced_thermostat-0.2.1-py2.py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,790 Found link https://files.pythonhosted.org/packages/fa/61/e8fab1d2dad81e3ef949f1fb8449da9e032035661bc5e8cbdd7b360bb2fa/fritz-advanced-thermostat-0.2.2.tar.gz (from https://pypi.org/simple/fritz-advanced-thermostat/), version: 0.2.2 2025-09-11T19:38:08,790 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/45/41/aec2e140aaf076927eefd321767ce6a0921ecbb9b1def1c90333cba1d5d4/fritz_advanced_thermostat-0.2.2-py2.py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,791 Found link https://files.pythonhosted.org/packages/96/b9/7631862b41115e7437c18e5d354c3a9cda68a8a9077cd8135978fd6fafac/fritz-advanced-thermostat-0.2.3.tar.gz (from https://pypi.org/simple/fritz-advanced-thermostat/), version: 0.2.3 2025-09-11T19:38:08,791 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/93/e1/d97d092309a59e1eee4d7ba2938fc9e428038eac4e8223d27b37b88c1a1a/fritz_advanced_thermostat-0.2.3-py2.py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,791 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/2d/03/a228810d6b39089a7b1fb8a8e2c03900ca6700daf41854779b3fdaa23c9a/fritz_advanced_thermostat-0.2.3-py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,791 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/ea/a2/9e9542adfdeea513bcd513f356aa1ffd6059c731c156f818efe0f19d9bfb/fritz_advanced_thermostat-0.2.4-py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,791 Skipping link: No binaries permitted for fritz-advanced-thermostat: https://files.pythonhosted.org/packages/30/c9/4b481cb228a290295cc88b6a59cc78e5ce80d7327d8c24dfc4096e9b5260/fritz_advanced_thermostat-0.2.5-py3-none-any.whl (from https://pypi.org/simple/fritz-advanced-thermostat/) 2025-09-11T19:38:08,792 Fetching project page and analyzing links: https://www.piwheels.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,792 Getting page https://www.piwheels.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,793 Found index url https://www.piwheels.org/simple/ 2025-09-11T19:38:08,888 Fetched page https://www.piwheels.org/simple/fritz-advanced-thermostat/ as text/html 2025-09-11T19:38:08,889 Skipping link: not a file: https://www.piwheels.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,889 Skipping link: not a file: https://pypi.org/simple/fritz-advanced-thermostat/ 2025-09-11T19:38:08,915 Given no hashes to check 1 links for project 'fritz-advanced-thermostat': discarding no candidates 2025-09-11T19:38:08,916 Collecting fritz-advanced-thermostat==0.2.0 2025-09-11T19:38:08,918 Created temporary directory: /tmp/pip-unpack-igmy26ak 2025-09-11T19:38:09,063 Downloading fritz-advanced-thermostat-0.2.0.tar.gz (7.6 kB) 2025-09-11T19:38:09,083 Added fritz-advanced-thermostat==0.2.0 from https://files.pythonhosted.org/packages/c6/51/80225eda2e8182cf69b1f75d07dee292a872f633c8ca34f311550a5c2a29/fritz-advanced-thermostat-0.2.0.tar.gz to build tracker '/tmp/pip-build-tracker-_0zc9qfz' 2025-09-11T19:38:09,084 Running setup.py (path:/tmp/pip-wheel-bi_c6el2/fritz-advanced-thermostat_19c6791bbcbb4aaaa5416b01c7cb43b0/setup.py) egg_info for package fritz-advanced-thermostat 2025-09-11T19:38:09,084 Created temporary directory: /tmp/pip-pip-egg-info-_y7whmp1 2025-09-11T19:38:09,085 Preparing metadata (setup.py): started 2025-09-11T19:38:09,086 Running command python setup.py egg_info 2025-09-11T19:38:09,640 requirements.txt not found 2025-09-11T19:38:09,738 ERROR: python setup.py egg_info exited with 1 2025-09-11T19:38:09,752 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2025-09-11T19:38:09,752 exec(compile('"'"''"'"''"'"' 2025-09-11T19:38:09,752 # This is -- a caller that pip uses to run setup.py 2025-09-11T19:38:09,752 # 2025-09-11T19:38:09,752 # - It imports setuptools before invoking setup.py, to enable projects that directly 2025-09-11T19:38:09,752 # import from `distutils.core` to work with newer packaging standards. 2025-09-11T19:38:09,752 # - It provides a clear error message when setuptools is not installed. 2025-09-11T19:38:09,752 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2025-09-11T19:38:09,752 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2025-09-11T19:38:09,752 # manifest_maker: standard file '"'"'-c'"'"' not found". 2025-09-11T19:38:09,752 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2025-09-11T19:38:09,752 import os, sys, tokenize, traceback 2025-09-11T19:38:09,752 2025-09-11T19:38:09,752 try: 2025-09-11T19:38:09,752 import setuptools 2025-09-11T19:38:09,752 except ImportError: 2025-09-11T19:38:09,752 print( 2025-09-11T19:38:09,752 "ERROR: Can not execute `setup.py` since setuptools failed to import in " 2025-09-11T19:38:09,752 "the build environment with exception:", 2025-09-11T19:38:09,752 file=sys.stderr, 2025-09-11T19:38:09,752 ) 2025-09-11T19:38:09,752 traceback.print_exc() 2025-09-11T19:38:09,752 sys.exit(1) 2025-09-11T19:38:09,752 2025-09-11T19:38:09,752 __file__ = %r 2025-09-11T19:38:09,752 sys.argv[0] = __file__ 2025-09-11T19:38:09,752 2025-09-11T19:38:09,752 if os.path.exists(__file__): 2025-09-11T19:38:09,752 filename = __file__ 2025-09-11T19:38:09,752 with tokenize.open(__file__) as f: 2025-09-11T19:38:09,752 setup_py_code = f.read() 2025-09-11T19:38:09,752 else: 2025-09-11T19:38:09,752 filename = "" 2025-09-11T19:38:09,752 setup_py_code = "from setuptools import setup; setup()" 2025-09-11T19:38:09,752 2025-09-11T19:38:09,752 exec(compile(setup_py_code, filename, "exec")) 2025-09-11T19:38:09,752 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-bi_c6el2/fritz-advanced-thermostat_19c6791bbcbb4aaaa5416b01c7cb43b0/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-_y7whmp1[/] 2025-09-11T19:38:09,752 [bold magenta]cwd[/]: /tmp/pip-wheel-bi_c6el2/fritz-advanced-thermostat_19c6791bbcbb4aaaa5416b01c7cb43b0/ 2025-09-11T19:38:09,752 Preparing metadata (setup.py): finished with status 'error' 2025-09-11T19:38:09,753 ERROR: metadata generation failed 2025-09-11T19:38:09,759 Exception information: 2025-09-11T19:38:09,759 Traceback (most recent call last): 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 63, in generate_metadata 2025-09-11T19:38:09,759 call_subprocess( 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~^ 2025-09-11T19:38:09,759 args, 2025-09-11T19:38:09,759 ^^^^^ 2025-09-11T19:38:09,759 ...<2 lines>... 2025-09-11T19:38:09,759 spinner=spinner, 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 ^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 209, in call_subprocess 2025-09-11T19:38:09,759 raise error 2025-09-11T19:38:09,759 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2025-09-11T19:38:09,759 2025-09-11T19:38:09,759 The above exception was the direct cause of the following exception: 2025-09-11T19:38:09,759 2025-09-11T19:38:09,759 Traceback (most recent call last): 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 105, in _run_wrapper 2025-09-11T19:38:09,759 status = _inner_run() 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 96, in _inner_run 2025-09-11T19:38:09,759 return self.run(options, args) 2025-09-11T19:38:09,759 ~~~~~~~~^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 68, in wrapper 2025-09-11T19:38:09,759 return func(self, options, args) 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 147, in run 2025-09-11T19:38:09,759 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 96, in resolve 2025-09-11T19:38:09,759 result = self._result = resolver.resolve( 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~^ 2025-09-11T19:38:09,759 collected.requirements, max_rounds=limit_how_complex_resolution_can_be 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 ^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 515, in resolve 2025-09-11T19:38:09,759 state = resolution.resolve(requirements, max_rounds=max_rounds) 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 388, in resolve 2025-09-11T19:38:09,759 self._add_to_criteria(self.state.criteria, r, parent=None) 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers/resolution.py", line 141, in _add_to_criteria 2025-09-11T19:38:09,759 if not criterion.candidates: 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 194, in __bool__ 2025-09-11T19:38:09,759 return bool(self._sequence) 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 163, in __bool__ 2025-09-11T19:38:09,759 self._bool = any(self) 2025-09-11T19:38:09,759 ~~~^^^^^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 147, in 2025-09-11T19:38:09,759 return (c for c in iterator if id(c) not in self._incompatible_ids) 2025-09-11T19:38:09,759 ^^^^^^^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 37, in _iter_built 2025-09-11T19:38:09,759 candidate = func() 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 187, in _make_candidate_from_link 2025-09-11T19:38:09,759 base: Optional[BaseCandidate] = self._make_base_candidate_from_link( 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-11T19:38:09,759 link, template, name, version 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 ^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 233, in _make_base_candidate_from_link 2025-09-11T19:38:09,759 self._link_candidate_cache[link] = LinkCandidate( 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~^ 2025-09-11T19:38:09,759 link, 2025-09-11T19:38:09,759 ^^^^^ 2025-09-11T19:38:09,759 ...<3 lines>... 2025-09-11T19:38:09,759 version=version, 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 ^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 306, in __init__ 2025-09-11T19:38:09,759 super().__init__( 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~^ 2025-09-11T19:38:09,759 link=link, 2025-09-11T19:38:09,759 ^^^^^^^^^^ 2025-09-11T19:38:09,759 ...<4 lines>... 2025-09-11T19:38:09,759 version=version, 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 ^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 159, in __init__ 2025-09-11T19:38:09,759 self.dist = self._prepare() 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 236, in _prepare 2025-09-11T19:38:09,759 dist = self._prepare_distribution() 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 317, in _prepare_distribution 2025-09-11T19:38:09,759 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 532, in prepare_linked_requirement 2025-09-11T19:38:09,759 return self._prepare_linked_requirement(req, parallel_builds) 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 647, in _prepare_linked_requirement 2025-09-11T19:38:09,759 dist = _get_prepared_distribution( 2025-09-11T19:38:09,759 req, 2025-09-11T19:38:09,759 ...<3 lines>... 2025-09-11T19:38:09,759 self.check_build_deps, 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 71, in _get_prepared_distribution 2025-09-11T19:38:09,759 abstract_dist.prepare_distribution_metadata( 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-11T19:38:09,759 finder, build_isolation, check_build_deps 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 ^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 69, in prepare_distribution_metadata 2025-09-11T19:38:09,759 self.req.prepare_metadata() 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~~~~~~~~~~^^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 581, in prepare_metadata 2025-09-11T19:38:09,759 self.metadata_directory = generate_metadata_legacy( 2025-09-11T19:38:09,759 ~~~~~~~~~~~~~~~~~~~~~~~~^ 2025-09-11T19:38:09,759 build_env=self.build_env, 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ...<3 lines>... 2025-09-11T19:38:09,759 details=details, 2025-09-11T19:38:09,759 ^^^^^^^^^^^^^^^^ 2025-09-11T19:38:09,759 ) 2025-09-11T19:38:09,759 ^ 2025-09-11T19:38:09,759 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 70, in generate_metadata 2025-09-11T19:38:09,759 raise MetadataGenerationFailed(package_details=details) from error 2025-09-11T19:38:09,759 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2025-09-11T19:38:09,783 Removed fritz-advanced-thermostat==0.2.0 from https://files.pythonhosted.org/packages/c6/51/80225eda2e8182cf69b1f75d07dee292a872f633c8ca34f311550a5c2a29/fritz-advanced-thermostat-0.2.0.tar.gz from build tracker '/tmp/pip-build-tracker-_0zc9qfz' 2025-09-11T19:38:09,783 Removed build tracker: '/tmp/pip-build-tracker-_0zc9qfz'