1
1
Fork 0
mirror of https://github.com/pypa/pip synced 2023-12-13 21:30:23 +01:00
pip/src/pip/_internal/commands/wheel.py

176 lines
6.4 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
from __future__ import absolute_import
import logging
2012-10-17 00:57:10 +02:00
import os
2018-07-29 13:37:42 +02:00
from pip._internal.cache import WheelCache
2018-07-23 09:31:05 +02:00
from pip._internal.cli import cmdoptions
from pip._internal.cli.req_command import RequirementCommand
from pip._internal.exceptions import CommandError, PreviousBuildDirError
from pip._internal.req import RequirementSet
from pip._internal.req.req_tracker import RequirementTracker
from pip._internal.utils.temp_dir import TempDirectory
from pip._internal.utils.typing import MYPY_CHECK_RUNNING
from pip._internal.wheel import WheelBuilder
if MYPY_CHECK_RUNNING:
from optparse import Values
from typing import Any, List
logger = logging.getLogger(__name__)
class WheelCommand(RequirementCommand):
2013-03-16 07:56:46 +01:00
"""
2013-03-18 03:58:32 +01:00
Build Wheel archives for your requirements and dependencies.
2013-03-16 07:56:46 +01:00
Wheel is a built-package format, and offers the advantage of not
recompiling your software during every install. For more details, see the
wheel docs: https://wheel.readthedocs.io/en/latest/
2013-03-18 03:58:32 +01:00
Requirements: setuptools>=0.8, and wheel.
2013-03-18 03:58:32 +01:00
'pip wheel' uses the bdist_wheel setuptools extension from the wheel
package to build individual wheels.
2013-03-18 03:58:32 +01:00
2013-03-16 07:56:46 +01:00
"""
2013-02-03 07:40:30 +01:00
usage = """
%prog [options] <requirement specifier> ...
2013-04-05 20:02:15 +02:00
%prog [options] -r <requirements file> ...
%prog [options] [-e] <vcs project url> ...
%prog [options] [-e] <local project path> ...
2013-04-05 20:02:15 +02:00
%prog [options] <archive url/path> ..."""
2013-02-03 07:40:30 +01:00
def __init__(self, *args, **kw):
super(WheelCommand, self).__init__(*args, **kw)
cmd_opts = self.cmd_opts
cmd_opts.add_option(
2012-10-17 00:57:10 +02:00
'-w', '--wheel-dir',
dest='wheel_dir',
2013-02-03 07:40:30 +01:00
metavar='dir',
default=os.curdir,
help=("Build wheels into <dir>, where the default is the "
"current working directory."),
)
cmd_opts.add_option(cmdoptions.no_binary())
cmd_opts.add_option(cmdoptions.only_binary())
cmd_opts.add_option(cmdoptions.prefer_binary())
2013-02-03 07:40:30 +01:00
cmd_opts.add_option(
2012-10-17 00:57:10 +02:00
'--build-option',
dest='build_options',
2013-02-03 07:56:32 +01:00
metavar='options',
2012-10-17 00:57:10 +02:00
action='append',
help="Extra arguments to be supplied to 'setup.py bdist_wheel'.",
)
cmd_opts.add_option(cmdoptions.no_build_isolation())
cmd_opts.add_option(cmdoptions.use_pep517())
cmd_opts.add_option(cmdoptions.no_use_pep517())
cmd_opts.add_option(cmdoptions.constraints())
cmd_opts.add_option(cmdoptions.editable())
cmd_opts.add_option(cmdoptions.requirements())
cmd_opts.add_option(cmdoptions.src())
cmd_opts.add_option(cmdoptions.ignore_requires_python())
cmd_opts.add_option(cmdoptions.no_deps())
cmd_opts.add_option(cmdoptions.build_dir())
cmd_opts.add_option(cmdoptions.progress_bar())
2013-02-03 07:40:30 +01:00
cmd_opts.add_option(
'--global-option',
dest='global_options',
action='append',
metavar='options',
help="Extra global options to be supplied to the setup.py "
"call before the 'bdist_wheel' command.")
cmd_opts.add_option(
'--pre',
action='store_true',
default=False,
help=("Include pre-release and development versions. By default, "
"pip only finds stable versions."),
)
cmd_opts.add_option(cmdoptions.no_clean())
cmd_opts.add_option(cmdoptions.require_hashes())
2013-05-25 02:11:15 +02:00
index_opts = cmdoptions.make_option_group(
cmdoptions.index_group,
self.parser,
)
2013-02-03 07:40:30 +01:00
self.parser.insert_option_group(0, index_opts)
self.parser.insert_option_group(0, cmd_opts)
2012-10-17 00:57:10 +02:00
def run(self, options, args):
# type: (Values, List[Any]) -> None
cmdoptions.check_install_build_global(options)
2012-10-17 01:39:56 +02:00
if options.build_dir:
options.build_dir = os.path.abspath(options.build_dir)
options.src_dir = os.path.abspath(options.src_dir)
with self._build_session(options) as session:
finder = self._build_package_finder(options, session)
build_delete = (not (options.no_clean or options.build_dir))
wheel_cache = WheelCache(options.cache_dir, options.format_control)
with RequirementTracker() as req_tracker, TempDirectory(
options.build_dir, delete=build_delete, kind="wheel"
) as directory:
requirement_set = RequirementSet(
require_hashes=options.require_hashes,
)
try:
self.populate_requirement_set(
requirement_set, args, options, finder, session,
wheel_cache
)
preparer = self.make_requirement_preparer(
temp_directory=directory,
options=options,
req_tracker=req_tracker,
wheel_download_dir=options.wheel_dir,
)
resolver = self.make_resolver(
preparer=preparer,
finder=finder,
session=session,
options=options,
wheel_cache=wheel_cache,
ignore_requires_python=options.ignore_requires_python,
use_pep517=options.use_pep517,
)
resolver.resolve(requirement_set)
2017-06-13 07:19:53 +02:00
# build wheels
wb = WheelBuilder(
preparer, wheel_cache,
build_options=options.build_options or [],
global_options=options.global_options or [],
no_clean=options.no_clean,
)
build_failures = wb.build(
requirement_set.requirements.values(),
)
if len(build_failures) != 0:
raise CommandError(
"Failed to build one or more wheels"
)
except PreviousBuildDirError:
options.no_clean = True
raise
finally:
if not options.no_clean:
requirement_set.cleanup_files()
2017-07-06 02:15:21 +02:00
wheel_cache.cleanup()