summaryrefslogtreecommitdiff
path: root/src/virtualenv/create/via_global_ref
diff options
context:
space:
mode:
authorTracey Spicer <78386000+tmspicer@users.noreply.github.com>2021-12-31 02:55:34 -0500
committerGitHub <noreply@github.com>2021-12-31 07:55:34 +0000
commitf7ababdf0be4db3625444bbb20fa268a3885e645 (patch)
treef700febdf1c25709edfec76f44628b3630f3b7ca /src/virtualenv/create/via_global_ref
parent61c065ba7731b65bdc15af7900aa530963695868 (diff)
downloadvirtualenv-f7ababdf0be4db3625444bbb20fa268a3885e645.tar.gz
Sign the python2 exe on Darwin arm64 (#2233)
Co-authored-by: Bernát Gábor <gaborjbernat@gmail.com>
Diffstat (limited to 'src/virtualenv/create/via_global_ref')
-rw-r--r--src/virtualenv/create/via_global_ref/builtin/cpython/mac_os.py38
1 files changed, 34 insertions, 4 deletions
diff --git a/src/virtualenv/create/via_global_ref/builtin/cpython/mac_os.py b/src/virtualenv/create/via_global_ref/builtin/cpython/mac_os.py
index c6343e7..4f7f646 100644
--- a/src/virtualenv/create/via_global_ref/builtin/cpython/mac_os.py
+++ b/src/virtualenv/create/via_global_ref/builtin/cpython/mac_os.py
@@ -69,6 +69,10 @@ class CPythonmacOsFramework(CPython):
class CPython2macOsFramework(CPythonmacOsFramework, CPython2PosixBase):
@classmethod
+ def can_create(cls, interpreter):
+ return not IS_MAC_ARM64 and super(CPython2macOsFramework, cls).can_describe(interpreter)
+
+ @classmethod
def image_ref(cls, interpreter):
return Path(interpreter.prefix) / "Python"
@@ -103,12 +107,38 @@ class CPython2macOsFramework(CPythonmacOsFramework, CPython2PosixBase):
)
return result
+
+class CPython2macOsArmFramework(CPython2macOsFramework, CPythonmacOsFramework, CPython2PosixBase):
@classmethod
def can_create(cls, interpreter):
- if IS_MAC_ARM64:
- return False
- else:
- return super(CPythonmacOsFramework, cls).can_create(interpreter)
+ return IS_MAC_ARM64 and super(CPythonmacOsFramework, cls).can_describe(interpreter)
+
+ def create(self):
+ super(CPython2macOsFramework, self).create()
+ self.fix_signature()
+
+ def fix_signature(self):
+ """
+ On Apple M1 machines (arm64 chips), rewriting the python executable invalidates its signature.
+ In python2 this results in a unusable python exe which just dies.
+ As a temporary workaround we can codesign the python exe during the creation process.
+ """
+ exe = self.exe
+ try:
+ logging.debug("Changing signature of copied python exe %s", exe)
+ bak_dir = exe.parent / "bk"
+ # Reset the signing on Darwin since the exe has been modified.
+ # Note codesign fails on the original exe, it needs to be copied and moved back.
+ bak_dir.mkdir(parents=True, exist_ok=True)
+ subprocess.check_call(["cp", exe, bak_dir])
+ subprocess.check_call(["mv", bak_dir / exe.name, exe])
+ bak_dir.unlink()
+ cmd = ["codesign", "-s", "-", "--preserve-metadata=identifier,entitlements,flags,runtime", "-f", exe]
+ logging.debug("Changing Signature: %s", cmd)
+ subprocess.check_call(cmd)
+ except Exception:
+ logging.fatal("Could not change MacOS code signing on copied python exe at %s", exe)
+ raise
class CPython3macOsFramework(CPythonmacOsFramework, CPython3, CPythonPosix):