I had to hack python-2.7 ebuild to pass --with-pydebug to get hopefully better stacktraces. Would be nice if USE=debug could be used for this.
--with-pydebug changes C ABI of Python and requires rebuilding of all packages providing Python extension modules (*.so) or embedding Python interpreter.
Running python-updater is the usual requirement but your are right, I also needed to recompile chromium but even gdb. Don't know if that is a a bug or feature but python-related apps now print (probably on STDERR) some numbers in square brackets. An example of the behavior during gdb reinstall: >>> Completed installing gdb-7.6 into /mnt/1TB/var/tmp/portage/sys-devel/gdb-7.6/image/ [26176 refs] [26176 refs] [45091 refs] ecompressdir: bzip2 -9 /usr/share/info ecompressdir: bzip2 -9 /usr/share/man * QA Notice: The following shared libraries lack a SONAME * /usr/lib64/libinproctrace.so [18329 refs] [45099 refs] >>> Installing (1 of 1) sys-devel/gdb-7.6 [26176 refs] [45091 refs] [45099 refs] Looks I managed to to do the transition to pydebug-enabled system and Gentoo is the easiest distribution to do that for me. Other than tyhat I don't see a problem with my system so far.
(In reply to Martin Mokrejš from comment #2) > some numbers in square brackets http://docs.python.org/3.4/c-api/intro.html#debugging-builds "Upon exit, all existing references are printed. (In interactive mode this happens after every statement run by the interpreter.)"
(In reply to Martin Mokrejš from comment #2) > Running python-updater is the usual requirement but your are right, I also > needed to recompile chromium but even gdb. Nope, we're killing python-updater. It's broken already, and nobody bothers fixing it. > Looks I managed to to do the transition to pydebug-enabled system and Gentoo > is the easiest distribution to do that for me. Other than tyhat I don't see > a problem with my system so far. If we really want this, we can add USE=debug bug permanently masked. Otherwise, you can use EXTRA_ECONF to append it via package.env.
(In reply to Michał Górny from comment #4) > (In reply to Martin Mokrejš from comment #2) > > Running python-updater is the usual requirement but your are right, I also > > needed to recompile chromium but even gdb. > > Nope, we're killing python-updater. It's broken already, and nobody bothers > fixing it. This is a bit off-topic but please make python-updater to print a fat warning then explaining what other tool is one supposed to use. > > > Looks I managed to to do the transition to pydebug-enabled system and Gentoo > > is the easiest distribution to do that for me. Other than that I don't see > > a problem with my system so far. > > If we really want this, we can add USE=debug bug permanently masked. > Otherwise, you can use EXTRA_ECONF to append it via package.env. Don't really understand what you mean here. You mean EXTRA_ECONF='--with-pydebug' emerge python ? What is the point of obeying a USE flag? People are used to use them, USE=debug exists so why to invent something else? Especially as Gentoo want USE=debug to only enable application-specific debugging whereas average user anticipates that it would automagically inject -gg3 or -ggdb to compiler. So, in this particular case, "USE=debug emerge python" should really end up in "--with-pydebug" passed to configure. It is exactly for this kind of purpose.
(In reply to Martin Mokrejš from comment #5) > This is a bit off-topic but please make python-updater to print a fat > warning then explaining what other tool is one supposed to use. > Once we have everything migrated to PYTHON_TARGETS, you won't need to run python-updater; emerge --changed-use would be the replacement. > Don't really understand what you mean here. You mean > EXTRA_ECONF='--with-pydebug' emerge python > ? > > What is the point of obeying a USE flag? People are used to use them, > USE=debug exists so why to invent something else? Especially as Gentoo want > USE=debug to only enable application-specific debugging whereas average user > anticipates that it would automagically inject -gg3 or -ggdb to compiler. > So, in this particular case, "USE=debug emerge python" should really end up > in "--with-pydebug" passed to configure. It is exactly for this kind of > purpose. It's a feature that very few people would actually want to enable, and adding/maintaining use flags takes some effort. So the cost to benefit ratio is not very good. We are not saying "no" to the use flag, but we probably aren't going to implement it right away. EXTRA_ECONF is a workaround so that you can enable this functionality without having to modify the ebuild. You may utilize it like this: mkdir -p /etc/portage/env echo 'EXTRA_ECONF="--with-pydebug"' > /etc/portage/env/pydebug.conf echo dev-lang/python pydebug.conf >> /etc/portage/package.env
(In reply to Martin Mokrejš from comment #5) > > > Looks I managed to to do the transition to pydebug-enabled system and Gentoo > > > is the easiest distribution to do that for me. Other than that I don't see > > > a problem with my system so far. > > > > If we really want this, we can add USE=debug bug permanently masked. > > Otherwise, you can use EXTRA_ECONF to append it via package.env. > > Don't really understand what you mean here. You mean > EXTRA_ECONF='--with-pydebug' emerge python > ? > > What is the point of obeying a USE flag? People are used to use them, > USE=debug exists so why to invent something else? Especially as Gentoo want > USE=debug to only enable application-specific debugging whereas average user > anticipates that it would automagically inject -gg3 or -ggdb to compiler. > So, in this particular case, "USE=debug emerge python" should really end up > in "--with-pydebug" passed to configure. It is exactly for this kind of > purpose. USE=debug is for debug that does not interfere with normal behavior. If something changes Python ABI and prints additional output when it's not expected by applications and unlikely expected by users it's a large change. It's not like typical USE=debug that does some assertions (that wouldn't fail and therefore cause behavior changes in a perfect world) and/or debug output in specific channels (e.g. logs). Here USE=debug changes a lot and we don't support that. Giving a USE flag would suggest otherwise.
Created attachment 866718 [details] build.log (In reply to Mike Gilbert from comment #6) > mkdir -p /etc/portage/env > echo 'EXTRA_ECONF="--with-pydebug"' > /etc/portage/env/pydebug.conf > echo dev-lang/python pydebug.conf >> /etc/portage/package.env It doesn't compile: rm: cannot remove '/var/tmp/portage/dev-lang/python-3.11.4/image/usr/lib64/libpython3.so': No such file or directory
I'm going to close this given: commit 4c6957bd00ba63468d93f40982d77a378858569d Author: Sam James <sam@gentoo.org> Date: Fri May 26 08:48:29 2023 +0100 dev-lang/python: add USE=debug to control assertions Note that we don't do pydebug for this as it forces optimisations to be disabled (-O0, not just some). For newer Pythons, fwiw, pydebug is ABI compatible with release pythons, but still not worth it. Signed-off-by: Sam James <sam@gentoo.org>