wheel.py 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738
  1. from __future__ import annotations
  2. import logging
  3. import os
  4. from pip._vendor.pyproject_hooks import BuildBackendHookCaller
  5. from pip._internal.utils.subprocess import runner_with_spinner_message
  6. logger = logging.getLogger(__name__)
  7. def build_wheel_pep517(
  8. name: str,
  9. backend: BuildBackendHookCaller,
  10. metadata_directory: str,
  11. wheel_directory: str,
  12. ) -> str | None:
  13. """Build one InstallRequirement using the PEP 517 build process.
  14. Returns path to wheel if successfully built. Otherwise, returns None.
  15. """
  16. assert metadata_directory is not None
  17. try:
  18. logger.debug("Destination directory: %s", wheel_directory)
  19. runner = runner_with_spinner_message(
  20. f"Building wheel for {name} (pyproject.toml)"
  21. )
  22. with backend.subprocess_runner(runner):
  23. wheel_name = backend.build_wheel(
  24. wheel_directory=wheel_directory,
  25. metadata_directory=metadata_directory,
  26. )
  27. except Exception:
  28. logger.error("Failed building wheel for %s", name)
  29. return None
  30. return os.path.join(wheel_directory, wheel_name)