diff options
| author | Michał Górny <mgorny@gentoo.org> | 2025-09-21 03:30:06 +0200 |
|---|---|---|
| committer | Michał Górny <mgorny@gentoo.org> | 2025-09-21 03:30:06 +0200 |
| commit | a9576f0ae0dbc10b195d30dcb4486c38ad36adc5 (patch) | |
| tree | 4dd3d1f4b1c692e5b761b8dae8d71481facb102d /dev-python | |
| parent | 2b936e5057569c4e5f2a7c74cbad39aaa49c95ce (diff) | |
| download | gentoo-a9576f0ae0dbc10b195d30dcb4486c38ad36adc5.tar.gz gentoo-a9576f0ae0dbc10b195d30dcb4486c38ad36adc5.tar.bz2 gentoo-a9576f0ae0dbc10b195d30dcb4486c38ad36adc5.zip | |
dev-python/pydevd: Bump to 3.4.1
Signed-off-by: Michał Górny <mgorny@gentoo.org>
Diffstat (limited to 'dev-python')
| -rw-r--r-- | dev-python/pydevd/Manifest | 1 | ||||
| -rw-r--r-- | dev-python/pydevd/pydevd-3.4.1.ebuild | 142 |
2 files changed, 143 insertions, 0 deletions
diff --git a/dev-python/pydevd/Manifest b/dev-python/pydevd/Manifest index ea19d9bc58f8..745b00b67cdb 100644 --- a/dev-python/pydevd/Manifest +++ b/dev-python/pydevd/Manifest @@ -1 +1,2 @@ DIST PyDev.Debugger-pydev_debugger_3_3_0.gh.tar.gz 4283838 BLAKE2B c035f99e9e6988dd753fcb23aeb7aad53dedd290b60ee3bef89deebe784b7b951d119a8c4ff87ea9d83ffe8134680ab8db8296c298556c35daef89ec417b4664 SHA512 99bfb67470d9d200ba4a0de929c0c4ae053d836b7c6c034173e9d51a2428e98cc6052612ad11f8d66c375da0b7ab8f18b627441b174f71924e851f41f4bd5a21 +DIST PyDev.Debugger-pydev_debugger_3_4_1.gh.tar.gz 4308315 BLAKE2B 26d4611aa5af866a2deddd3f7bacd65f9e83a6ec9e1136243929d59953ef3fe0bec61fb66370f9a22312057bb3761fe89baaa176f15a9b0f02b91404cb4046b2 SHA512 3b86d1a33bce47286308dde695420b05b904bfc879d11cb0fb96dcf337e49a8c3255b2e9a651e62113cf0e3de8b3ae86db083a4e20413e81055312c4fbea6e6c diff --git a/dev-python/pydevd/pydevd-3.4.1.ebuild b/dev-python/pydevd/pydevd-3.4.1.ebuild new file mode 100644 index 000000000000..46dfdc498439 --- /dev/null +++ b/dev-python/pydevd/pydevd-3.4.1.ebuild @@ -0,0 +1,142 @@ +# Copyright 1999-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +DISTUTILS_EXT=1 +DISTUTILS_USE_PEP517=setuptools +PYTHON_COMPAT=( python3_{11..13} ) + +inherit distutils-r1 toolchain-funcs + +TAG="pydev_debugger_${PV//./_}" +MY_P="PyDev.Debugger-${TAG}" +DESCRIPTION="PyDev.Debugger (used in PyDev, PyCharm and VSCode Python)" +HOMEPAGE=" + https://github.com/fabioz/PyDev.Debugger/ + https://pypi.org/project/pydevd/ +" +SRC_URI=" + https://github.com/fabioz/PyDev.Debugger/archive/${TAG}.tar.gz + -> ${MY_P}.gh.tar.gz +" +S=${WORKDIR}/${MY_P} + +LICENSE="EPL-1.0" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86" + +RDEPEND=" + dev-debug/gdb +" +BDEPEND=" + test? ( + dev-python/numpy[${PYTHON_USEDEP}] + dev-python/psutil[${PYTHON_USEDEP}] + dev-python/untangle[${PYTHON_USEDEP}] + ) +" + +EPYTEST_PLUGINS=() +EPYTEST_RERUNS=5 +EPYTEST_XDIST=1 +distutils_enable_tests pytest + +python_prepare_all() { + distutils-r1_python_prepare_all + + # Drop -O3 and -flto compiler args + # Make extension build failures fatal + sed -i \ + -e 's/extra_link_args = extra_compile_args\[\:\]/pass/g' \ + -e '/extra_compile_args/d' \ + -e '/except/a\ raise' \ + setup.py || die + + # Disable tests incompatible with new package versions + sed -e '/TEST_\(DJANGO\|FLASK\)/s:True:False:' \ + -i tests_python/debug_constants.py || die + + # Clean up some prebuilt files + rm -r third_party || die + cd pydevd_attach_to_process || die + + # Remove these Windows files + rm attach_{amd64,x86}.dll || die + rm inject_dll_{amd64,x86}.exe || die + rm run_code_on_dllmain_{amd64,x86}.dll || die + rm -r windows winappdbg || die + + # Remove these MacOS files + rm attach_x86_64.dylib || die + + # Remove these prebuilt linux files + rm attach_linux_{amd64,x86}.so || die + + cd linux_and_mac || die + rm compile_mac.sh || die +} + +src_compile() { + pushd pydevd_attach_to_process/linux_and_mac || die + # recompile removed file (extracted from compile_linux.sh) + $(tc-getBUILD_CXX) ${CXXFLAGS} ${CPPFLAGS} \ + -o "../attach_linux_${ARCH}.so" \ + ${LDFLAGS} -nostartfiles attach.cpp -ldl || die + popd || die + + distutils-r1_src_compile + + # C extensions + rm -r _pydevd* || die +} + +python_test() { + local EPYTEST_DESELECT=( + # TODO + # NB: upstream seems to run tests via runfiles.py but that script + # is a horror and it seems broken for us anyway + tests_python/test_debugger.py::test_attach_to_pid_halted + tests_python/test_debugger.py::test_attach_to_pid_no_threads + 'tests_python/test_debugger.py::test_path_translation[False]' + tests_python/test_debugger_json.py::test_attach_to_pid + tests_python/test_debugger_json.py::test_case_sys_exit_multiple_exception_attach + tests_python/test_debugger_json.py::test_evaluate_exception_trace + tests_python/test_debugger_json.py::test_gui_event_loop_custom + tests_python/test_debugger_json.py::test_path_translation_and_source_reference + tests_python/test_utilities.py::test_tracing_basic + tests_python/test_utilities.py::test_tracing_other_threads + # incompatible with xdist + tests_python/test_utilities.py::test_find_main_thread_id + tests_python/test_utilities.py::test_is_main_thread + # numpy-2? + tests_python/test_debugger_json.py::test_evaluate_numpy + ) + + case ${EPYTHON} in + python3.11) + EPYTEST_DESELECT+=( + tests_python/test_debugger.py::test_frame_eval_limitations + tests_python/test_debugger.py::test_remote_debugger_threads + ) + ;; + python3.12) + EPYTEST_DESELECT+=( + # flaky + tests_python/test_debugger_json.py::test_step_next_step_in_multi_threads + ) + ;; + esac + + # this is only used to compare against getpid() to detect that xdist + # is being used + local -x PYDEV_MAIN_PID=1 + epytest +} + +python_install_all() { + distutils-r1_python_install_all + # Remove this duplicate that is installed directly to /usr/ + # These files are also correctly installed to the python site-packages dir + rm -r "${ED}/usr/pydevd_attach_to_process" || die +} |
