commit:     aeadd23f8c820482aace2c108539378f287cd72f
Author:     Michał Górny <mgorny <AT> gentoo <DOT> org>
AuthorDate: Thu Sep 11 09:23:50 2025 +0000
Commit:     Michał Górny <mgorny <AT> gentoo <DOT> org>
CommitDate: Thu Sep 11 13:09:23 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=aeadd23f

dev-python/ipython: Bump to 9.5.0

Signed-off-by: Michał Górny <mgorny <AT> gentoo.org>

 dev-python/ipython/Manifest                        |   1 +
 .../ipython/files/ipython-9.5.0-assert.patch       |  88 ++++++++++++
 dev-python/ipython/ipython-9.5.0.ebuild            | 155 +++++++++++++++++++++
 3 files changed, 244 insertions(+)

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 <[email protected]>
+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
+}

Reply via email to