[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
58/75: gnu: python: Make the build reproducible.
From: |
guix-commits |
Subject: |
58/75: gnu: python: Make the build reproducible. |
Date: |
Sun, 21 Jan 2024 13:21:49 -0500 (EST) |
apteryx pushed a commit to branch core-updates
in repository guix.
commit e84519a949a98ee57f039157087bd9bf97f0def4
Author: Tomas Volf <~@wolfsden.cz>
AuthorDate: Sat Jan 20 22:59:08 2024 -0500
gnu: python: Make the build reproducible.
While Python build was reproducible on a single machine, once multiple file
systems entered the picture, it was no longer true. The solution adopted by
the upstream (and Debian) was cherry-picked.
More info: <https://github.com/python/cpython/pull/8226>.
* gnu/packages/python.scm (python-3.10) [source]: Apply reproducibility
patch.
Signed-off-by: Maxim Cournoyer <maxim.cournoyer@gmail.com>
Modified-by: Maxim Cournoyer <maxim.cournoyer@gmail.com>
Change-Id: I0273dc0f8511a7acdcc2b462a26cc29a9756c801
---
gnu/local.mk | 1 +
.../patches/python-3-reproducible-build.patch | 30 ++++++++++++++++++++++
gnu/packages/python.scm | 1 +
3 files changed, 32 insertions(+)
diff --git a/gnu/local.mk b/gnu/local.mk
index deeba67ce9..6a6a2a1b11 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -1912,6 +1912,7 @@ dist_patch_DATA =
\
%D%/packages/patches/python-3-search-paths.patch \
%D%/packages/patches/python-3-fix-tests.patch \
%D%/packages/patches/python-3-hurd-configure.patch \
+ %D%/packages/patches/python-3-reproducible-build.patch \
%D%/packages/patches/python-aionotify-0.2.0-py3.8.patch \
%D%/packages/patches/python-argcomplete-1.11.1-fish31.patch \
%D%/packages/patches/python-cross-compile.patch \
diff --git a/gnu/packages/patches/python-3-reproducible-build.patch
b/gnu/packages/patches/python-3-reproducible-build.patch
new file mode 100644
index 0000000000..12bd8de7c2
--- /dev/null
+++ b/gnu/packages/patches/python-3-reproducible-build.patch
@@ -0,0 +1,30 @@
+From 6c8ea7c1dacd42f3ba00440231ec0e6b1a38300d Mon Sep 17 00:00:00 2001
+From: Inada Naoki <songofacandy@gmail.com>
+Date: Sat, 14 Jul 2018 00:46:11 +0900
+Subject: [PATCH] Use FLAG_REF always for interned strings
+
+---
+ Python/marshal.c | 9 +++++++--
+ 1 file changed, 7 insertions(+), 2 deletions(-)
+
+diff --git a/Python/marshal.c b/Python/marshal.c
+index 6d06266c6a8e2e..51db2e3b2e29a2 100644
+--- a/Python/marshal.c
++++ b/Python/marshal.c
+@@ -275,9 +275,14 @@ w_ref(PyObject *v, char *flag, WFILE *p)
+ if (p->version < 3 || p->hashtable == NULL)
+ return 0; /* not writing object references */
+
+- /* if it has only one reference, it definitely isn't shared */
+- if (Py_REFCNT(v) == 1)
++ /* If it has only one reference, it definitely isn't shared.
++ * But we use TYPE_REF always for interned string, to PYC file stable
++ * as possible.
++ */
++ if (Py_REFCNT(v) == 1 &&
++ !(PyUnicode_CheckExact(v) && PyUnicode_CHECK_INTERNED(v))) {
+ return 0;
++ }
+
+ entry = _Py_HASHTABLE_GET_ENTRY(p->hashtable, v);
+ if (entry != NULL) {
diff --git a/gnu/packages/python.scm b/gnu/packages/python.scm
index 51d5f598d7..e4a84609c8 100644
--- a/gnu/packages/python.scm
+++ b/gnu/packages/python.scm
@@ -433,6 +433,7 @@ data types.")
"python-3-deterministic-build-info.patch"
"python-3-fix-tests.patch"
"python-3-hurd-configure.patch"
+ "python-3-reproducible-build.patch"
"python-3-search-paths.patch"))
(sha256
(base32
- 22/75: gnu: font-fira-sans: Install license file., (continued)
- 22/75: gnu: font-fira-sans: Install license file., guix-commits, 2024/01/21
- 34/75: gnu: libgpg-error: Update to 1.46., guix-commits, 2024/01/21
- 43/75: build/gnu: Support compressing non-numeric man sections., guix-commits, 2024/01/21
- 28/75: gnu: font-culmus: Install all license files., guix-commits, 2024/01/21
- 30/75: gnu: font-dseg: Install license file., guix-commits, 2024/01/21
- 33/75: gnu: font-charter: Install license file., guix-commits, 2024/01/21
- 61/75: build/cargo-build-system: Support 16k page sizes on aarch64., guix-commits, 2024/01/21
- 13/75: gnu: inetutils: Convert to gexp., guix-commits, 2024/01/21
- 35/75: gnu: webrtc-audio-processing: Update to 1.0., guix-commits, 2024/01/21
- 45/75: gnu: dbm: Regenerate Autotools files., guix-commits, 2024/01/21
- 58/75: gnu: python: Make the build reproducible.,
guix-commits <=
- 65/75: gnu: patchelf: Update to 0.18.0., guix-commits, 2024/01/21
- 66/75: gnu: qpdf: Update to 11.8.0., guix-commits, 2024/01/21
- 51/75: gnu: findutils-boot0: Re-enable most tests., guix-commits, 2024/01/21
- 17/75: gnu: font-canada1500: Install license file., guix-commits, 2024/01/21
- 36/75: gnu: libxcomposite: Update to 0.4.6., guix-commits, 2024/01/21
- 38/75: gnu: transset: Update to 1.0.3., guix-commits, 2024/01/21
- 42/75: gnu: bluez: enable wiimote plugin., guix-commits, 2024/01/21
- 44/75: gnu: man-pages-posix: Remove redundant manpage compression., guix-commits, 2024/01/21
- 46/75: build-system/go: Honor #:parallel-build?., guix-commits, 2024/01/21
- 48/75: import: crate: Emit new-style package inputs., guix-commits, 2024/01/21