[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[bug#32260] [PATCH 20/21] gnu: gdb: Fix build with Python >= 3.7.
From: |
Marius Bakke |
Subject: |
[bug#32260] [PATCH 20/21] gnu: gdb: Fix build with Python >= 3.7. |
Date: |
Tue, 24 Jul 2018 14:36:03 +0200 |
* gnu/packages/patches/gdb-python-3.7.patch: New file.
* gnu/local.mk (dist_patch_DATA): Register it.
* gnu/packages/gdb.scm (gdb)[source](patches): New field.
---
gnu/local.mk | 1 +
gnu/packages/gdb.scm | 1 +
gnu/packages/patches/gdb-python-3.7.patch | 52 +++++++++++++++++++++++
3 files changed, 54 insertions(+)
create mode 100644 gnu/packages/patches/gdb-python-3.7.patch
diff --git a/gnu/local.mk b/gnu/local.mk
index 16521e8e0..eb3764410 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -711,6 +711,7 @@ dist_patch_DATA =
\
%D%/packages/patches/gd-CVE-2018-5711.patch \
%D%/packages/patches/gd-fix-tests-on-i686.patch \
%D%/packages/patches/gd-freetype-test-failure.patch \
+ %D%/packages/patches/gdb-python-3.7.patch \
%D%/packages/patches/gemma-intel-compat.patch \
%D%/packages/patches/geoclue-config.patch \
%D%/packages/patches/ghc-8.0-fall-back-to-madv_dontneed.patch \
diff --git a/gnu/packages/gdb.scm b/gnu/packages/gdb.scm
index 36ccb79d6..4c47cc585 100644
--- a/gnu/packages/gdb.scm
+++ b/gnu/packages/gdb.scm
@@ -42,6 +42,7 @@
(method url-fetch)
(uri (string-append "mirror://gnu/gdb/gdb-"
version ".tar.xz"))
+ (patches (search-patches "gdb-python-3.7.patch"))
(sha256
(base32
"0d2bpqk58fqlx21rbnk8mbcjlggzc9kb5sjirrfrrrjq70ka0qdg"))))
diff --git a/gnu/packages/patches/gdb-python-3.7.patch
b/gnu/packages/patches/gdb-python-3.7.patch
new file mode 100644
index 000000000..c51442c8b
--- /dev/null
+++ b/gnu/packages/patches/gdb-python-3.7.patch
@@ -0,0 +1,52 @@
+Fix build failure with Python 3.7 and newer.
+
+Taken from this upstream commit, sans ChangeLog update:
+
+https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;a=commitdiff;h=aeab512851bf6ed623d1c6c4305b6ce05e51a10c
+
+diff --git a/gdb/python/python.c b/gdb/python/python.c
+index 1805c90..20fc674 100644
+--- a/gdb/python/python.c
++++ b/gdb/python/python.c
+@@ -1667,6 +1667,17 @@ finalize_python (void *ignore)
+ restore_active_ext_lang (previous_active);
+ }
+
++#ifdef IS_PY3K
++/* This is called via the PyImport_AppendInittab mechanism called
++ during initialization, to make the built-in _gdb module known to
++ Python. */
++PyMODINIT_FUNC
++init__gdb_module (void)
++{
++ return PyModule_Create (&python_GdbModuleDef);
++}
++#endif
++
+ static bool
+ do_start_initialization ()
+ {
+@@ -1707,6 +1718,9 @@ do_start_initialization ()
+ remain alive for the duration of the program's execution, so
+ it is not freed after this call. */
+ Py_SetProgramName (progname_copy);
++
++ /* Define _gdb as a built-in module. */
++ PyImport_AppendInittab ("_gdb", init__gdb_module);
+ #else
+ Py_SetProgramName (progname.release ());
+ #endif
+@@ -1716,9 +1730,7 @@ do_start_initialization ()
+ PyEval_InitThreads ();
+
+ #ifdef IS_PY3K
+- gdb_module = PyModule_Create (&python_GdbModuleDef);
+- /* Add _gdb module to the list of known built-in modules. */
+- _PyImport_FixupBuiltin (gdb_module, "_gdb");
++ gdb_module = PyImport_ImportModule ("_gdb");
+ #else
+ gdb_module = Py_InitModule ("_gdb", python_GdbMethods);
+ #endif
+--
+2.9.3
+
--
2.18.0
- [bug#32260] [PATCH 09/21] gnu: python-more-itertools: Update to 4.2.0., (continued)
- [bug#32260] [PATCH 09/21] gnu: python-more-itertools: Update to 4.2.0., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 07/21] gnu: python-py: Update home page., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 12/21] gnu: python-pytest-runner: Update to 4.2., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 02/21] gnu: python: Update to 3.7.0., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 05/21] gnu: python-py: Add missing dependency on setuptools-scm., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 14/21] gnu: python-hypothesis: Update to 3.66.6., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 15/21] gnu: python-pytest-cov: Update to 2.5.1., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 18/21] gnu: python-pytest-mock: Update to 1.10.0., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 11/21] gnu: python-setuptools: Update to 40.0.0., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 20/21] gnu: gdb: Fix build with Python >= 3.7.,
Marius Bakke <=
- [bug#32260] [PATCH 01/21] gnu: python: Remove outdated comment and phases., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 08/21] gnu: python-pyflakes: Update to 2.0.0., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 17/21] gnu: python-pytest: Update to 3.6.3., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 10/21] gnu: python-pycodestyle: Update to 2.4.0., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 13/21] gnu: python-flake8: Update to 3.5.0., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 16/21] gnu: Add python-invoke., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 19/21] gnu: docbook-xsl: Delete bundled jars., Marius Bakke, 2018/07/24
- [bug#32260] [PATCH 21/21] gnu: python-fonttools: Update to 3.28.0., Marius Bakke, 2018/07/24
- bug#32260: [PATCH 00/21] Python updates, Marius Bakke, 2018/07/28