summaryrefslogtreecommitdiff
diff options
authorMichał Górny <mgorny@gentoo.org>2025-09-11 11:23:50 +0200
committerMichał Górny <mgorny@gentoo.org>2025-09-11 15:09:23 +0200
commitaeadd23f8c820482aace2c108539378f287cd72f (patch)
tree614f1a5d96322263353722f7aa1ae70c6591c4f9
parentapp-text/ansifilter: Bump to 2.22 (diff)
downloadgentoo-aeadd23f8c820482aace2c108539378f287cd72f.tar.gz
gentoo-aeadd23f8c820482aace2c108539378f287cd72f.tar.bz2
gentoo-aeadd23f8c820482aace2c108539378f287cd72f.zip
dev-python/ipython: Bump to 9.5.0
Signed-off-by: Michał Górny <mgorny@gentoo.org>
-rw-r--r--dev-python/ipython/Manifest1
-rw-r--r--dev-python/ipython/files/ipython-9.5.0-assert.patch88
-rw-r--r--dev-python/ipython/ipython-9.5.0.ebuild155
3 files changed, 244 insertions, 0 deletions
diff --git a/dev-python/ipython/Manifest b/dev-python/ipython/Manifest
index 4a78da73332c..8a997ad12f03 100644
--- a/dev-python/ipython/Manifest
+++ b/dev-python/ipython/Manifest
@@ -1,3 +1,4 @@
DIST ipython-8.37.0.tar.gz 5606088 BLAKE2B 4cb3a6ae801fcbbf352eb8aaae11a7bc6911a76a816e1ce8845a6f3044fbb888cf49dc7c5a500305da47497ec2341a7abf6ad5fff863dd9175bf6eae2f03f7a8 SHA512 bde7b6962ca59688cb9f1032a2735df428dec41ec531b98488a5a35ef67c09a375973537c10bef7574ad112f3396b056f8a4f754b63712b72b0f9f20ab052623
DIST ipython-9.3.0.tar.gz 4426460 BLAKE2B d9d6ec38ab7ee2c4128869cd6fa0518c5df8ed3f3eb1db531099ff753b959a2eb1d872b5c782a017b2f559b460c0121cb951893c54f842cb936f08022eb32325 SHA512 21bd98e7f164bdbb799e0316c56620b0d086af943e28fa43f5d1f4c31064e496b01b47babcf0be4282d12d446362a7c0945a29580078279dc3038c66e8e75cf6
DIST ipython-9.4.0.tar.gz 4385338 BLAKE2B 20bf17c945ab2c727aa340a500e2f452dadd440ff809e5aea2ebaa0bd146a6bf2103f2435549a0f4b898690e6aceb15850fc2ba92bb9b94d8e084b1f13cb17a1 SHA512 8e0bd35effa6b5d6d17b7903ae708f1db753717b2271c79b6662fc508e003a7b3b510604ed340e6e89a8c84abf7c3718f785eb39d0914b653c47adc999a1d2f4
+DIST ipython-9.5.0.tar.gz 4389137 BLAKE2B c9d0cccac9a7a0711425e74ecfde8bdb7789d8289d58d86dccaddd06c1012f4c5f94aedf444f8b6c313d04f7617c5d9adc191d7b25426d8f70622435207acbe5 SHA512 fddf470a03ed94dfe2e193dce0d7228bd1143706ce1cd189348d6778eb7d1650a1589e49bc050214337b5fd9c30e7f1d91f871bc0d4a0a04d1a227747a81a132
diff --git a/dev-python/ipython/files/ipython-9.5.0-assert.patch b/dev-python/ipython/files/ipython-9.5.0-assert.patch
new file mode 100644
index 000000000000..dc5f40207f97
--- /dev/null
+++ b/dev-python/ipython/files/ipython-9.5.0-assert.patch
@@ -0,0 +1,88 @@
+From 9e1f15f0b7e354daff8cb8ce9eba2b4f11d48c71 Mon Sep 17 00:00:00 2001
+From: Stephen Macke <stephen.macke@databricks.com>
+Date: Sat, 30 Aug 2025 21:35:56 -0700
+Subject: [PATCH] deduperreload should patch NULL for empty closure rather than
+ None
+
+---
+ .../deduperreload/deduperreload_patching.py | 34 +++++++++----------
+ 1 file changed, 17 insertions(+), 17 deletions(-)
+
+diff --git a/IPython/extensions/deduperreload/deduperreload_patching.py b/IPython/extensions/deduperreload/deduperreload_patching.py
+index a8b53e68e78..36ee103a8e4 100644
+--- a/IPython/extensions/deduperreload/deduperreload_patching.py
++++ b/IPython/extensions/deduperreload/deduperreload_patching.py
+@@ -4,6 +4,7 @@
+ from typing import Any
+
+ NOT_FOUND: object = object()
++NULL: object = object()
+ _MAX_FIELD_SEARCH_OFFSET = 50
+
+ if sys.maxsize > 2**32:
+@@ -55,12 +56,17 @@ def try_write_readonly_attr(
+ if offset == -1:
+ return
+ obj_addr = ctypes.c_void_p.from_buffer(ctypes.py_object(obj)).value
+- new_value_addr = ctypes.c_void_p.from_buffer(ctypes.py_object(new_value)).value
++ if new_value is NULL:
++ new_value_addr: int | None = 0
++ else:
++ new_value_addr = ctypes.c_void_p.from_buffer(
++ ctypes.py_object(new_value)
++ ).value
+ if obj_addr is None or new_value_addr is None:
+ return
+ if prev_value is not None:
+ ctypes.pythonapi.Py_DecRef(ctypes.py_object(prev_value))
+- if new_value is not None:
++ if new_value not in (None, NULL):
+ ctypes.pythonapi.Py_IncRef(ctypes.py_object(new_value))
+ ctypes.cast(
+ obj_addr + WORD_N_BYTES * offset, ctypes.POINTER(WORD_TYPE)
+@@ -108,12 +114,10 @@ def try_patch_attr(
+ def patch_function(
+ cls, to_patch_to: Any, to_patch_from: Any, is_method: bool
+ ) -> None:
+- new_freevars = []
+ new_closure = []
+ for freevar, closure_val in zip(
+ to_patch_from.__code__.co_freevars or [], to_patch_from.__closure__ or []
+ ):
+- new_freevars.append(freevar)
+ if (
+ callable(closure_val.cell_contents)
+ and freevar in to_patch_to.__code__.co_freevars
+@@ -125,23 +129,19 @@ def patch_function(
+ )
+ else:
+ new_closure.append(closure_val)
+- code_with_new_freevars = to_patch_from.__code__.replace(
+- co_freevars=tuple(new_freevars)
+- )
+ # lambdas may complain if there is more than one freevar
+- cls.try_patch_attr(
+- to_patch_to, code_with_new_freevars, "__code__", new_is_value=True
+- )
++ cls.try_patch_attr(to_patch_to, to_patch_from, "__code__")
+ offset = -1
+ if to_patch_to.__closure__ is None and to_patch_from.__closure__ is not None:
+ offset = cls.infer_field_offset(to_patch_from, "__closure__")
+- cls.try_patch_readonly_attr(
+- to_patch_to,
+- tuple(new_closure) or None,
+- "__closure__",
+- new_is_value=True,
+- offset=offset,
+- )
++ if to_patch_to.__closure__ is not None or to_patch_from.__closure__ is not None:
++ cls.try_patch_readonly_attr(
++ to_patch_to,
++ tuple(new_closure) or NULL,
++ "__closure__",
++ new_is_value=True,
++ offset=offset,
++ )
+ for attr in ("__defaults__", "__kwdefaults__", "__doc__", "__dict__"):
+ cls.try_patch_attr(to_patch_to, to_patch_from, attr)
+ if is_method:
diff --git a/dev-python/ipython/ipython-9.5.0.ebuild b/dev-python/ipython/ipython-9.5.0.ebuild
new file mode 100644
index 000000000000..0794db5af8e5
--- /dev/null
+++ b/dev-python/ipython/ipython-9.5.0.ebuild
@@ -0,0 +1,155 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+DISTUTILS_USE_PEP517=standalone
+PYTHON_COMPAT=( pypy3_11 python3_{11..13} )
+PYTHON_REQ_USE='readline(+),sqlite,threads(+)'
+
+inherit distutils-r1 optfeature pypi virtualx
+
+DESCRIPTION="Advanced interactive shell for Python"
+HOMEPAGE="
+ https://ipython.org/
+ https://github.com/ipython/ipython/
+ https://pypi.org/project/ipython/
+"
+
+LICENSE="BSD"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
+IUSE="examples gui notebook nbconvert +smp test"
+RESTRICT="!test? ( test )"
+
+RDEPEND="
+ dev-python/decorator[${PYTHON_USEDEP}]
+ dev-python/ipython-pygments-lexers[${PYTHON_USEDEP}]
+ >=dev-python/jedi-0.16[${PYTHON_USEDEP}]
+ dev-python/matplotlib-inline[${PYTHON_USEDEP}]
+ >=dev-python/pexpect-4.3[${PYTHON_USEDEP}]
+ >=dev-python/prompt-toolkit-3.0.41[${PYTHON_USEDEP}]
+ <dev-python/prompt-toolkit-3.1[${PYTHON_USEDEP}]
+ >=dev-python/pygments-2.4.0[${PYTHON_USEDEP}]
+ dev-python/stack-data[${PYTHON_USEDEP}]
+ >=dev-python/traitlets-5.13.0[${PYTHON_USEDEP}]
+ $(python_gen_cond_dep '
+ dev-python/typing-extensions[${PYTHON_USEDEP}]
+ ' 3.11)
+"
+
+BDEPEND="
+ dev-python/setuptools[${PYTHON_USEDEP}]
+ test? (
+ app-text/dvipng[truetype]
+ >=dev-python/ipykernel-5.1.0[${PYTHON_USEDEP}]
+ >=dev-python/matplotlib-3.9[${PYTHON_USEDEP}]
+ dev-python/nbformat[${PYTHON_USEDEP}]
+ >=dev-python/numpy-1.23[${PYTHON_USEDEP}]
+ dev-python/matplotlib-inline[${PYTHON_USEDEP}]
+ dev-python/packaging[${PYTHON_USEDEP}]
+ dev-python/pickleshare[${PYTHON_USEDEP}]
+ dev-python/requests[${PYTHON_USEDEP}]
+ dev-python/testpath[${PYTHON_USEDEP}]
+ )
+"
+
+EPYTEST_PLUGINS=( pytest-asyncio )
+distutils_enable_tests pytest
+
+RDEPEND+="
+ nbconvert? (
+ dev-python/nbconvert[${PYTHON_USEDEP}]
+ )
+"
+PDEPEND="
+ $(python_gen_cond_dep '
+ gui? ( dev-python/qtconsole[${PYTHON_USEDEP}] )
+ ' 'python*')
+ $(python_gen_cond_dep '
+ notebook? (
+ dev-python/notebook[${PYTHON_USEDEP}]
+ dev-python/ipywidgets[${PYTHON_USEDEP}]
+ dev-python/widgetsnbextension[${PYTHON_USEDEP}]
+ )
+ ' 3.{11..13})
+ smp? (
+ >=dev-python/ipykernel-5.1.0[${PYTHON_USEDEP}]
+ >=dev-python/ipyparallel-6.2.3[${PYTHON_USEDEP}]
+ )
+"
+
+python_prepare_all() {
+ local PATCHES=(
+ # https://github.com/ipython/ipython/pull/14978
+ "${FILESDIR}/${P}-assert.patch"
+ )
+
+ # Rename the test directory to reduce sys.path pollution
+ # https://github.com/ipython/ipython/issues/12892
+ mv IPython/extensions/{,ipython_}tests || die
+
+ distutils-r1_python_prepare_all
+}
+
+src_test() {
+ virtx distutils-r1_src_test
+}
+
+python_test() {
+ local -x IPYTHON_TESTING_TIMEOUT_SCALE=20
+ local EPYTEST_DESELECT=()
+
+ case ${EPYTHON} in
+ pypy3*)
+ EPYTEST_DESELECT+=(
+ # https://github.com/ipython/ipython/issues/14244
+ tests/test_display.py::TestAudioDataWithoutNumpy
+ # minor exception message mismatch
+ # https://github.com/ipython/ipython/issues/14976
+ tests/test_ultratb.py::ExceptionMessagePreferenceTest::test_jsondecodeerror_message
+ )
+ ;;
+ esac
+
+ # nonfatal implied by virtx
+ nonfatal epytest || die "Tests failed on ${EPYTHON}"
+}
+
+python_install() {
+ distutils-r1_python_install
+
+ # Create ipythonX.Y symlinks.
+ # TODO:
+ # 1. do we want them for pypy?
+ # 2. handle it in the eclass instead (use _python_ln_rel).
+ # With pypy not an option the dosym becomes unconditional
+ # TODO2: figure out what TODO meant.
+ dosym ../lib/python-exec/${EPYTHON}/ipython \
+ /usr/bin/ipython${EPYTHON#python}
+}
+
+python_install_all() {
+ distutils-r1_python_install_all
+
+ if use examples; then
+ dodoc -r examples
+ docompress -x /usr/share/doc/${PF}/examples
+ fi
+}
+
+pkg_postinst() {
+ optfeature "code formatting" dev-python/black
+ optfeature "sympyprinting" dev-python/sympy
+ optfeature "cythonmagic" dev-python/cython
+ optfeature "%lprun magic command" dev-python/line-profiler
+ optfeature "%matplotlib magic command" dev-python/matplotlib-inline
+
+ if use nbconvert; then
+ if ! has_version virtual/pandoc ; then
+ einfo "Node.js will be used to convert notebooks to other formats"
+ einfo "like HTML. Support for that is still experimental. If you"
+ einfo "encounter any problems, please use app-text/pandoc instead."
+ fi
+ fi
+}