summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatt Clay <matt@mystile.com>2023-05-09 12:26:17 -0700
committerGitHub <noreply@github.com>2023-05-09 14:26:17 -0500
commit55b0b6954553392bf43d0ebbd4e2be0f51b02df8 (patch)
treecee772ac97becb175470ba37b119fa29e38e30dc
parent88a25b7fdc2ba7317f526e6e951e4e3de1d1bf27 (diff)
downloadansible-55b0b6954553392bf43d0ebbd4e2be0f51b02df8.tar.gz
[stable-2.14] pep517 backend - Copy symlinks when copying source (#80690) (#80701)
(cherry picked from commit 54576cd794530768a67bddba2f7450b614611e92)
-rw-r--r--changelogs/fragments/pep517-backend-traceback-fix.yml3
-rw-r--r--packaging/pep517_backend/_backend.py2
2 files changed, 4 insertions, 1 deletions
diff --git a/changelogs/fragments/pep517-backend-traceback-fix.yml b/changelogs/fragments/pep517-backend-traceback-fix.yml
new file mode 100644
index 0000000000..cf779f9b46
--- /dev/null
+++ b/changelogs/fragments/pep517-backend-traceback-fix.yml
@@ -0,0 +1,3 @@
+bugfixes:
+ - pep517 build backend - Copy symlinks when copying the source tree.
+ This avoids tracebacks in various scenarios, such as when a venv is present in the source tree.
diff --git a/packaging/pep517_backend/_backend.py b/packaging/pep517_backend/_backend.py
index e9bb8097c9..ce97cfab65 100644
--- a/packaging/pep517_backend/_backend.py
+++ b/packaging/pep517_backend/_backend.py
@@ -118,7 +118,7 @@ def build_sdist( # noqa: WPS210, WPS430
original_src_dir = Path.cwd().resolve()
with _run_in_temporary_directory() as tmp_dir:
tmp_src_dir = Path(tmp_dir) / 'src'
- copytree(original_src_dir, tmp_src_dir)
+ copytree(original_src_dir, tmp_src_dir, symlinks=True)
os.chdir(tmp_src_dir)
if build_manpages_requested: