Skip to content

Commit

Permalink
Merge pull request #2256 from pypa/bugfix/2230-warn-distutils-present
Browse files Browse the repository at this point in the history
Warn the user when distutils is present
  • Loading branch information
jaraco authored Jul 12, 2020
2 parents 6ecd778 + 36df1d7 commit a494597
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 1 deletion.
1 change: 1 addition & 0 deletions changelog.d/2230.change.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Now warn the user when setuptools is imported after distutils modules have been loaded (exempting PyPy for 3.6), directing the users of packages to import setuptools first.
19 changes: 18 additions & 1 deletion setuptools/distutils_patch.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,26 @@
import warnings


is_pypy = '__pypy__' in sys.builtin_module_names


def warn_distutils_present():
if 'distutils' not in sys.modules:
return
if is_pypy and sys.version_info < (3, 7):
# PyPy for 3.6 unconditionally imports distutils, so bypass the warning
# https://foss.heptapod.net/pypy/pypy/-/blob/be829135bc0d758997b3566062999ee8b23872b4/lib-python/3/site.py#L250
return
warnings.warn(
"Distutils was imported before Setuptools. This usage is discouraged "
"and may exhibit undesirable behaviors or errors. Please use "
"Setuptools' objects directly or at least import Setuptools first.")


def clear_distutils():
if 'distutils' not in sys.modules:
return
warnings.warn("Setuptools is replacing distutils")
warnings.warn("Setuptools is replacing distutils.")
mods = [name for name in sys.modules if re.match(r'distutils\b', name)]
for name in mods:
del sys.modules[name]
Expand All @@ -40,5 +56,6 @@ def ensure_local_distutils():
assert '_distutils' in core.__file__, core.__file__


warn_distutils_present()
if enabled():
ensure_local_distutils()

0 comments on commit a494597

Please sign in to comment.