diff --git a/news/8372.removal b/news/8372.removal new file mode 100644 index 00000000000..af0cb6e70c7 --- /dev/null +++ b/news/8372.removal @@ -0,0 +1,4 @@ +Deprecate -b/--build/--build-dir/--build-directory. Its current behaviour is confusing +and breaks in case different versions of the same distribution need to be built during +the resolution process. Using the TMPDIR/TEMP/TMP environment variable, possibly +combined with --no-clean covers known use cases. diff --git a/src/pip/_internal/cli/base_command.py b/src/pip/_internal/cli/base_command.py index f51682b60e9..3dbe7fc0796 100644 --- a/src/pip/_internal/cli/base_command.py +++ b/src/pip/_internal/cli/base_command.py @@ -190,6 +190,20 @@ def _main(self, args): ) options.cache_dir = None + if getattr(options, "build_dir", None): + deprecated( + reason=( + "The -b/--build/--build-dir/--build-directory " + "option is deprecated." + ), + replacement=( + "use the TMPDIR/TEMP/TMP environment variable, " + "possibly combined with --no-clean" + ), + gone_in="20.3", + issue=8333, + ) + try: status = self.run(options, args) assert isinstance(status, int) diff --git a/src/pip/_internal/cli/cmdoptions.py b/src/pip/_internal/cli/cmdoptions.py index 5b5647d64f4..82d3d047271 100644 --- a/src/pip/_internal/cli/cmdoptions.py +++ b/src/pip/_internal/cli/cmdoptions.py @@ -702,7 +702,8 @@ def _handle_build_dir(option, opt, value, parser): metavar='dir', action='callback', callback=_handle_build_dir, - help='Directory to unpack packages into and build in. Note that ' + help='(DEPRECATED) ' + 'Directory to unpack packages into and build in. Note that ' 'an initial build still takes place in a temporary directory. ' 'The location of temporary directories can be controlled by setting ' 'the TMPDIR environment variable (TEMP on Windows) appropriately. ' diff --git a/tests/functional/test_install_cleanup.py b/tests/functional/test_install_cleanup.py index ece2161cfb2..649f8ba7fbd 100644 --- a/tests/functional/test_install_cleanup.py +++ b/tests/functional/test_install_cleanup.py @@ -14,7 +14,11 @@ def test_no_clean_option_blocks_cleaning_after_install(script, data): build = script.base_path / 'pip-build' script.pip( 'install', '--no-clean', '--no-index', '--build', build, - '--find-links={}'.format(data.find_links), 'simple', expect_temp=True, + '--find-links={}'.format(data.find_links), 'simple', + expect_temp=True, + # TODO: allow_stderr_warning is used for the --build deprecation, + # remove it when removing support for --build + allow_stderr_warning=True, ) assert exists(build) diff --git a/tests/functional/test_wheel.py b/tests/functional/test_wheel.py index 6bf0486819a..7ad2f160d0b 100644 --- a/tests/functional/test_wheel.py +++ b/tests/functional/test_wheel.py @@ -201,6 +201,9 @@ def test_no_clean_option_blocks_cleaning_after_wheel(script, data): '--find-links={data.find_links}'.format(**locals()), 'simple', expect_temp=True, + # TODO: allow_stderr_warning is used for the --build deprecation, + # remove it when removing support for --build + allow_stderr_warning=True, ) build = build / 'simple' assert exists(build), \