From afaa7177fe831b3b731d50fa4b7dc2d9af5a875f Mon Sep 17 00:00:00 2001 From: Ryan Howard Date: Fri, 19 Jul 2024 12:58:07 -0400 Subject: [PATCH] fix(scripts): setuptools v71 removed the need for extern (#15717) # Overview Version 71.0.0 removed the setuptools.extern package and release on 07/18/2024 With this we no longer need to use `from setuptools.extern import packaging` and we can just `import packaging` However depending on the version of 3.10 you may still have 70.3.0 and packaging < 24.0 so we need to navigate around the old and new. # Test Plan # Changelog # Review requests # Risk assessment --- scripts/python_build_utils.py | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/scripts/python_build_utils.py b/scripts/python_build_utils.py index 317775cd2f2..7124e695cd2 100644 --- a/scripts/python_build_utils.py +++ b/scripts/python_build_utils.py @@ -56,9 +56,18 @@ def normalize_version(package, project, extra_tag='', git_dir=None): # the way they vendor dependencies, like the packaging module that # provides the way to normalize version numbers for wheel file names. So # we try all the possible ways to find it. + # Since 71.0.0 they have removed the need for extern + # So depending on the version of 3.10 you're building on you may or may not + # need to use the extern or import it directly try: - # new way - from setuptools.extern import packaging + import setuptools + major, minor, patch = [int(x, 10) for x in setuptools.__version__.split('.')] + if major < 71: + # new way + from setuptools.extern import packaging + else: + # new new way + import packaging except ImportError: # old way from pkg_resources.extern import packaging