From f3f1b5d242a45e3189ae88d1b9445d48d39ea1e9 Mon Sep 17 00:00:00 2001 From: Jonathan Kliem Date: Sat, 21 May 2022 10:41:45 +0200 Subject: [PATCH 01/40] test new changes to pari --- build/pkgs/cypari/checksums.ini | 8 ++++---- build/pkgs/cypari/package-version.txt | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/build/pkgs/cypari/checksums.ini b/build/pkgs/cypari/checksums.ini index d81625b5867..78cc1004702 100644 --- a/build/pkgs/cypari/checksums.ini +++ b/build/pkgs/cypari/checksums.ini @@ -1,5 +1,5 @@ tarball=cypari2-VERSION.tar.gz -sha1=2a3039aa6bd690206cb58d4c39aef21e736eacf1 -md5=6267c0dace847160763dc1777a390c0a -cksum=3639046443 -upstream_url=https://pypi.io/packages/source/c/cypari2/cypari2-VERSION.tar.gz +sha1=ed20dccfd8ae1a734f5b01ee958ce884472e7b37 +md5=9e9a53be114a97748ff9b1bd4cd02bdf +cksum=1166572480 +upstream_url=https://github.com/kliem/cypari2/archive/refs/tags/vVERSION.tar.gz diff --git a/build/pkgs/cypari/package-version.txt b/build/pkgs/cypari/package-version.txt index eca07e4c1a8..a6eece0c361 100644 --- a/build/pkgs/cypari/package-version.txt +++ b/build/pkgs/cypari/package-version.txt @@ -1 +1 @@ -2.1.2 +2.1.3b1 From 481d7821509c1ccb55db68c458c90d9b3a66f2d2 Mon Sep 17 00:00:00 2001 From: Jonathan Kliem Date: Thu, 2 Jun 2022 14:46:29 +0200 Subject: [PATCH 02/40] test cypari update --- build/pkgs/cypari/checksums.ini | 6 +++--- build/pkgs/cypari/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/cypari/checksums.ini b/build/pkgs/cypari/checksums.ini index 78cc1004702..119b819d666 100644 --- a/build/pkgs/cypari/checksums.ini +++ b/build/pkgs/cypari/checksums.ini @@ -1,5 +1,5 @@ tarball=cypari2-VERSION.tar.gz -sha1=ed20dccfd8ae1a734f5b01ee958ce884472e7b37 -md5=9e9a53be114a97748ff9b1bd4cd02bdf -cksum=1166572480 +sha1=f39b7a2b4b91302264b3997edd022feb945df7bb +md5=080b7da24aad03d5664f007dfccf0022 +cksum=948153093 upstream_url=https://github.com/kliem/cypari2/archive/refs/tags/vVERSION.tar.gz diff --git a/build/pkgs/cypari/package-version.txt b/build/pkgs/cypari/package-version.txt index a6eece0c361..887948350c6 100644 --- a/build/pkgs/cypari/package-version.txt +++ b/build/pkgs/cypari/package-version.txt @@ -1 +1 @@ -2.1.3b1 +2.2.0a0 From 6387f576b15a43f3c96228cd85f5e5324c9e4edf Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Wed, 11 May 2022 19:55:28 -0700 Subject: [PATCH 03/40] build/pkgs/python3: Update to 3.11.0b1 --- build/pkgs/python3/checksums.ini | 8 ++++---- build/pkgs/python3/package-version.txt | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/build/pkgs/python3/checksums.ini b/build/pkgs/python3/checksums.ini index 47be56a5323..f1ca0beabd6 100644 --- a/build/pkgs/python3/checksums.ini +++ b/build/pkgs/python3/checksums.ini @@ -1,5 +1,5 @@ tarball=Python-VERSION.tar.xz -sha1=5cd4ef548b1649a9a4fd78f5b7c5a86acdbd5001 -md5=21e0b70d70fdd4756aafc4caa55cc17e -cksum=3680748226 -upstream_url=https://www.python.org/ftp/python/VERSION/Python-VERSION.tar.xz +sha1=50ca32bbbadbcb9c5878cc3342c5a6fd60b0bb54 +md5=9e0b8e46b67c53170549da7c3d874b15 +cksum=913325877 +upstream_url=https://www.python.org/ftp/python/3.11.0/Python-VERSION.tar.xz diff --git a/build/pkgs/python3/package-version.txt b/build/pkgs/python3/package-version.txt index 7d4ef04f654..b548e0ca8b6 100644 --- a/build/pkgs/python3/package-version.txt +++ b/build/pkgs/python3/package-version.txt @@ -1 +1 @@ -3.10.3 +3.11.0b1 From e0d0ad9b68d8c93db9bae4895d35f43502db54e3 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Wed, 11 May 2022 20:00:20 -0700 Subject: [PATCH 04/40] build/pkgs/python3/patches/cygwin-socket-tcpnodelay-21649.patch: Remove, upstreamed --- .../cygwin-socket-tcpnodelay-21649.patch | 36 ------------------- 1 file changed, 36 deletions(-) delete mode 100644 build/pkgs/python3/patches/cygwin-socket-tcpnodelay-21649.patch diff --git a/build/pkgs/python3/patches/cygwin-socket-tcpnodelay-21649.patch b/build/pkgs/python3/patches/cygwin-socket-tcpnodelay-21649.patch deleted file mode 100644 index 3769318fe74..00000000000 --- a/build/pkgs/python3/patches/cygwin-socket-tcpnodelay-21649.patch +++ /dev/null @@ -1,36 +0,0 @@ -From bf2b131976694d5f4fe182c4a48d2d90edf5f303 Mon Sep 17 00:00:00 2001 -From: Zackery Spytz -Date: Mon, 27 Jul 2020 19:22:14 -0600 -Subject: [PATCH] bpo-41374: Include netinet/tcp.h on Cygwin - -On Cygwin, constants like TCP_NODELAY are no longer provided by -sys/socket.h. ---- - .../next/Library/2020-07-27-19-21-05.bpo-41374.cd-kFL.rst | 2 ++ - Modules/socketmodule.h | 4 +--- - 2 files changed, 3 insertions(+), 3 deletions(-) - create mode 100644 Misc/NEWS.d/next/Library/2020-07-27-19-21-05.bpo-41374.cd-kFL.rst - -diff --git a/Misc/NEWS.d/next/Library/2020-07-27-19-21-05.bpo-41374.cd-kFL.rst b/Misc/NEWS.d/next/Library/2020-07-27-19-21-05.bpo-41374.cd-kFL.rst -new file mode 100644 -index 0000000000000..a5b2e042a3fae ---- /dev/null -+++ b/Misc/NEWS.d/next/Library/2020-07-27-19-21-05.bpo-41374.cd-kFL.rst -@@ -0,0 +1,2 @@ -+Ensure that ``socket.TCP_*`` constants are exposed on Cygwin 3.1.6 and -+greater. -diff --git a/Modules/socketmodule.h b/Modules/socketmodule.h -index ba2c9f5c31c3b..f565b8e1396ff 100644 ---- a/Modules/socketmodule.h -+++ b/Modules/socketmodule.h -@@ -8,9 +8,7 @@ - # include - # endif - # include --# if !defined(__CYGWIN__) --# include --# endif -+# include - - #else /* MS_WINDOWS */ - # include From 6e09d4daaefa28106d99bf534911f1ececc62385 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Sun, 10 Jul 2022 15:36:49 -0700 Subject: [PATCH 05/40] build/pkgs/python3: Update to 3.11.0b3 --- build/pkgs/python3/checksums.ini | 6 +++--- build/pkgs/python3/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/python3/checksums.ini b/build/pkgs/python3/checksums.ini index f1ca0beabd6..e7f2461af99 100644 --- a/build/pkgs/python3/checksums.ini +++ b/build/pkgs/python3/checksums.ini @@ -1,5 +1,5 @@ tarball=Python-VERSION.tar.xz -sha1=50ca32bbbadbcb9c5878cc3342c5a6fd60b0bb54 -md5=9e0b8e46b67c53170549da7c3d874b15 -cksum=913325877 +sha1=2c509348f7d845f0e7b9e2241294e28dedca059a +md5=d8ebc28f88e5e0c0215cf074537f0d48 +cksum=641843617 upstream_url=https://www.python.org/ftp/python/3.11.0/Python-VERSION.tar.xz diff --git a/build/pkgs/python3/package-version.txt b/build/pkgs/python3/package-version.txt index b548e0ca8b6..0f0d2ab1644 100644 --- a/build/pkgs/python3/package-version.txt +++ b/build/pkgs/python3/package-version.txt @@ -1 +1 @@ -3.11.0b1 +3.11.0b3 From d7923b778ec7fe4eb8b8ddf05dba2da1873ea92e Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Sun, 10 Jul 2022 16:15:20 -0700 Subject: [PATCH 06/40] build/pkgs/kiwisolver: Update to 1.4.3 --- build/pkgs/kiwisolver/checksums.ini | 6 +++--- build/pkgs/kiwisolver/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/kiwisolver/checksums.ini b/build/pkgs/kiwisolver/checksums.ini index fc15fadea23..3fc15248198 100644 --- a/build/pkgs/kiwisolver/checksums.ini +++ b/build/pkgs/kiwisolver/checksums.ini @@ -1,5 +1,5 @@ tarball=kiwisolver-VERSION.tar.gz -sha1=61811685031328a8a2a77f45593d8238432ce35e -md5=98d746f558685c6b6658cefc39be14df -cksum=1915059157 +sha1=157556602639eb6cc8546463f56feaa9023e3bcd +md5=73a4e57c33ded99dbe9a5cabca5be04b +cksum=3382585353 upstream_url=https://files.pythonhosted.org/packages/source/k/kiwisolver/kiwisolver-VERSION.tar.gz diff --git a/build/pkgs/kiwisolver/package-version.txt b/build/pkgs/kiwisolver/package-version.txt index 1892b926767..428b770e3e2 100644 --- a/build/pkgs/kiwisolver/package-version.txt +++ b/build/pkgs/kiwisolver/package-version.txt @@ -1 +1 @@ -1.3.2 +1.4.3 From b5ceaf09ce6fa433b2440728e27ecef8f9227604 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Sun, 10 Jul 2022 16:41:49 -0700 Subject: [PATCH 07/40] build/pkgs/cppy: Update to 1.2.1 --- build/pkgs/cppy/checksums.ini | 6 +++--- build/pkgs/cppy/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/cppy/checksums.ini b/build/pkgs/cppy/checksums.ini index 5c781671d43..613b3b3f5b8 100644 --- a/build/pkgs/cppy/checksums.ini +++ b/build/pkgs/cppy/checksums.ini @@ -1,5 +1,5 @@ tarball=cppy-VERSION.tar.gz -sha1=3af4f5f14ef1f9b49d7457e2fa5c241c721db29c -md5=2110891d75aa12551deebba1603428c6 -cksum=793876648 +sha1=c82ee7a4f38e302bfe4de2a695d2bdfefb69951f +md5=7c1f825c43dd66454440932a35b9969c +cksum=1879136901 upstream_url=https://files.pythonhosted.org/packages/source/c/cppy/cppy-VERSION.tar.gz diff --git a/build/pkgs/cppy/package-version.txt b/build/pkgs/cppy/package-version.txt index 9084fa2f716..6085e946503 100644 --- a/build/pkgs/cppy/package-version.txt +++ b/build/pkgs/cppy/package-version.txt @@ -1 +1 @@ -1.1.0 +1.2.1 From 7082f0edaf29597662ea07013cfeabfeef0f716f Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Mon, 25 Jul 2022 21:07:28 -0700 Subject: [PATCH 08/40] build/pkgs/python3: Update to 3.11.0b4 --- build/pkgs/python3/checksums.ini | 6 +++--- build/pkgs/python3/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/python3/checksums.ini b/build/pkgs/python3/checksums.ini index e7f2461af99..8991eed7422 100644 --- a/build/pkgs/python3/checksums.ini +++ b/build/pkgs/python3/checksums.ini @@ -1,5 +1,5 @@ tarball=Python-VERSION.tar.xz -sha1=2c509348f7d845f0e7b9e2241294e28dedca059a -md5=d8ebc28f88e5e0c0215cf074537f0d48 -cksum=641843617 +sha1=be15df829b2c908d4c8f5b83e13c5ff3016e87a8 +md5=aa663eaec1554e0979ed8b30afd6a7e9 +cksum=143783252 upstream_url=https://www.python.org/ftp/python/3.11.0/Python-VERSION.tar.xz diff --git a/build/pkgs/python3/package-version.txt b/build/pkgs/python3/package-version.txt index 0f0d2ab1644..d0a802f6913 100644 --- a/build/pkgs/python3/package-version.txt +++ b/build/pkgs/python3/package-version.txt @@ -1 +1 @@ -3.11.0b3 +3.11.0b4 From 74221f2b75f42f10117cbbdb2c040e24bb60382c Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 26 Jul 2022 17:09:36 -0700 Subject: [PATCH 09/40] build/pkgs/python3: Update to 3.11.0b5 --- build/pkgs/python3/checksums.ini | 6 +++--- build/pkgs/python3/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/python3/checksums.ini b/build/pkgs/python3/checksums.ini index 8991eed7422..eb966de3534 100644 --- a/build/pkgs/python3/checksums.ini +++ b/build/pkgs/python3/checksums.ini @@ -1,5 +1,5 @@ tarball=Python-VERSION.tar.xz -sha1=be15df829b2c908d4c8f5b83e13c5ff3016e87a8 -md5=aa663eaec1554e0979ed8b30afd6a7e9 -cksum=143783252 +sha1=5f350072c5b96f257734ea4a189e9fd84e9255fc +md5=ef72213a60146324699c48344b4ea31c +cksum=3612210553 upstream_url=https://www.python.org/ftp/python/3.11.0/Python-VERSION.tar.xz diff --git a/build/pkgs/python3/package-version.txt b/build/pkgs/python3/package-version.txt index d0a802f6913..58ee0cedeff 100644 --- a/build/pkgs/python3/package-version.txt +++ b/build/pkgs/python3/package-version.txt @@ -1 +1 @@ -3.11.0b4 +3.11.0b5 From 393d69528a6546b9b00273776f1bf895ad16aba7 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Mon, 8 Aug 2022 23:28:50 -0700 Subject: [PATCH 10/40] build/pkgs/python3: Update to 3.11.0rc1 --- build/pkgs/python3/checksums.ini | 6 +++--- build/pkgs/python3/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/python3/checksums.ini b/build/pkgs/python3/checksums.ini index eb966de3534..be7d7deb4cb 100644 --- a/build/pkgs/python3/checksums.ini +++ b/build/pkgs/python3/checksums.ini @@ -1,5 +1,5 @@ tarball=Python-VERSION.tar.xz -sha1=5f350072c5b96f257734ea4a189e9fd84e9255fc -md5=ef72213a60146324699c48344b4ea31c -cksum=3612210553 +sha1=f60ea46e5190eec13803ad0896a650aaba3d76e1 +md5=013eb698ab20c284e5b8373435add767 +cksum=267896025 upstream_url=https://www.python.org/ftp/python/3.11.0/Python-VERSION.tar.xz diff --git a/build/pkgs/python3/package-version.txt b/build/pkgs/python3/package-version.txt index 58ee0cedeff..ccd5b735148 100644 --- a/build/pkgs/python3/package-version.txt +++ b/build/pkgs/python3/package-version.txt @@ -1 +1 @@ -3.11.0b5 +3.11.0rc1 From a76a718c02f47257ed438a13e8d142582b1786c7 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Mon, 8 Aug 2022 23:49:25 -0700 Subject: [PATCH 11/40] Bump python_requires to >=3.8, <3.12 --- pkgs/sage-setup/setup.cfg | 2 +- pkgs/sagemath-categories/setup.cfg.m4 | 2 +- pkgs/sagemath-environment/setup.cfg.m4 | 2 +- pkgs/sagemath-objects/setup.cfg.m4 | 2 +- pkgs/sagemath-repl/setup.cfg.m4 | 2 +- src/setup.cfg.m4 | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/pkgs/sage-setup/setup.cfg b/pkgs/sage-setup/setup.cfg index 05f152ef60b..54b5b401aad 100644 --- a/pkgs/sage-setup/setup.cfg +++ b/pkgs/sage-setup/setup.cfg @@ -31,7 +31,7 @@ packages = sage_setup.autogen.interpreters.specs sage_setup.command -python_requires = >=3.8, <3.11 +python_requires = >=3.8, <3.12 install_requires = pkgconfig diff --git a/pkgs/sagemath-categories/setup.cfg.m4 b/pkgs/sagemath-categories/setup.cfg.m4 index 4ba67f86fdb..5f42a0d90fb 100644 --- a/pkgs/sagemath-categories/setup.cfg.m4 +++ b/pkgs/sagemath-categories/setup.cfg.m4 @@ -25,7 +25,7 @@ classifiers = Topic :: Scientific/Engineering :: Mathematics [options] -python_requires = >=3.8, <3.11 +python_requires = >=3.8, <3.12 install_requires = esyscmd(`sage-get-system-packages install-requires \ cython \ diff --git a/pkgs/sagemath-environment/setup.cfg.m4 b/pkgs/sagemath-environment/setup.cfg.m4 index c67043cb715..9c242890f89 100644 --- a/pkgs/sagemath-environment/setup.cfg.m4 +++ b/pkgs/sagemath-environment/setup.cfg.m4 @@ -25,7 +25,7 @@ classifiers = Topic :: Scientific/Engineering :: Mathematics [options] -python_requires = >=3.7, <3.11 +python_requires = >=3.8, <3.12 install_requires = esyscmd(`sage-get-system-packages install-requires \ | sed "2,\$s/^/ /;"')dnl diff --git a/pkgs/sagemath-objects/setup.cfg.m4 b/pkgs/sagemath-objects/setup.cfg.m4 index 00c65ca9f8a..fc432b51738 100644 --- a/pkgs/sagemath-objects/setup.cfg.m4 +++ b/pkgs/sagemath-objects/setup.cfg.m4 @@ -25,7 +25,7 @@ classifiers = Topic :: Scientific/Engineering :: Mathematics [options] -python_requires = >=3.8, <3.11 +python_requires = >=3.8, <3.12 install_requires = esyscmd(`sage-get-system-packages install-requires \ cython \ diff --git a/pkgs/sagemath-repl/setup.cfg.m4 b/pkgs/sagemath-repl/setup.cfg.m4 index f8757ee66cb..ebf3f9407d4 100644 --- a/pkgs/sagemath-repl/setup.cfg.m4 +++ b/pkgs/sagemath-repl/setup.cfg.m4 @@ -25,7 +25,7 @@ classifiers = Topic :: Scientific/Engineering :: Mathematics [options] -python_requires = >=3.7, <3.11 +python_requires = >=3.8, <3.12 install_requires = esyscmd(`sage-get-system-packages install-requires \ sagemath_objects \ diff --git a/src/setup.cfg.m4 b/src/setup.cfg.m4 index a69b69924c5..f95da191884 100644 --- a/src/setup.cfg.m4 +++ b/src/setup.cfg.m4 @@ -26,7 +26,7 @@ classifiers = Topic :: Scientific/Engineering :: Mathematics [options] -python_requires = >=3.8, <3.11 +python_requires = >=3.8, <3.12 install_requires = esyscmd(`sage-get-system-packages install-requires \ sage_conf \ From 9042e6b0acfcd781bca108cbd42d3a0190b96126 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 25 Oct 2022 17:11:55 -0700 Subject: [PATCH 12/40] build/pkgs/python3: Update to 3.11.0 --- build/pkgs/python3/checksums.ini | 6 +++--- build/pkgs/python3/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/python3/checksums.ini b/build/pkgs/python3/checksums.ini index be7d7deb4cb..eb08893c0e9 100644 --- a/build/pkgs/python3/checksums.ini +++ b/build/pkgs/python3/checksums.ini @@ -1,5 +1,5 @@ tarball=Python-VERSION.tar.xz -sha1=f60ea46e5190eec13803ad0896a650aaba3d76e1 -md5=013eb698ab20c284e5b8373435add767 -cksum=267896025 +sha1=474838615eab658fc15c87d4bee6bf85a02b424d +md5=fe92acfa0db9b9f5044958edb451d463 +cksum=1490492967 upstream_url=https://www.python.org/ftp/python/3.11.0/Python-VERSION.tar.xz diff --git a/build/pkgs/python3/package-version.txt b/build/pkgs/python3/package-version.txt index ccd5b735148..afad818663d 100644 --- a/build/pkgs/python3/package-version.txt +++ b/build/pkgs/python3/package-version.txt @@ -1 +1 @@ -3.11.0rc1 +3.11.0 From a379ea3a3d4020bf344bf8ed4c562018cacb661d Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 25 Oct 2022 17:23:41 -0700 Subject: [PATCH 13/40] build/pkgs/cypari: Update to 2.1.3 --- build/pkgs/cypari/checksums.ini | 8 ++++---- build/pkgs/cypari/package-version.txt | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/build/pkgs/cypari/checksums.ini b/build/pkgs/cypari/checksums.ini index 119b819d666..1d3a8a4db0d 100644 --- a/build/pkgs/cypari/checksums.ini +++ b/build/pkgs/cypari/checksums.ini @@ -1,5 +1,5 @@ tarball=cypari2-VERSION.tar.gz -sha1=f39b7a2b4b91302264b3997edd022feb945df7bb -md5=080b7da24aad03d5664f007dfccf0022 -cksum=948153093 -upstream_url=https://github.com/kliem/cypari2/archive/refs/tags/vVERSION.tar.gz +sha1=8a2d41ca468917a61ec02d318184816856bb7046 +md5=38398e46d3ceeb0109b712df264cdecd +cksum=2943559075 +upstream_url=https://pypi.io/packages/source/c/cypari2/cypari2-VERSION.tar.gz diff --git a/build/pkgs/cypari/package-version.txt b/build/pkgs/cypari/package-version.txt index 887948350c6..ac2cdeba013 100644 --- a/build/pkgs/cypari/package-version.txt +++ b/build/pkgs/cypari/package-version.txt @@ -1 +1 @@ -2.2.0a0 +2.1.3 From 34c5c94963138aa79bcec01a432d2d6a522f28c0 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 25 Oct 2022 17:34:13 -0700 Subject: [PATCH 14/40] build/pkgs/cypari/patches/trashcan.patch: Remove --- build/pkgs/cypari/patches/trashcan.patch | 47 ------------------------ 1 file changed, 47 deletions(-) delete mode 100644 build/pkgs/cypari/patches/trashcan.patch diff --git a/build/pkgs/cypari/patches/trashcan.patch b/build/pkgs/cypari/patches/trashcan.patch deleted file mode 100644 index f4918d4cd39..00000000000 --- a/build/pkgs/cypari/patches/trashcan.patch +++ /dev/null @@ -1,47 +0,0 @@ -commit 78e6dcf937c960c51132132e14f86bddbbe5b7d9 -Author: Jeroen Demeyer -Date: Tue Feb 19 11:50:49 2019 +0100 - - Use the trashcan for Gen - -diff --git a/cypari2/gen.pxd b/cypari2/gen.pxd -index 2ac0669..664d57d 100644 ---- a/cypari2/gen.pxd -+++ b/cypari2/gen.pxd -@@ -1,3 +1,4 @@ -+cimport cython - from cpython.object cimport PyObject - from .types cimport GEN, pari_sp - -diff --git a/cypari2/gen.pyx b/cypari2/gen.pyx -index d268cf1..687f5b2 100644 ---- a/cypari2/gen.pyx -+++ b/cypari2/gen.pyx -@@ -135,6 +135,7 @@ cdef extern from *: - GEN new_nfeltup(GEN nf, GEN x, GEN zknf) - - -+@cython.trashcan(True) - cdef class Gen(Gen_base): - """ - Wrapper for a PARI ``GEN`` with memory management. -diff --git a/cypari2/pari_instance.pyx b/cypari2/pari_instance.pyx -index ba82438..d13bc45 100644 ---- a/cypari2/pari_instance.pyx -+++ b/cypari2/pari_instance.pyx -@@ -243,6 +243,15 @@ Reset default precision for the following tests: - - >>> pari.set_real_precision_bits(53) - -+Test the trashcan mechanism (without the trashcan, this would cause -+a stack overflow): -+ -+>>> pari.allocatemem(2**27, silent=True) -+>>> L = [pari(i) for i in range(2**20)] -+>>> x = pari.Pi() -+>>> del L -+>>> del x -+ - Test that interrupts work properly: - - >>> pari.allocatemem(8000000, 2**29) From de38bac21e276c6dba95b8b33f7457a0ac56bdeb Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 25 Oct 2022 19:43:53 -0700 Subject: [PATCH 15/40] src/sage: Apply python-3.11.patch from https://github.com/void-linux/void-packages/commit/6229f313450ecae88743b4d5e99da2ed4de44e07 --- src/sage/cpython/cython_metaclass.h | 2 +- src/sage/libs/gmp/pylong.pyx | 8 +++----- src/sage/symbolic/ginac/numeric.cpp | 1 - 3 files changed, 4 insertions(+), 7 deletions(-) diff --git a/src/sage/cpython/cython_metaclass.h b/src/sage/cpython/cython_metaclass.h index cc620a4dac7..6487342b71e 100644 --- a/src/sage/cpython/cython_metaclass.h +++ b/src/sage/cpython/cython_metaclass.h @@ -66,7 +66,7 @@ static CYTHON_INLINE int Sage_PyType_Ready(PyTypeObject* t) } /* Now, set t.__class__ to metaclass */ - Py_TYPE(t) = metaclass; + Py_SET_TYPE(t, metaclass); PyType_Modified(t); } else diff --git a/src/sage/libs/gmp/pylong.pyx b/src/sage/libs/gmp/pylong.pyx index 388be32c55e..e772b60e3e0 100644 --- a/src/sage/libs/gmp/pylong.pyx +++ b/src/sage/libs/gmp/pylong.pyx @@ -32,7 +32,7 @@ from cpython.longintrepr cimport _PyLong_New, py_long, digit, PyLong_SHIFT from .mpz cimport * cdef extern from *: - Py_ssize_t* Py_SIZE_PTR "&Py_SIZE"(object) + void Py_SET_SIZE(object, Py_ssize_t) int hash_bits """ #ifdef _PyHASH_BITS _PyHASH_BITS /* Python 3 */ @@ -57,10 +57,8 @@ cdef mpz_get_pylong_large(mpz_srcptr z): mpz_export(L.ob_digit, NULL, -1, sizeof(digit), 0, PyLong_nails, z) if mpz_sgn(z) < 0: - # Set correct size (use a pointer to hack around Cython's - # non-support for lvalues). - sizeptr = Py_SIZE_PTR(L) - sizeptr[0] = -pylong_size + # Set correct size + Py_SET_SIZE(L, -pylong_size) return L diff --git a/src/sage/symbolic/ginac/numeric.cpp b/src/sage/symbolic/ginac/numeric.cpp index 22060441760..b40ed64edb5 100644 --- a/src/sage/symbolic/ginac/numeric.cpp +++ b/src/sage/symbolic/ginac/numeric.cpp @@ -52,7 +52,6 @@ #define register #define PY_SSIZE_T_CLEAN #include -#include #include "flint/fmpz.h" #include "flint/fmpz_factor.h" From 2df72dfa9ecb5ae76fea92379a751c4d46358dea Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 25 Oct 2022 21:26:32 -0700 Subject: [PATCH 16/40] build/pkgs/cython/patches/trashcan.patch: Remove --- build/pkgs/cython/patches/trashcan.patch | 180 ----------------------- 1 file changed, 180 deletions(-) delete mode 100644 build/pkgs/cython/patches/trashcan.patch diff --git a/build/pkgs/cython/patches/trashcan.patch b/build/pkgs/cython/patches/trashcan.patch deleted file mode 100644 index 18e1b4a7052..00000000000 --- a/build/pkgs/cython/patches/trashcan.patch +++ /dev/null @@ -1,180 +0,0 @@ -See https://github.com/cython/cython/pull/2842 - -commit c47c4ef735c4b7f1863b21bbe6f112b06c4aad05 -Author: Jeroen Demeyer -Date: Thu Feb 14 10:02:41 2019 +0100 - - @cython.trashcan directive to enable the Python trashcan for deallocations - -diff --git a/Cython/Compiler/ModuleNode.py b/Cython/Compiler/ModuleNode.py -index d5742de..27fcad6 100644 ---- a/Cython/Compiler/ModuleNode.py -+++ b/Cython/Compiler/ModuleNode.py -@@ -1426,6 +1426,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): - - is_final_type = scope.parent_type.is_final_type - needs_gc = scope.needs_gc() -+ needs_trashcan = scope.needs_trashcan() - - weakref_slot = scope.lookup_here("__weakref__") if not scope.is_closure_class_scope else None - if weakref_slot not in scope.var_entries: -@@ -1464,6 +1465,11 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): - # running this destructor. - code.putln("PyObject_GC_UnTrack(o);") - -+ if needs_trashcan: -+ code.globalstate.use_utility_code( -+ UtilityCode.load_cached("PyTrashcan", "ExtensionTypes.c")) -+ code.putln("__Pyx_TRASHCAN_BEGIN(o, %s)" % slot_func_cname) -+ - # call the user's __dealloc__ - self.generate_usr_dealloc_call(scope, code) - -@@ -1537,6 +1543,10 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): - code.putln("(*Py_TYPE(o)->tp_free)(o);") - if freelist_size: - code.putln("}") -+ -+ if needs_trashcan: -+ code.putln("__Pyx_TRASHCAN_END") -+ - code.putln( - "}") - -diff --git a/Cython/Compiler/Options.py b/Cython/Compiler/Options.py -index d859c19..19d96f1 100644 ---- a/Cython/Compiler/Options.py -+++ b/Cython/Compiler/Options.py -@@ -313,6 +313,7 @@ directive_types = { - 'freelist': int, - 'c_string_type': one_of('bytes', 'bytearray', 'str', 'unicode'), - 'c_string_encoding': normalise_encoding_name, -+ 'trashcan': bool, - } - - for key, val in _directive_defaults.items(): -@@ -355,6 +356,7 @@ directive_scopes = { # defaults to available everywhere - 'np_pythran': ('module',), - 'fast_gil': ('module',), - 'iterable_coroutine': ('module', 'function'), -+ 'trashcan' : ('cclass',), - } - - -diff --git a/Cython/Compiler/PyrexTypes.py b/Cython/Compiler/PyrexTypes.py -index 3b572d6..f200c5f 100644 ---- a/Cython/Compiler/PyrexTypes.py -+++ b/Cython/Compiler/PyrexTypes.py -@@ -1136,6 +1136,7 @@ class PyObjectType(PyrexType): - is_extern = False - is_subclassed = False - is_gc_simple = False -+ builtin_trashcan = False # builtin type using trashcan - - def __str__(self): - return "Python object" -@@ -1190,10 +1191,14 @@ class PyObjectType(PyrexType): - - - builtin_types_that_cannot_create_refcycles = set([ -- 'bool', 'int', 'long', 'float', 'complex', -+ 'object', 'bool', 'int', 'long', 'float', 'complex', - 'bytearray', 'bytes', 'unicode', 'str', 'basestring' - ]) - -+builtin_types_with_trashcan = set([ -+ 'dict', 'list', 'set', 'frozenset', 'tuple', 'type', -+]) -+ - - class BuiltinObjectType(PyObjectType): - # objstruct_cname string Name of PyObject struct -@@ -1218,6 +1223,7 @@ class BuiltinObjectType(PyObjectType): - self.typeptr_cname = "(&%s)" % cname - self.objstruct_cname = objstruct_cname - self.is_gc_simple = name in builtin_types_that_cannot_create_refcycles -+ self.builtin_trashcan = name in builtin_types_with_trashcan - if name == 'type': - # Special case the type type, as many C API calls (and other - # libraries) actually expect a PyTypeObject* for type arguments. -diff --git a/Cython/Compiler/Symtab.py b/Cython/Compiler/Symtab.py -index f7443cb..d44484d 100644 ---- a/Cython/Compiler/Symtab.py -+++ b/Cython/Compiler/Symtab.py -@@ -2085,6 +2085,22 @@ class CClassScope(ClassScope): - return not self.parent_type.is_gc_simple - return False - -+ def needs_trashcan(self): -+ # If the trashcan directive is explicitly set to False, -+ # unconditionally disable the trashcan. -+ directive = self.directives.get('trashcan') -+ if directive is False: -+ return False -+ # If the directive is set to True and the class has Python-valued -+ # C attributes, then it should use the trashcan in tp_dealloc. -+ if directive and self.has_cyclic_pyobject_attrs: -+ return True -+ # Use the trashcan if the base class uses it -+ base_type = self.parent_type.base_type -+ if base_type and base_type.scope is not None: -+ return base_type.scope.needs_trashcan() -+ return self.parent_type.builtin_trashcan -+ - def needs_tp_clear(self): - """ - Do we need to generate an implementation for the tp_clear slot? Can -diff --git a/Cython/Utility/ExtensionTypes.c b/Cython/Utility/ExtensionTypes.c -index 50d0e21..ca2adbe 100644 ---- a/Cython/Utility/ExtensionTypes.c -+++ b/Cython/Utility/ExtensionTypes.c -@@ -74,6 +74,49 @@ static int __Pyx_PyType_Ready(PyTypeObject *t) { - return r; - } - -+/////////////// PyTrashcan.proto /////////////// -+ -+// These macros are taken from https://github.com/python/cpython/pull/11841 -+// Unlike the Py_TRASHCAN_SAFE_BEGIN/Py_TRASHCAN_SAFE_END macros, they -+// allow dealing correctly with subclasses. -+ -+// This requires CPython version >= 2.7.4 -+// (or >= 3.2.4 but we don't support such old Python 3 versions anyway) -+#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x02070400 -+#define __Pyx_TRASHCAN_BEGIN_CONDITION(op, cond) \ -+ do { \ -+ PyThreadState *_tstate = NULL; \ -+ // If "cond" is false, then _tstate remains NULL and the deallocator -+ // is run normally without involving the trashcan -+ if (cond) { \ -+ _tstate = PyThreadState_GET(); \ -+ if (_tstate->trash_delete_nesting >= PyTrash_UNWIND_LEVEL) { \ -+ // Store the object (to be deallocated later) and jump past -+ // Py_TRASHCAN_END, skipping the body of the deallocator -+ _PyTrash_thread_deposit_object((PyObject*)(op)); \ -+ break; \ -+ } \ -+ ++_tstate->trash_delete_nesting; \ -+ } -+ // The body of the deallocator is here. -+#define __Pyx_TRASHCAN_END \ -+ if (_tstate) { \ -+ --_tstate->trash_delete_nesting; \ -+ if (_tstate->trash_delete_later && _tstate->trash_delete_nesting <= 0) \ -+ _PyTrash_thread_destroy_chain(); \ -+ } \ -+ } while (0); -+ -+#define __Pyx_TRASHCAN_BEGIN(op, dealloc) __Pyx_TRASHCAN_BEGIN_CONDITION(op, \ -+ Py_TYPE(op)->tp_dealloc == (destructor)(dealloc)) -+ -+#else -+// The trashcan is a no-op on other Python implementations -+// or old CPython versions -+#define __Pyx_TRASHCAN_BEGIN(op, dealloc) -+#define __Pyx_TRASHCAN_END -+#endif -+ - /////////////// CallNextTpDealloc.proto /////////////// - - static void __Pyx_call_next_tp_dealloc(PyObject* obj, destructor current_tp_dealloc); From 9eb08f3afde3266bbd667e196513240a0fe245f4 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 25 Oct 2022 22:52:56 -0700 Subject: [PATCH 17/40] inspect.ArgSpec -> inspect.FullArgSpec --- src/sage/misc/cachefunc.pyx | 4 ++-- src/sage/misc/decorators.py | 6 ++++-- src/sage/misc/function_mangling.pyx | 2 +- src/sage/misc/sageinspect.py | 24 +++++++++++++----------- 4 files changed, 20 insertions(+), 16 deletions(-) diff --git a/src/sage/misc/cachefunc.pyx b/src/sage/misc/cachefunc.pyx index 9fa967ce737..72042ef13d6 100644 --- a/src/sage/misc/cachefunc.pyx +++ b/src/sage/misc/cachefunc.pyx @@ -2818,7 +2818,7 @@ cdef class CachedMethod(): except Exception: pass if self.nargs == 0: - args, varargs, keywords, defaults = sage_getargspec(f) + args, varargs, keywords, defaults, kwonlyargs, kwonlydefaults, annotations = sage_getargspec(f) if varargs is None and keywords is None and len(args)<=1: self.nargs = 1 else: @@ -2954,7 +2954,7 @@ cdef class CachedSpecialMethod(CachedMethod): # we need to analyse the argspec f = self._cachedfunc.f if self.nargs == 0: - args, varargs, keywords, defaults = sage_getargspec(f) + args, varargs, keywords, defaults, kwonlyargs, kwonlydefaults, annotations = sage_getargspec(f) if varargs is None and keywords is None and len(args)<=1: self.nargs = 1 Caller = CachedMethodCallerNoArgs(inst, f, name=name, do_pickle=self._cachedfunc.do_pickle) diff --git a/src/sage/misc/decorators.py b/src/sage/misc/decorators.py index 28c52448813..311a5105739 100644 --- a/src/sage/misc/decorators.py +++ b/src/sage/misc/decorators.py @@ -32,7 +32,8 @@ from sage.misc.sageinspect import (sage_getsource, sage_getsourcelines, sage_getargspec) -from inspect import ArgSpec + +from inspect import FullArgSpec def sage_wraps(wrapped, assigned=WRAPPER_ASSIGNMENTS, updated=WRAPPER_UPDATES): @@ -499,7 +500,8 @@ def argspec(): list(self.options)) defaults = (argspec.defaults or ()) + tuple(self.options.values()) # Note: argspec.defaults is not always a tuple for some reason - return ArgSpec(args, argspec.varargs, argspec.keywords, defaults) + return FullArgSpec(args, argspec.varargs, argspec.keywords, defaults, + kwonlyargs=[], kwonlydefaults={}, annotations={}) wrapper._sage_argspec_ = argspec diff --git a/src/sage/misc/function_mangling.pyx b/src/sage/misc/function_mangling.pyx index 0ac03cf0715..e1bb7978953 100644 --- a/src/sage/misc/function_mangling.pyx +++ b/src/sage/misc/function_mangling.pyx @@ -116,7 +116,7 @@ cdef class ArgumentFixer: """ def __init__(self, f, classmethod = False): try: - arg_names, varargs, varkw, defaults = sage_getargspec(f) + arg_names, varargs, varkw, defaults, kwonlyargs, kwonlydefaults, annotations = sage_getargspec(f) except AttributeError: # This error occurs if f is defined in a Cython file and the # source file has gone. diff --git a/src/sage/misc/sageinspect.py b/src/sage/misc/sageinspect.py index fbca2defc20..a3821cb56b9 100644 --- a/src/sage/misc/sageinspect.py +++ b/src/sage/misc/sageinspect.py @@ -359,7 +359,7 @@ def _extract_embedded_signature(docstring, name): docstring = L[1] if len(L) > 1 else '' # Remove first line, keep the rest def_string = "def " + name + signature + ": pass" try: - return docstring, inspect.ArgSpec(*_sage_getargspec_cython(def_string)) + return docstring, inspect.FullArgSpec(*_sage_getargspec_cython(def_string)) except SyntaxError: docstring = os.linesep.join(L) return docstring, None @@ -1135,8 +1135,9 @@ def _sage_getargspec_from_ast(source): vararg = getattr(ast_args.vararg, 'arg', None) kwarg = getattr(ast_args.kwarg, 'arg', None) - return inspect.ArgSpec(args, vararg, kwarg, - tuple(defaults) if defaults else None) + return inspect.FullArgSpec(args, vararg, kwarg, + tuple(defaults) if defaults else None, + kwonlyargs=[], kwonlydefaults={}, annotations={}) def _sage_getargspec_cython(source): @@ -1152,7 +1153,7 @@ def _sage_getargspec_cython(source): OUTPUT: - - an instance of :obj:`inspect.ArgSpec`, i.e., a named tuple + - an instance of :class:`inspect.FullArgSpec`, i.e., a named tuple EXAMPLES:: @@ -1662,11 +1663,11 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return return sage_getargspec(obj.__call__) if isinstance(obj, (lazy_attribute, AbstractMethod)): source = sage_getsource(obj) - return inspect.ArgSpec(*_sage_getargspec_cython(source)) + return inspect.FullArgSpec(*_sage_getargspec_cython(source)) if not callable(obj): raise TypeError("obj is not a code object") try: - return inspect.ArgSpec(*obj._sage_argspec_()) + return inspect.FullArgSpec(*obj._sage_argspec_()) except (AttributeError, TypeError): pass # If we are lucky, the function signature is embedded in the docstring. @@ -1682,7 +1683,7 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return # Note that this may give a wrong result for the constants! try: args, varargs, varkw = inspect.getargs(obj.__code__) - return inspect.ArgSpec(args, varargs, varkw, obj.__defaults__) + return inspect.FullArgSpec(args, varargs, varkw, obj.__defaults__) except (TypeError, AttributeError): pass if isclassinstance(obj): @@ -1717,7 +1718,7 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return except TypeError: # happens for Python builtins source = '' if source: - return inspect.ArgSpec(*_sage_getargspec_cython(source)) + return inspect.FullArgSpec(*_sage_getargspec_cython(source)) else: func_obj = obj @@ -1730,7 +1731,7 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return except TypeError: # arg is not a code object # The above "hopefully" was wishful thinking: try: - return inspect.ArgSpec(*_sage_getargspec_cython(sage_getsource(obj))) + return inspect.FullArgSpec(*_sage_getargspec_cython(sage_getsource(obj))) except TypeError: # This happens for Python builtins # The best we can do is to return a generic argspec args = [] @@ -1740,7 +1741,8 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return defaults = func_obj.__defaults__ except AttributeError: defaults = None - return inspect.ArgSpec(args, varargs, varkw, defaults) + return inspect.FullArgSpec(args, varargs, varkw, defaults, + kwonlyargs=[], kwonlydefaults={}, annotations={}) def formatannotation(annotation, base_module=None): @@ -1811,7 +1813,7 @@ def sage_formatargspec(args, varargs=None, varkw=None, defaults=None, :func:`sage_getargspec`. Since :func:`sage_getargspec` works for Cython functions while Python's inspect module does not, it makes sense to keep this function for formatting instances of - ``inspect.ArgSpec``. + ``inspect.FullArgSpec``. EXAMPLES:: From 69db932a2f9fd56b5ca8370e72398f602573e1b8 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 25 Oct 2022 23:13:48 -0700 Subject: [PATCH 18/40] pkgs/*/setup.cfg: Update python versions --- pkgs/sage-docbuild/setup.cfg | 1 + pkgs/sage-setup/setup.cfg | 1 + pkgs/sagemath-categories/setup.cfg.m4 | 1 + pkgs/sagemath-environment/setup.cfg.m4 | 3 ++- pkgs/sagemath-objects/setup.cfg.m4 | 1 + pkgs/sagemath-repl/setup.cfg.m4 | 1 + src/setup.cfg.m4 | 1 + 7 files changed, 8 insertions(+), 1 deletion(-) diff --git a/pkgs/sage-docbuild/setup.cfg b/pkgs/sage-docbuild/setup.cfg index abc71ffcd00..337548c6ff3 100644 --- a/pkgs/sage-docbuild/setup.cfg +++ b/pkgs/sage-docbuild/setup.cfg @@ -20,6 +20,7 @@ classifiers = Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.10 + Programming Language :: Python :: 3.11 Programming Language :: Python :: Implementation :: CPython Topic :: Scientific/Engineering :: Mathematics diff --git a/pkgs/sage-setup/setup.cfg b/pkgs/sage-setup/setup.cfg index 54b5b401aad..5d7f440e7c6 100644 --- a/pkgs/sage-setup/setup.cfg +++ b/pkgs/sage-setup/setup.cfg @@ -20,6 +20,7 @@ classifiers = Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.10 + Programming Language :: Python :: 3.11 Programming Language :: Python :: Implementation :: CPython Topic :: Scientific/Engineering :: Mathematics diff --git a/pkgs/sagemath-categories/setup.cfg.m4 b/pkgs/sagemath-categories/setup.cfg.m4 index 6d22c2206c6..62aca5af44f 100644 --- a/pkgs/sagemath-categories/setup.cfg.m4 +++ b/pkgs/sagemath-categories/setup.cfg.m4 @@ -21,6 +21,7 @@ classifiers = Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.10 + Programming Language :: Python :: 3.11 Programming Language :: Python :: Implementation :: CPython Topic :: Scientific/Engineering :: Mathematics diff --git a/pkgs/sagemath-environment/setup.cfg.m4 b/pkgs/sagemath-environment/setup.cfg.m4 index 9c242890f89..919a5b576cd 100644 --- a/pkgs/sagemath-environment/setup.cfg.m4 +++ b/pkgs/sagemath-environment/setup.cfg.m4 @@ -18,9 +18,10 @@ classifiers = Operating System :: POSIX Operating System :: MacOS :: MacOS X Programming Language :: Python :: 3 :: Only - Programming Language :: Python :: 3.7 Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 + Programming Language :: Python :: 3.10 + Programming Language :: Python :: 3.11 Programming Language :: Python :: Implementation :: CPython Topic :: Scientific/Engineering :: Mathematics diff --git a/pkgs/sagemath-objects/setup.cfg.m4 b/pkgs/sagemath-objects/setup.cfg.m4 index a6cc3ebc7fe..88246c422f2 100644 --- a/pkgs/sagemath-objects/setup.cfg.m4 +++ b/pkgs/sagemath-objects/setup.cfg.m4 @@ -21,6 +21,7 @@ classifiers = Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.10 + Programming Language :: Python :: 3.11 Programming Language :: Python :: Implementation :: CPython Topic :: Scientific/Engineering :: Mathematics diff --git a/pkgs/sagemath-repl/setup.cfg.m4 b/pkgs/sagemath-repl/setup.cfg.m4 index 8afc51ce010..2367fda7b9a 100644 --- a/pkgs/sagemath-repl/setup.cfg.m4 +++ b/pkgs/sagemath-repl/setup.cfg.m4 @@ -21,6 +21,7 @@ classifiers = Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.10 + Programming Language :: Python :: 3.11 Programming Language :: Python :: Implementation :: CPython Topic :: Scientific/Engineering :: Mathematics diff --git a/src/setup.cfg.m4 b/src/setup.cfg.m4 index 733855409d3..9f69af385e9 100644 --- a/src/setup.cfg.m4 +++ b/src/setup.cfg.m4 @@ -22,6 +22,7 @@ classifiers = Programming Language :: Python :: 3.8 Programming Language :: Python :: 3.9 Programming Language :: Python :: 3.10 + Programming Language :: Python :: 3.11 Programming Language :: Python :: Implementation :: CPython Topic :: Scientific/Engineering :: Mathematics From 9e590b75c218d501be68f2da6af8b50417e894ec Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Wed, 26 Oct 2022 17:01:27 -0700 Subject: [PATCH 19/40] src/sage/features/__init__.py: Guard import sage.misc.cython with try...except --- src/sage/features/__init__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sage/features/__init__.py b/src/sage/features/__init__.py index fd899aa4770..404571e672a 100644 --- a/src/sage/features/__init__.py +++ b/src/sage/features/__init__.py @@ -768,8 +768,8 @@ def _is_present(self): from distutils.errors import CCompilerError with open(tmp_filename(ext=".pyx"), 'w') as pyx: pyx.write(self.test_code) - from sage.misc.cython import cython_import try: + from sage.misc.cython import cython_import cython_import(pyx.name, verbose=-1) except CCompilerError: return FeatureTestResult(self, False, reason="Failed to compile test code.") From 8955607c71cb94e4a810b89f113b7b220a351417 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Sun, 6 Nov 2022 11:26:10 -0300 Subject: [PATCH 20/40] dict_del_by_value: move python internal definitions to a separate file --- src/sage/cpython/dict_del_by_value.pyx | 153 ++++++++--------------- src/sage/cpython/dict_internal.h | 165 +++++++++++++++++++++++++ 2 files changed, 214 insertions(+), 104 deletions(-) create mode 100644 src/sage/cpython/dict_internal.h diff --git a/src/sage/cpython/dict_del_by_value.pyx b/src/sage/cpython/dict_del_by_value.pyx index 488bf9c84cc..3894554c13d 100644 --- a/src/sage/cpython/dict_del_by_value.pyx +++ b/src/sage/cpython/dict_del_by_value.pyx @@ -19,13 +19,8 @@ AUTHORS: # https://www.gnu.org/licenses/ # **************************************************************************** -import weakref -from weakref import KeyedRef - from cpython.list cimport PyList_New -from cpython cimport Py_XINCREF, Py_XDECREF -from libc.stdint cimport int8_t, int16_t, int32_t, int64_t cdef extern from "Python.h": ctypedef struct PyDictKeysObject @@ -34,99 +29,47 @@ cdef extern from "Python.h": PyDictKeysObject * ma_keys PyObject ** ma_values - #we need this redefinition because we want to be able to call - #PyWeakref_GetObject with borrowed references. This is the recommended - #strategy according to Cython/Includes/cpython/__init__.pxd - PyObject* PyWeakref_GetObject(PyObject * wr) int PyList_SetItem(object list, Py_ssize_t index, PyObject * item) except -1 - int PyWeakref_Check(PyObject * ob) -#### -#definitions replicated from CPython's Objects/dict-common.h -#(this file is not exported from CPython, so we need to be -#careful the definitions are in step with what happens there. - -ctypedef void* dict_lookup_func # Precise definition not needed - -ctypedef union IndexBlock: - int8_t as_1[8] - int16_t as_2[4] - int32_t as_4[2] - int64_t as_8[1] - -ctypedef struct MyPyDictKeysObject: - Py_ssize_t dk_refcnt - Py_ssize_t dk_size - dict_lookup_func dk_lookup - Py_ssize_t dk_usable - Py_ssize_t dk_nentries - IndexBlock dk_indices - -ctypedef struct PyDictKeyEntry: - Py_hash_t me_hash - PyObject * me_key - PyObject * me_value - -cdef Py_ssize_t DKIX_EMPTY = -1 -cdef Py_ssize_t DKIX_DUMMY = -2 -cdef Py_ssize_t DKIX_ERROR = -3 - -##### -#These routines are copied from CPython's Object/dictobject.c -#in order to access PyDictKeysObject fields - -cdef inline int DK_IXSIZE(MyPyDictKeysObject *keys): - cdef Py_ssize_t s = keys.dk_size - if s <= 0xff: - return 1 - elif s <= 0xffff: - return 2 - elif s <= 0xffffffff: - return 4 - else: - return 8 - -cdef inline PyDictKeyEntry * DK_ENTRIES(MyPyDictKeysObject *keys): - return &(keys.dk_indices.as_1[keys.dk_size * DK_IXSIZE(keys)]) - -cdef inline Py_ssize_t dk_get_index(MyPyDictKeysObject *keys, Py_ssize_t i): - cdef Py_ssize_t s = keys.dk_size - if s <= 0xff: - return keys.dk_indices.as_1[i] - elif s <= 0xffff: - return keys.dk_indices.as_2[i] - elif s <= 0xffffffff: - return keys.dk_indices.as_4[i] - else: - return keys.dk_indices.as_8[i] - -cdef inline void dk_set_index(MyPyDictKeysObject *keys, Py_ssize_t i, Py_ssize_t ix): - cdef Py_ssize_t s = keys.dk_size - if s <= 0xff: - keys.dk_indices.as_1[i] = ix - elif s <= 0xffff: - keys.dk_indices.as_2[i] = ix - elif s <= 0xffffffff: - keys.dk_indices.as_4[i] = ix - else: - keys.dk_indices.as_8[i] = ix - -#End of replication of Object/dictobject.c -###### - -cdef dict_lookup_func lookdict - -cdef dict_lookup_func DK_LOOKUP(PyDictObject *mp): - return ((mp.ma_keys)).dk_lookup - -def init_lookdict(): - global lookdict - # A dict which a non-string key uses the generic "lookdict" - # as lookup function - cdef object D = {} - D[0] = 0 - lookdict = DK_LOOKUP(D) - -init_lookdict() + +cdef extern from "dict_internal.h": + Py_ssize_t DK_MASK(PyDictKeysObject *) + PyDictKeyEntry * DK_ENTRIES(PyDictKeysObject *keys) + + Py_ssize_t dictkeys_get_index (PyDictKeysObject *keys, Py_ssize_t i) + void dictkeys_set_index (PyDictKeysObject *keys, Py_ssize_t i, Py_ssize_t ix) + + Py_ssize_t DKIX_EMPTY, DKIX_DUMMY + int PERTURB_SHIFT + + ctypedef struct PyDictKeyEntry: + Py_hash_t me_hash + PyObject * me_key + PyObject * me_value + + +# dk_lookup was removed in python 3.11 +DEF HAS_DK_LOOKUP = PY_VERSION_HEX < 0x30b0000 + +IF HAS_DK_LOOKUP: + + cdef extern from *: + """ + #define DK_LOOKUP(dk) ((dk)->dk_lookup) + """ + ctypedef void * dict_lookup_func # Precise definition not needed + dict_lookup_func DK_LOOKUP(PyDictKeysObject *mp) + + cdef dict_lookup_func lookdict + + def init_lookdict(): + global lookdict + # A dict which a non-string key uses the generic "lookdict" + # as lookup function + cdef object D = {} + D[0] = 0 + lookdict = DK_LOOKUP((D).ma_keys) + + init_lookdict() cdef int del_dictitem_by_exact_value(PyDictObject *mp, PyObject *value, Py_hash_t hash) except -1: """ @@ -177,9 +120,9 @@ cdef int del_dictitem_by_exact_value(PyDictObject *mp, PyObject *value, Py_hash_ sage: for i in range(10^3+10): newA = A(); M[newA] = prev; prev = newA sage: del a """ - keys = (mp.ma_keys) + keys = mp.ma_keys cdef size_t perturb - cdef size_t mask = keys.dk_size-1 + cdef size_t mask = DK_MASK(keys) cdef PyDictKeyEntry *entries = DK_ENTRIES(keys) cdef PyDictKeyEntry *ep @@ -187,7 +130,7 @@ cdef int del_dictitem_by_exact_value(PyDictObject *mp, PyObject *value, Py_hash_ raise TypeError("del_dictitem_by_exact_value cannot be applied to a shared key dict") cdef size_t i = hash & mask - ix = dk_get_index(keys, i) + ix = dictkeys_get_index(keys, i) if ix == DKIX_EMPTY: # key not found @@ -196,9 +139,9 @@ cdef int del_dictitem_by_exact_value(PyDictObject *mp, PyObject *value, Py_hash_ ep = &(entries[ix]) perturb = hash while (ep.me_value != value or ep.me_hash != hash): - perturb = perturb >> 5 #this is the value of PERTURB_SHIFT + perturb = perturb >> PERTURB_SHIFT i = mask & (i * 5 + perturb + 1) - ix = dk_get_index(keys, i) + ix = dictkeys_get_index(keys, i) if ix == DKIX_EMPTY: # key not found return 0 @@ -206,7 +149,9 @@ cdef int del_dictitem_by_exact_value(PyDictObject *mp, PyObject *value, Py_hash_ # We need the lookup function to be the generic lookdict, otherwise # deletions may not work correctly - keys.dk_lookup = lookdict + IF HAS_DK_LOOKUP: + # Can this fail? In any case dk_lookup was removed in python 3.11 + assert DK_LOOKUP(keys) is lookdict T = PyList_New(2) PyList_SetItem(T, 0, ep.me_key) @@ -214,7 +159,7 @@ cdef int del_dictitem_by_exact_value(PyDictObject *mp, PyObject *value, Py_hash_ ep.me_key = NULL ep.me_value = NULL mp.ma_used -= 1 - dk_set_index(keys, i, DKIX_DUMMY) + dictkeys_set_index(keys, i, DKIX_DUMMY) #We have transferred the to-be-deleted references to the list T #we now delete the list so that the actual decref happens through a #deallocation routine that uses the Python Trashcan macros to diff --git a/src/sage/cpython/dict_internal.h b/src/sage/cpython/dict_internal.h new file mode 100644 index 00000000000..06c7a16b275 --- /dev/null +++ b/src/sage/cpython/dict_internal.h @@ -0,0 +1,165 @@ +/* This contains internal definitions for python dictionaries, + * mostly copied from cpython sourcecode. + * + * Moved here to make it easier to maintain in the face of python + * changes. + * */ + +/************************************************************/ +/* Copied verbatim from cpython 3.8 (Objects/dict-common.h) */ +/************************************************************/ + +#ifndef Py_DICT_COMMON_H +#define Py_DICT_COMMON_H + +typedef struct { + /* Cached hash code of me_key. */ + Py_hash_t me_hash; + PyObject *me_key; + PyObject *me_value; /* This field is only meaningful for combined tables */ +} PyDictKeyEntry; + +/* dict_lookup_func() returns index of entry which can be used like DK_ENTRIES(dk)[index]. + * -1 when no entry found, -3 when compare raises error. + */ +typedef Py_ssize_t (*dict_lookup_func) + (PyDictObject *mp, PyObject *key, Py_hash_t hash, PyObject **value_addr); + +#define DKIX_EMPTY (-1) +#define DKIX_DUMMY (-2) /* Used internally */ +#define DKIX_ERROR (-3) + +/* See dictobject.c for actual layout of DictKeysObject */ +struct _dictkeysobject { + Py_ssize_t dk_refcnt; + + /* Size of the hash table (dk_indices). It must be a power of 2. */ + Py_ssize_t dk_size; + + /* Function to lookup in the hash table (dk_indices): + + - lookdict(): general-purpose, and may return DKIX_ERROR if (and + only if) a comparison raises an exception. + + - lookdict_unicode(): specialized to Unicode string keys, comparison of + which can never raise an exception; that function can never return + DKIX_ERROR. + + - lookdict_unicode_nodummy(): similar to lookdict_unicode() but further + specialized for Unicode string keys that cannot be the value. + + - lookdict_split(): Version of lookdict() for split tables. */ + dict_lookup_func dk_lookup; + + /* Number of usable entries in dk_entries. */ + Py_ssize_t dk_usable; + + /* Number of used entries in dk_entries. */ + Py_ssize_t dk_nentries; + + /* Actual hash table of dk_size entries. It holds indices in dk_entries, + or DKIX_EMPTY(-1) or DKIX_DUMMY(-2). + + Indices must be: 0 <= indice < USABLE_FRACTION(dk_size). + + The size in bytes of an indice depends on dk_size: + + - 1 byte if dk_size <= 0xff (char*) + - 2 bytes if dk_size <= 0xffff (int16_t*) + - 4 bytes if dk_size <= 0xffffffff (int32_t*) + - 8 bytes otherwise (int64_t*) + + Dynamically sized, SIZEOF_VOID_P is minimum. */ + char dk_indices[]; /* char is required to avoid strict aliasing. */ + + /* "PyDictKeyEntry dk_entries[dk_usable];" array follows: + see the DK_ENTRIES() macro */ +}; + +#endif + + +/***********************************************************/ +/* Copied verbatim from cpython 3.8 (Objects/dictobject.c) */ +/***********************************************************/ + +#define PERTURB_SHIFT 5 +#define DK_SIZE(dk) ((dk)->dk_size) +#if SIZEOF_VOID_P > 4 +#define DK_IXSIZE(dk) \ + (DK_SIZE(dk) <= 0xff ? \ + 1 : DK_SIZE(dk) <= 0xffff ? \ + 2 : DK_SIZE(dk) <= 0xffffffff ? \ + 4 : sizeof(int64_t)) +#else +#define DK_IXSIZE(dk) \ + (DK_SIZE(dk) <= 0xff ? \ + 1 : DK_SIZE(dk) <= 0xffff ? \ + 2 : sizeof(int32_t)) +#endif +#define DK_ENTRIES(dk) \ + ((PyDictKeyEntry*)(&((int8_t*)((dk)->dk_indices))[DK_SIZE(dk) * DK_IXSIZE(dk)])) + +#define DK_MASK(dk) (((dk)->dk_size)-1) + +/* lookup indices. returns DKIX_EMPTY, DKIX_DUMMY, or ix >=0 */ +static inline Py_ssize_t +dictkeys_get_index(PyDictKeysObject *keys, Py_ssize_t i) +{ + Py_ssize_t s = DK_SIZE(keys); + Py_ssize_t ix; + + if (s <= 0xff) { + int8_t *indices = (int8_t*)(keys->dk_indices); + ix = indices[i]; + } + else if (s <= 0xffff) { + int16_t *indices = (int16_t*)(keys->dk_indices); + ix = indices[i]; + } +#if SIZEOF_VOID_P > 4 + else if (s > 0xffffffff) { + int64_t *indices = (int64_t*)(keys->dk_indices); + ix = indices[i]; + } +#endif + else { + int32_t *indices = (int32_t*)(keys->dk_indices); + ix = indices[i]; + } + assert(ix >= DKIX_DUMMY); + return ix; +} + +/* write to indices. */ +static inline void +dictkeys_set_index(PyDictKeysObject *keys, Py_ssize_t i, Py_ssize_t ix) +{ + Py_ssize_t s = DK_SIZE(keys); + + assert(ix >= DKIX_DUMMY); + + if (s <= 0xff) { + int8_t *indices = (int8_t*)(keys->dk_indices); + assert(ix <= 0x7f); + indices[i] = (char)ix; + } + else if (s <= 0xffff) { + int16_t *indices = (int16_t*)(keys->dk_indices); + assert(ix <= 0x7fff); + indices[i] = (int16_t)ix; + } +#if SIZEOF_VOID_P > 4 + else if (s > 0xffffffff) { + int64_t *indices = (int64_t*)(keys->dk_indices); + indices[i] = ix; + } +#endif + else { + int32_t *indices = (int32_t*)(keys->dk_indices); + assert(ix <= 0x7fffffff); + indices[i] = (int32_t)ix; + } +} + +/************************************************************/ From 76040803c8ae150baef449edce67ebdafb2ee896 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Sun, 6 Nov 2022 11:53:24 -0300 Subject: [PATCH 21/40] dict_del_by_value: add internal definitions for python 3.11 --- src/sage/cpython/dict_internal.h | 77 ++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) diff --git a/src/sage/cpython/dict_internal.h b/src/sage/cpython/dict_internal.h index 06c7a16b275..42a57bcb468 100644 --- a/src/sage/cpython/dict_internal.h +++ b/src/sage/cpython/dict_internal.h @@ -5,6 +5,8 @@ * changes. * */ +#if PY_VERSION_HEX < 0x30b0000 + /************************************************************/ /* Copied verbatim from cpython 3.8 (Objects/dict-common.h) */ /************************************************************/ @@ -163,3 +165,78 @@ dictkeys_set_index(PyDictKeysObject *keys, Py_ssize_t i, Py_ssize_t ix) } /************************************************************/ + +#else /* Python >= 3.11 */ + +#define Py_BUILD_CORE +#include + +/************************************************************/ +/* Copied verbatim from cpython 3.11 (Objects/dictobject.c) */ +/************************************************************/ + +#define PERTURB_SHIFT 5 +#define DK_MASK(dk) (DK_SIZE(dk)-1) + +/* lookup indices. returns DKIX_EMPTY, DKIX_DUMMY, or ix >=0 */ +static inline Py_ssize_t +dictkeys_get_index(const PyDictKeysObject *keys, Py_ssize_t i) +{ + int log2size = DK_LOG_SIZE(keys); + Py_ssize_t ix; + + if (log2size < 8) { + const int8_t *indices = (const int8_t*)(keys->dk_indices); + ix = indices[i]; + } + else if (log2size < 16) { + const int16_t *indices = (const int16_t*)(keys->dk_indices); + ix = indices[i]; + } +#if SIZEOF_VOID_P > 4 + else if (log2size >= 32) { + const int64_t *indices = (const int64_t*)(keys->dk_indices); + ix = indices[i]; + } +#endif + else { + const int32_t *indices = (const int32_t*)(keys->dk_indices); + ix = indices[i]; + } + assert(ix >= DKIX_DUMMY); + return ix; +} + +/* write to indices. */ +static inline void +dictkeys_set_index(PyDictKeysObject *keys, Py_ssize_t i, Py_ssize_t ix) +{ + int log2size = DK_LOG_SIZE(keys); + + assert(ix >= DKIX_DUMMY); + assert(keys->dk_version == 0); + + if (log2size < 8) { + int8_t *indices = (int8_t*)(keys->dk_indices); + assert(ix <= 0x7f); + indices[i] = (char)ix; + } + else if (log2size < 16) { + int16_t *indices = (int16_t*)(keys->dk_indices); + assert(ix <= 0x7fff); + indices[i] = (int16_t)ix; + } +#if SIZEOF_VOID_P > 4 + else if (log2size >= 32) { + int64_t *indices = (int64_t*)(keys->dk_indices); + indices[i] = ix; + } +#endif + else { + int32_t *indices = (int32_t*)(keys->dk_indices); + assert(ix <= 0x7fffffff); + indices[i] = (int32_t)ix; + } +} + +#endif From 014c2ac9a6f6de25d4e31fe0bdaf819e9c67d24b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 06:47:18 -0300 Subject: [PATCH 22/40] deprecated uu -> base64 --- src/sage/rings/polynomial/pbori/gbrefs.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sage/rings/polynomial/pbori/gbrefs.py b/src/sage/rings/polynomial/pbori/gbrefs.py index 76e3924715d..70dc795cbab 100644 --- a/src/sage/rings/polynomial/pbori/gbrefs.py +++ b/src/sage/rings/polynomial/pbori/gbrefs.py @@ -1,6 +1,6 @@ import gzip from io import StringIO -import uu +import base64 as uu import re from types import ModuleType from .PyPolyBoRi import Polynomial From dc8e155994a870a5e0b01a690a3fec8975197973 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 06:47:34 -0300 Subject: [PATCH 23/40] sage.misc.fpickle: fix for python 3.11 --- src/sage/misc/fpickle.pyx | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/src/sage/misc/fpickle.pyx b/src/sage/misc/fpickle.pyx index 502080e2c10..c5d544765bb 100644 --- a/src/sage/misc/fpickle.pyx +++ b/src/sage/misc/fpickle.pyx @@ -34,6 +34,12 @@ def reduce_code(co): sage: def foo(N): return N+1 sage: sage.misc.fpickle.reduce_code(foo.__code__) (, ...) + + Test that the constructed code matches the original code: + + sage: ctor, args = sage.misc.fpickle.reduce_code(foo.__code__) + sage: ctor(*args) == foo.__code__ + True """ if co.co_freevars or co.co_cellvars: raise ValueError("Cannot pickle code objects from closures") @@ -44,7 +50,12 @@ def reduce_code(co): co_args += (co.co_kwonlyargcount, co.co_nlocals, co.co_stacksize, co.co_flags, co.co_code, co.co_consts, co.co_names, co.co_varnames, co.co_filename, - co.co_name, co.co_firstlineno, co.co_lnotab) + co.co_name) + if sys.version_info.minor >= 11: + co_args += (co.co_qualname, co.co_firstlineno, + co.co_linetable, co.co_exceptiontable) + else: + co_args += (co.co_firstlineno, co.co_lnotab) return (code_ctor, co_args) From 8b0dac2322d4a888c607c56d3b5a72ff71df4147 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 08:15:43 -0300 Subject: [PATCH 24/40] Fix FullArgSpec usage after 9eb08f3afde3266bbd667e196513240a0fe245f4 - `kwonlydefaults` default is `[]` rather than `{}` - `argspec.keywords` changed to `argspec.varkw` - `ArgSpec` changed to `FullArgSpec` --- src/sage/coding/abstract_code.py | 2 +- src/sage/misc/decorators.py | 7 ++++--- src/sage/misc/sageinspect.py | 9 +++++---- 3 files changed, 10 insertions(+), 8 deletions(-) diff --git a/src/sage/coding/abstract_code.py b/src/sage/coding/abstract_code.py index ba2ec68a038..238a165c021 100644 --- a/src/sage/coding/abstract_code.py +++ b/src/sage/coding/abstract_code.py @@ -123,7 +123,7 @@ def _explain_constructor(cl): reqs = "The constructor requires the arguments {}.".format(args) else: reqs = "The constructor requires no arguments." - if argspec.varargs or argspec.keywords: + if argspec.varargs or argspec.varkw: var = "It accepts unspecified arguments as well.\n" else: var = "" diff --git a/src/sage/misc/decorators.py b/src/sage/misc/decorators.py index 311a5105739..271e243050f 100644 --- a/src/sage/misc/decorators.py +++ b/src/sage/misc/decorators.py @@ -423,7 +423,8 @@ def listForNone(l): defaults = (argspec.defaults if argspec.defaults is not None else ()) \ + tuple(self.options.values()) # Note: argspec.defaults is not always a tuple for some reason - return ArgSpec(args, argspec.varargs, argspec.keywords, defaults) + return FullArgSpec(args, argspec.varargs, argspec.varkw, defaults, + kwonlyargs=[], kwonlydefaults=None, annotations={}) wrapper._sage_argspec_ = argspec return wrapper @@ -500,8 +501,8 @@ def argspec(): list(self.options)) defaults = (argspec.defaults or ()) + tuple(self.options.values()) # Note: argspec.defaults is not always a tuple for some reason - return FullArgSpec(args, argspec.varargs, argspec.keywords, defaults, - kwonlyargs=[], kwonlydefaults={}, annotations={}) + return FullArgSpec(args, argspec.varargs, argspec.varkw, defaults, + kwonlyargs=[], kwonlydefaults=None, annotations={}) wrapper._sage_argspec_ = argspec diff --git a/src/sage/misc/sageinspect.py b/src/sage/misc/sageinspect.py index a3821cb56b9..ce9a74f931d 100644 --- a/src/sage/misc/sageinspect.py +++ b/src/sage/misc/sageinspect.py @@ -1137,7 +1137,7 @@ def _sage_getargspec_from_ast(source): return inspect.FullArgSpec(args, vararg, kwarg, tuple(defaults) if defaults else None, - kwonlyargs=[], kwonlydefaults={}, annotations={}) + kwonlyargs=[], kwonlydefaults=None, annotations={}) def _sage_getargspec_cython(source): @@ -1683,7 +1683,8 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return # Note that this may give a wrong result for the constants! try: args, varargs, varkw = inspect.getargs(obj.__code__) - return inspect.FullArgSpec(args, varargs, varkw, obj.__defaults__) + return inspect.FullArgSpec(args, varargs, varkw, obj.__defaults__, + kwonlyargs=[], kwonlydefaults=None, annotations={}) except (TypeError, AttributeError): pass if isclassinstance(obj): @@ -1742,7 +1743,7 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return except AttributeError: defaults = None return inspect.FullArgSpec(args, varargs, varkw, defaults, - kwonlyargs=[], kwonlydefaults={}, annotations={}) + kwonlyargs=[], kwonlydefaults=None, annotations={}) def formatannotation(annotation, base_module=None): @@ -1788,7 +1789,7 @@ def formatannotation(annotation, base_module=None): def sage_formatargspec(args, varargs=None, varkw=None, defaults=None, - kwonlyargs=(), kwonlydefaults={}, annotations={}, + kwonlyargs=(), kwonlydefaults=None, annotations={}, formatarg=str, formatvarargs=lambda name: '*' + name, formatvarkw=lambda name: '**' + name, From db45aebfd6bd8413bec0fda218410d72deacd398 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 07:13:38 -0300 Subject: [PATCH 25/40] warnings: ignore deprecation for 'import cgi' in cython --- src/sage/all.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/sage/all.py b/src/sage/all.py index 6aef26c42a9..92d36d1fd26 100644 --- a/src/sage/all.py +++ b/src/sage/all.py @@ -104,6 +104,11 @@ message='The distutils(.sysconfig module| package) is deprecated', module='Cython|distutils|numpy|sage.env|sage.features') +# triggered by cython 0.29.32 +warnings.filterwarnings('ignore', category=DeprecationWarning, + message="'cgi' is deprecated and slated for removal in Python 3.13", + module='Cython') + ################ end setup warnings ############################### From 664fc008ed50c2f61fb3df3020c0d81b41170628 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 20:39:12 -0300 Subject: [PATCH 26/40] warnings: ignore deprecation for 'import sre_constants' in pyparsing --- src/sage/all.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/sage/all.py b/src/sage/all.py index 92d36d1fd26..ea0712308b4 100644 --- a/src/sage/all.py +++ b/src/sage/all.py @@ -109,6 +109,11 @@ message="'cgi' is deprecated and slated for removal in Python 3.13", module='Cython') +# triggered by pyparsing 2.4.7 +warnings.filterwarnings('ignore', category=DeprecationWarning, + message="module 'sre_constants' is deprecated", + module='pyparsing') + ################ end setup warnings ############################### From 08e1161c23caeeed5ad0e0237df8172eb8806ee5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 22:40:17 -0300 Subject: [PATCH 27/40] warnings: ignore deprecation of importlib.resources.path/read_binary --- src/sage/all.py | 6 ++++++ src/sage/repl/display/formatter.py | 3 +++ 2 files changed, 9 insertions(+) diff --git a/src/sage/all.py b/src/sage/all.py index ea0712308b4..fedf2a17aab 100644 --- a/src/sage/all.py +++ b/src/sage/all.py @@ -114,6 +114,12 @@ message="module 'sre_constants' is deprecated", module='pyparsing') +# importlib.resources.path and ...read_binary are deprecated in python 3.11, +# but the replacement importlib.resources.files needs python 3.9 +warnings.filterwarnings('ignore', category=DeprecationWarning, + message=r'(path|read_binary) is deprecated\. Use files\(\) instead\.', + module='sage.repl.rich_output.output_(graphics|graphics3d|video)') + ################ end setup warnings ############################### diff --git a/src/sage/repl/display/formatter.py b/src/sage/repl/display/formatter.py index 488f0bf2791..7e06656d880 100644 --- a/src/sage/repl/display/formatter.py +++ b/src/sage/repl/display/formatter.py @@ -143,6 +143,9 @@ def format(self, obj, include=None, exclude=None): sage: import os sage: import importlib.resources + sage: import warnings + sage: warnings.filterwarnings('ignore', category=DeprecationWarning, + ....: message=r'path is deprecated\. Use files\(\) instead\.') sage: from sage.repl.rich_output.backend_ipython import BackendIPython sage: backend = BackendIPython() sage: shell = get_test_shell() From 44480f4827e2bc1ed8daf6f4504a22ae6e8be4a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 07:14:01 -0300 Subject: [PATCH 28/40] doctests: fixes due to ArgSpec -> FullArgSpec change --- src/sage/interfaces/singular.py | 3 +- src/sage/libs/singular/standard_options.py | 3 +- src/sage/misc/cachefunc.pyx | 6 +- src/sage/misc/decorators.py | 9 ++- src/sage/misc/lazy_import.pyx | 4 +- src/sage/misc/sageinspect.py | 94 ++++++++++------------ src/sage/parallel/decorate.py | 3 +- src/sage/plot/plot3d/plot3d.py | 18 +++-- src/sage/sets/set_from_iterator.py | 4 +- 9 files changed, 76 insertions(+), 68 deletions(-) diff --git a/src/sage/interfaces/singular.py b/src/sage/interfaces/singular.py index 9c9586d8bc7..1dea77cdff0 100644 --- a/src/sage/interfaces/singular.py +++ b/src/sage/interfaces/singular.py @@ -2734,7 +2734,8 @@ def singular_gb_standard_options(func): sage: P. = QQ[] sage: I = P*[x,y] sage: sage_getargspec(I.interreduced_basis) - ArgSpec(args=['self'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['self'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getsourcelines(I.interreduced_basis) ([' @handle_AA_and_QQbar\n', ' @singular_gb_standard_options\n', diff --git a/src/sage/libs/singular/standard_options.py b/src/sage/libs/singular/standard_options.py index 6797cb05001..5d74da3ce3a 100644 --- a/src/sage/libs/singular/standard_options.py +++ b/src/sage/libs/singular/standard_options.py @@ -117,7 +117,8 @@ def libsingular_gb_standard_options(func): sage: P. = QQ[] sage: I = P*[x,y] sage: sage_getargspec(I.interreduced_basis) - ArgSpec(args=['self'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['self'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getsourcelines(I.interreduced_basis) ([' @handle_AA_and_QQbar\n', ' @singular_gb_standard_options\n', diff --git a/src/sage/misc/cachefunc.pyx b/src/sage/misc/cachefunc.pyx index 72042ef13d6..cea3071115d 100644 --- a/src/sage/misc/cachefunc.pyx +++ b/src/sage/misc/cachefunc.pyx @@ -931,9 +931,9 @@ cdef class CachedFunction(): sage: I = P*[x,y] sage: from sage.misc.sageinspect import sage_getargspec sage: sage_getargspec(I.groebner_basis) # indirect doctest - ArgSpec(args=['self', 'algorithm', 'deg_bound', 'mult_bound', 'prot'], - varargs='args', keywords='kwds', defaults=('', None, None, - False)) + FullArgSpec(args=['self', 'algorithm', 'deg_bound', 'mult_bound', 'prot'], + varargs='args', varkw='kwds', defaults=('', None, None, False), + kwonlyargs=[], kwonlydefaults=None, annotations={}) """ return sage_getargspec(self.f) diff --git a/src/sage/misc/decorators.py b/src/sage/misc/decorators.py index 271e243050f..dd9123f5004 100644 --- a/src/sage/misc/decorators.py +++ b/src/sage/misc/decorators.py @@ -93,7 +93,8 @@ def sage_wraps(wrapped, assigned=WRAPPER_ASSIGNMENTS, updated=WRAPPER_UPDATES): 5 sage: from sage.misc.sageinspect import sage_getargspec sage: sage_getargspec(g) - ArgSpec(args=['x'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['x'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) Demonstrate that it correctly gets the source lines and the source file, which is essential for interactive code edition; note that we @@ -392,7 +393,8 @@ def __call__(self, func): sage: from sage.misc.sageinspect import sage_getargspec sage: sage_getargspec(f) - ArgSpec(args=['arrow_size'], varargs='args', keywords='kwds', defaults=(2,)) + FullArgSpec(args=['arrow_size'], varargs='args', varkw='kwds', defaults=(2,), + kwonlyargs=[], kwonlydefaults=None, annotations={}) """ @sage_wraps(func) def wrapper(*args, **kwds): @@ -460,7 +462,8 @@ def __init__(self, **options): sage: f1 = o(f) sage: from sage.misc.sageinspect import sage_getargspec sage: sage_getargspec(f1) - ArgSpec(args=['rgbcolor'], varargs='args', keywords='kwds', defaults=((0, 0, 1),)) + FullArgSpec(args=['rgbcolor'], varargs='args', varkw='kwds', defaults=((0, 0, 1),), + kwonlyargs=[], kwonlydefaults=None, annotations={}) """ self.options = options self.original_opts = options.pop('__original_opts', False) diff --git a/src/sage/misc/lazy_import.pyx b/src/sage/misc/lazy_import.pyx index 2d4413cd1a3..018078b0cf2 100644 --- a/src/sage/misc/lazy_import.pyx +++ b/src/sage/misc/lazy_import.pyx @@ -351,7 +351,9 @@ cdef class LazyImport(): sage: from sage.misc.lazy_import import LazyImport sage: rm = LazyImport('sage.all', 'random_matrix') sage: rm._sage_argspec_() - ArgSpec(args=['ring', 'nrows', 'ncols', 'algorithm', 'implementation'], varargs='args', keywords='kwds', defaults=(None, 'randomize', None)) + FullArgSpec(args=['ring', 'nrows', 'ncols', 'algorithm', 'implementation'], + varargs='args', varkw='kwds', defaults=(None, 'randomize', None), + kwonlyargs=[], kwonlydefaults=None, annotations={}) """ return sageinspect.sage_getargspec(self.get_object()) diff --git a/src/sage/misc/sageinspect.py b/src/sage/misc/sageinspect.py index ce9a74f931d..619ff6da661 100644 --- a/src/sage/misc/sageinspect.py +++ b/src/sage/misc/sageinspect.py @@ -109,7 +109,7 @@ sage: print(sage_getsource(foo)) # optional - sage.misc.cython def foo(unsigned int x=1, a=')"', b={not (2+1==3):'bar'}, *args, **kwds): return sage: sage_getargspec(foo) # optional - sage.misc.cython - ArgSpec(args=['x', 'a', 'b'], varargs='args', keywords='kwds', defaults=(1, ')"', {False: 'bar'})) + FullArgSpec(args=['x', 'a', 'b'], varargs='args', varkw='kwds', defaults=(1, ')"', {False: 'bar'}), kwonlyargs=[], kwonlydefaults=None, annotations={}) """ @@ -343,7 +343,7 @@ def _extract_embedded_signature(docstring, name): File: sage/misc/nested_class.pyx (starting at line ...) ... sage: _extract_embedded_signature(MainClass.NestedClass.NestedSubClass.dummy.__doc__, 'dummy')[1] - ArgSpec(args=['self', 'x', 'r'], varargs='args', keywords='kwds', defaults=((1, 2, 3.4),)) + FullArgSpec(args=['self', 'x', 'r'], varargs='args', varkw='kwds', defaults=((1, 2, 3.4),), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: _extract_embedded_signature(range.__call__.__doc__, '__call__') ('Call self as a function.', None) """ @@ -1107,22 +1107,18 @@ def _sage_getargspec_from_ast(source): EXAMPLES:: - sage: import warnings - sage: warnings.filterwarnings('ignore', - ....: r'inspect.getargspec\(\) is deprecated', - ....: DeprecationWarning) sage: import inspect, sage.misc.sageinspect as sms sage: from_ast = sms._sage_getargspec_from_ast sage: s = "def f(a, b=2, c={'a': [4, 5.5, False]}, d=(None, True)):\n return" sage: from_ast(s) - ArgSpec(args=['a', 'b', 'c', 'd'], varargs=None, keywords=None, defaults=(2, {'a': [4, 5.5, False]}, (None, True))) + FullArgSpec(args=['a', 'b', 'c', 'd'], varargs=None, varkw=None, defaults=(2, {'a': [4, 5.5, False]}, (None, True)), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: context = {} sage: exec(compile(s, '', 'single'), context) - sage: inspect.getargspec(context['f']) - ArgSpec(args=['a', 'b', 'c', 'd'], varargs=None, keywords=None, defaults=(2, {'a': [4, 5.5, False]}, (None, True))) - sage: from_ast(s) == inspect.getargspec(context['f']) + sage: inspect.getfullargspec(context['f']) + FullArgSpec(args=['a', 'b', 'c', 'd'], varargs=None, varkw=None, defaults=(2, {'a': [4, 5.5, False]}, (None, True)), kwonlyargs=[], kwonlydefaults=None, annotations={}) + sage: from_ast(s) == inspect.getfullargspec(context['f']) True - sage: set(from_ast(sms.sage_getsource(x)) == inspect.getargspec(x) for x in [factor, identity_matrix, Graph.__init__]) + sage: set(from_ast(sms.sage_getsource(x)) == inspect.getfullargspec(x) for x in [factor, identity_matrix, Graph.__init__]) {True} """ ast_args = ast.parse(source.lstrip()).body[0].args @@ -1159,23 +1155,23 @@ def _sage_getargspec_cython(source): sage: from sage.misc.sageinspect import _sage_getargspec_cython as sgc sage: sgc("cpdef double abc(self, Element x=None, Parent base=0):") - ArgSpec(args=['self', 'x', 'base'], varargs=None, keywords=None, defaults=(None, 0)) + FullArgSpec(args=['self', 'x', 'base'], varargs=None, varkw=None, defaults=(None, 0), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc("def __init__(self, x=None, unsigned int base=0):") - ArgSpec(args=['self', 'x', 'base'], varargs=None, keywords=None, defaults=(None, 0)) + FullArgSpec(args=['self', 'x', 'base'], varargs=None, varkw=None, defaults=(None, 0), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc('def o(p, r={}, *q, **s) except? -1:') - ArgSpec(args=['p', 'r'], varargs='q', keywords='s', defaults=({},)) + FullArgSpec(args=['p', 'r'], varargs='q', varkw='s', defaults=({},), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc('cpdef how(r=(None, "u:doing?")):') - ArgSpec(args=['r'], varargs=None, keywords=None, defaults=((None, 'u:doing?'),)) + FullArgSpec(args=['r'], varargs=None, varkw=None, defaults=((None, 'u:doing?'),), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc('def _(x="):"):') - ArgSpec(args=['x'], varargs=None, keywords=None, defaults=('):',)) + FullArgSpec(args=['x'], varargs=None, varkw=None, defaults=('):',), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc('def f(z = {(1, 2, 3): True}):\n return z') - ArgSpec(args=['z'], varargs=None, keywords=None, defaults=({(1, 2, 3): True},)) + FullArgSpec(args=['z'], varargs=None, varkw=None, defaults=({(1, 2, 3): True},), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc('def f(double x, z = {(1, 2, 3): True}):\n return z') - ArgSpec(args=['x', 'z'], varargs=None, keywords=None, defaults=({(1, 2, 3): True},)) + FullArgSpec(args=['x', 'z'], varargs=None, varkw=None, defaults=({(1, 2, 3): True},), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc('def f(*args): pass') - ArgSpec(args=[], varargs='args', keywords=None, defaults=None) + FullArgSpec(args=[], varargs='args', varkw=None, defaults=None, kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sgc('def f(**args): pass') - ArgSpec(args=[], varargs=None, keywords='args', defaults=None) + FullArgSpec(args=[], varargs=None, varkw='args', defaults=None, kwonlyargs=[], kwonlydefaults=None, annotations={}) Some malformed input is detected:: @@ -1207,17 +1203,17 @@ def _sage_getargspec_cython(source): sage: def dummy_python(self, *args, x=1): pass sage: sgc("def dummy_python(self, *args, x=1): pass") - ArgSpec(args=['self', 'x'], varargs='args', keywords=None, defaults=(1,)) + FullArgSpec(args=['self', 'x'], varargs='args', varkw=None, defaults=(1,), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: cython("def dummy_cython(self, *args, x=1): pass") sage: sgc("def dummy_cython(self, *args, x=1): pass") - ArgSpec(args=['self', 'x'], varargs='args', keywords=None, defaults=(1,)) + FullArgSpec(args=['self', 'x'], varargs='args', varkw=None, defaults=(1,), kwonlyargs=[], kwonlydefaults=None, annotations={}) In some examples above, a syntax error was raised when a type definition contains a pointer. An exception is made for ``char*``, since C strings are acceptable input in public Cython functions:: sage: sgc('def f(char *x = "a string", z = {(1,2,3): True}): pass') - ArgSpec(args=['x', 'z'], varargs=None, keywords=None, defaults=('a string', {(1, 2, 3): True})) + FullArgSpec(args=['x', 'z'], varargs=None, varkw=None, defaults=('a string', {(1, 2, 3): True}), kwonlyargs=[], kwonlydefaults=None, annotations={}) AUTHORS: @@ -1503,40 +1499,40 @@ def sage_getargspec(obj): sage: def f(x, y, z=1, t=2, *args, **keywords): ....: pass sage: sage_getargspec(f) - ArgSpec(args=['x', 'y', 'z', 't'], varargs='args', keywords='keywords', defaults=(1, 2)) + FullArgSpec(args=['x', 'y', 'z', 't'], varargs='args', varkw='keywords', defaults=(1, 2), kwonlyargs=[], kwonlydefaults=None, annotations={}) We now run sage_getargspec on some functions from the Sage library:: sage: sage_getargspec(identity_matrix) - ArgSpec(args=['ring', 'n', 'sparse'], varargs=None, keywords=None, defaults=(0, False)) + FullArgSpec(args=['ring', 'n', 'sparse'], varargs=None, varkw=None, defaults=(0, False), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getargspec(factor) - ArgSpec(args=['n', 'proof', 'int_', 'algorithm', 'verbose'], varargs=None, keywords='kwds', defaults=(None, False, 'pari', 0)) + FullArgSpec(args=['n', 'proof', 'int_', 'algorithm', 'verbose'], varargs=None, varkw='kwds', defaults=(None, False, 'pari', 0), kwonlyargs=[], kwonlydefaults=None, annotations={}) In the case of a class or a class instance, the ``ArgSpec`` of the ``__new__``, ``__init__`` or ``__call__`` method is returned:: sage: P. = QQ[] sage: sage_getargspec(P) - ArgSpec(args=['base_ring', 'n', 'names', 'order'], varargs=None, keywords=None, defaults=('degrevlex',)) + FullArgSpec(args=['base_ring', 'n', 'names', 'order'], varargs=None, varkw=None, defaults=('degrevlex',), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getargspec(P.__class__) - ArgSpec(args=['self', 'x'], varargs='args', keywords='kwds', defaults=(0,)) + FullArgSpec(args=['self', 'x'], varargs='args', varkw='kwds', defaults=(0,), kwonlyargs=[], kwonlydefaults=None, annotations={}) The following tests against various bugs that were fixed in :trac:`9976`:: sage: from sage.rings.polynomial.real_roots import bernstein_polynomial_factory_ratlist sage: sage_getargspec(bernstein_polynomial_factory_ratlist.coeffs_bitsize) - ArgSpec(args=['self'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['self'], varargs=None, varkw=None, defaults=None, kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: from sage.rings.polynomial.pbori.pbori import BooleanMonomialMonoid sage: sage_getargspec(BooleanMonomialMonoid.gen) - ArgSpec(args=['self', 'i'], varargs=None, keywords=None, defaults=(0,)) + FullArgSpec(args=['self', 'i'], varargs=None, varkw=None, defaults=(0,), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: I = P*[x,y] sage: sage_getargspec(I.groebner_basis) - ArgSpec(args=['self', 'algorithm', 'deg_bound', 'mult_bound', 'prot'], - varargs='args', keywords='kwds', defaults=('', None, None, False)) + FullArgSpec(args=['self', 'algorithm', 'deg_bound', 'mult_bound', 'prot'], + varargs='args', varkw='kwds', defaults=('', None, None, False), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: cython("cpdef int foo(x,y) except -1: return 1") sage: sage_getargspec(foo) - ArgSpec(args=['x', 'y'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['x', 'y'], varargs=None, varkw=None, defaults=None, kwonlyargs=[], kwonlydefaults=None, annotations={}) If a ``functools.partial`` instance is involved, we see no other meaningful solution than to return the argspec of the underlying function:: @@ -1546,7 +1542,7 @@ def sage_getargspec(obj): sage: import functools sage: f1 = functools.partial(f, 1,c=2) sage: sage_getargspec(f1) - ArgSpec(args=['a', 'b', 'c', 'd'], varargs=None, keywords=None, defaults=(1,)) + FullArgSpec(args=['a', 'b', 'c', 'd'], varargs=None, varkw=None, defaults=(1,), kwonlyargs=[], kwonlydefaults=None, annotations={}) TESTS: @@ -1572,14 +1568,14 @@ def sage_getargspec(obj): sage: print(sage.misc.sageinspect.sage_getsource(O)) def foo(x, a=')"', b={(2+1):'bar', not 1:3, 3<<4:5}): return sage: spec = sage.misc.sageinspect.sage_getargspec(O) - sage: spec.args, spec.varargs, spec.keywords + sage: spec.args, spec.varargs, spec.varkw (['x', 'a', 'b'], None, None) sage: spec.defaults[0] ')"' sage: sorted(spec.defaults[1].items(), key=lambda x: str(x)) [(3, 'bar'), (48, 5), (False, 3)] sage: sage.misc.sageinspect.sage_getargspec(O.__call__) - ArgSpec(args=['self', 'm', 'n'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['self', 'm', 'n'], varargs=None, varkw=None, defaults=None, kwonlyargs=[], kwonlydefaults=None, annotations={}) :: @@ -1588,13 +1584,13 @@ def foo(x, a=')"', b={(2+1):'bar', not 1:3, 3<<4:5}): return def foo(x, a='\')"', b={not (2+1==3):'bar'}): return sage: sage.misc.sageinspect.sage_getargspec(foo) - ArgSpec(args=['x', 'a', 'b'], varargs=None, keywords=None, defaults=('\')"', {False: 'bar'})) + FullArgSpec(args=['x', 'a', 'b'], varargs=None, varkw=None, defaults=('\')"', {False: 'bar'}), kwonlyargs=[], kwonlydefaults=None, annotations={}) The following produced a syntax error before the patch at :trac:`11913`, see also :trac:`26906`:: sage: sage.misc.sageinspect.sage_getargspec(r.lm) # optional - rpy2 - ArgSpec(args=['self'], varargs='args', keywords='kwds', defaults=None) + FullArgSpec(args=['self'], varargs='args', varkw='kwds', defaults=None, kwonlyargs=[], kwonlydefaults=None, annotations={}) The following was fixed in :trac:`16309`:: @@ -1608,23 +1604,23 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return ....: cpdef meet(categories, bint as_list = False, tuple ignore_axioms=(), tuple axioms=()): pass ....: ''') sage: sage_getargspec(Foo.join) - ArgSpec(args=['categories', 'as_list', 'ignore_axioms', 'axioms'], varargs=None, keywords=None, defaults=(False, (), ())) + FullArgSpec(args=['categories', 'as_list', 'ignore_axioms', 'axioms'], varargs=None, varkw=None, defaults=(False, (), ()), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getargspec(Bar.join) - ArgSpec(args=['categories', 'as_list', 'ignore_axioms', 'axioms'], varargs=None, keywords=None, defaults=(False, (), ())) + FullArgSpec(args=['categories', 'as_list', 'ignore_axioms', 'axioms'], varargs=None, varkw=None, defaults=(False, (), ()), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getargspec(Bar.meet) - ArgSpec(args=['categories', 'as_list', 'ignore_axioms', 'axioms'], varargs=None, keywords=None, defaults=(False, (), ())) + FullArgSpec(args=['categories', 'as_list', 'ignore_axioms', 'axioms'], varargs=None, varkw=None, defaults=(False, (), ()), kwonlyargs=[], kwonlydefaults=None, annotations={}) Test that :trac:`17009` is fixed:: sage: sage_getargspec(gap) - ArgSpec(args=['self', 'x', 'name'], varargs=None, keywords=None, defaults=(None,)) + FullArgSpec(args=['self', 'x', 'name'], varargs=None, varkw=None, defaults=(None,), kwonlyargs=[], kwonlydefaults=None, annotations={}) By :trac:`17814`, the following gives the correct answer (previously, the defaults would have been found ``None``):: sage: from sage.misc.nested_class import MainClass sage: sage_getargspec(MainClass.NestedClass.NestedSubClass.dummy) - ArgSpec(args=['self', 'x', 'r'], varargs='args', keywords='kwds', defaults=((1, 2, 3.4),)) + FullArgSpec(args=['self', 'x', 'r'], varargs='args', varkw='kwds', defaults=((1, 2, 3.4),), kwonlyargs=[], kwonlydefaults=None, annotations={}) In :trac:`18249` was decided to return a generic signature for Python builtin functions, rather than to raise an error (which is what Python's @@ -1632,7 +1628,7 @@ def foo(x, a='\')"', b={not (2+1==3):'bar'}): return sage: import inspect sage: sage_getargspec(range) - ArgSpec(args=[], varargs='args', keywords='kwds', defaults=None) + FullArgSpec(args=[], varargs='args', varkw='kwds', defaults=None, kwonlyargs=[], kwonlydefaults=None, annotations={}) Test that :trac:`28524` is fixed:: @@ -1819,14 +1815,10 @@ def sage_formatargspec(args, varargs=None, varkw=None, defaults=None, EXAMPLES:: sage: from sage.misc.sageinspect import sage_formatargspec - sage: from inspect import formatargspec # deprecated in Python 3 sage: args = ['a', 'b', 'c'] sage: defaults = [3] sage: sage_formatargspec(args, defaults=defaults) '(a, b, c=3)' - sage: import warnings; warnings.simplefilter('ignore') # ignore DeprecationWarning - sage: formatargspec(args, defaults=defaults) == sage_formatargspec(args, defaults=defaults) - True """ def formatargandannotation(arg): result = formatarg(arg) @@ -2649,11 +2641,11 @@ def test3(b, # 12 Test _sage_getargspec_cython with multiple default arguments and a type:: sage: _sage_getargspec_cython("def init(self, x=None, base=0):") - ArgSpec(args=['self', 'x', 'base'], varargs=None, keywords=None, defaults=(None, 0)) + FullArgSpec(args=['self', 'x', 'base'], varargs=None, varkw=None, defaults=(None, 0), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: _sage_getargspec_cython("def __init__(self, x=None, base=0):") - ArgSpec(args=['self', 'x', 'base'], varargs=None, keywords=None, defaults=(None, 0)) + FullArgSpec(args=['self', 'x', 'base'], varargs=None, varkw=None, defaults=(None, 0), kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: _sage_getargspec_cython("def __init__(self, x=None, unsigned int base=0, **keys):") - ArgSpec(args=['self', 'x', 'base'], varargs=None, keywords='keys', defaults=(None, 0)) + FullArgSpec(args=['self', 'x', 'base'], varargs=None, varkw='keys', defaults=(None, 0), kwonlyargs=[], kwonlydefaults=None, annotations={}) Test _extract_embedded_position: diff --git a/src/sage/parallel/decorate.py b/src/sage/parallel/decorate.py index c14518af570..3a7152d5ac9 100644 --- a/src/sage/parallel/decorate.py +++ b/src/sage/parallel/decorate.py @@ -243,7 +243,8 @@ def _sage_argspec_(self): ....: return x + y sage: from sage.misc.sageinspect import sage_getargspec sage: sage_getargspec(p(f)) - ArgSpec(args=['x', 'y'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['x', 'y'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) """ from sage.misc.sageinspect import sage_getargspec return sage_getargspec(self.func) diff --git a/src/sage/plot/plot3d/plot3d.py b/src/sage/plot/plot3d/plot3d.py index 64b11a0442a..174765980f7 100644 --- a/src/sage/plot/plot3d/plot3d.py +++ b/src/sage/plot/plot3d/plot3d.py @@ -329,19 +329,24 @@ def to_cartesian(self, func, params=None): sage: t1,t2,t3=T.to_cartesian(lambda a,b: 2*a+b) sage: from sage.misc.sageinspect import sage_getargspec sage: sage_getargspec(t1) - ArgSpec(args=['a', 'b'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['a', 'b'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getargspec(t2) - ArgSpec(args=['a', 'b'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['a', 'b'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: sage_getargspec(t3) - ArgSpec(args=['a', 'b'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['a', 'b'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: def g(a,b): return 2*a+b sage: t1,t2,t3=T.to_cartesian(g) sage: sage_getargspec(t1) - ArgSpec(args=['a', 'b'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['a', 'b'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: t1,t2,t3=T.to_cartesian(2*a+b) sage: sage_getargspec(t1) - ArgSpec(args=['a', 'b'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['a', 'b'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) If we cannot guess the right parameter names, then the parameters are named `u` and `v`:: @@ -352,7 +357,8 @@ def to_cartesian(self, func, params=None): sage: T = _ArbitraryCoordinates((x + y, x - y, z), z,[x,y]) sage: t1,t2,t3=T.to_cartesian(operator.add) sage: sage_getargspec(t1) - ArgSpec(args=['u', 'v'], varargs=None, keywords=None, defaults=None) + FullArgSpec(args=['u', 'v'], varargs=None, varkw=None, defaults=None, + kwonlyargs=[], kwonlydefaults=None, annotations={}) sage: [h(1,2) for h in T.to_cartesian(operator.mul)] [3.0, -1.0, 2.0] sage: [h(u=1,v=2) for h in T.to_cartesian(operator.mul)] diff --git a/src/sage/sets/set_from_iterator.py b/src/sage/sets/set_from_iterator.py index 3a2360383ea..74015c4433d 100644 --- a/src/sage/sets/set_from_iterator.py +++ b/src/sage/sets/set_from_iterator.py @@ -526,7 +526,9 @@ def _sage_argspec_(self): sage: d = Decorator() sage: d.f = find_local_minimum sage: sage_getargspec(d) # indirect doctest - ArgSpec(args=['f', 'a', 'b', 'tol', 'maxfun'], varargs=None, keywords=None, defaults=(1.48e-08, 500)) + FullArgSpec(args=['f', 'a', 'b', 'tol', 'maxfun'], + varargs=None, varkw=None, defaults=(1.48e-08, 500), + kwonlyargs=[], kwonlydefaults=None, annotations={}) """ from sage.misc.sageinspect import sage_getargspec return sage_getargspec(self.f) From 482dd1ac3d2bcaa94dd935e3add1a5165674b146 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 22:12:38 -0300 Subject: [PATCH 29/40] doctests: AssertionError message changed in python 3.11 --- src/sage/misc/lazy_format.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sage/misc/lazy_format.py b/src/sage/misc/lazy_format.py index e3050695b25..b58ea155862 100644 --- a/src/sage/misc/lazy_format.py +++ b/src/sage/misc/lazy_format.py @@ -78,7 +78,7 @@ class LazyFormat(str): ....: LazyFormat("%s is wrong")%IDontLikeBeingPrinted()) Traceback (most recent call last): ... - AssertionError: + AssertionError: ... """ def __mod__(self, args): From 7b6fa565f426e28e14be3b22c202301f9d530e9e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Mon, 31 Oct 2022 22:13:13 -0300 Subject: [PATCH 30/40] doctests: message added more info in python 3.11 --- src/sage/repl/attach.py | 1 + 1 file changed, 1 insertion(+) diff --git a/src/sage/repl/attach.py b/src/sage/repl/attach.py index 39da6ee4acd..20b848e4f04 100644 --- a/src/sage/repl/attach.py +++ b/src/sage/repl/attach.py @@ -54,6 +54,7 @@ exec(code, globals) File ".../foobar.sage....py", line ..., in raise ValueError("third") # this should appear in the source snippet + ... ValueError: third sage: detach(src) """ From ca887536d91cfe6fbb639adf41f1be3291d5f517 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Tornar=C3=ADa?= Date: Sat, 12 Nov 2022 11:52:20 -0300 Subject: [PATCH 31/40] restore support for python 3.8 --- src/sage/cpython/cython_metaclass.h | 7 +++++++ src/sage/libs/gmp/pylong.pyx | 8 ++++++++ 2 files changed, 15 insertions(+) diff --git a/src/sage/cpython/cython_metaclass.h b/src/sage/cpython/cython_metaclass.h index 6487342b71e..da06ab75a6b 100644 --- a/src/sage/cpython/cython_metaclass.h +++ b/src/sage/cpython/cython_metaclass.h @@ -8,6 +8,13 @@ * http://www.gnu.org/licenses/ *****************************************************************************/ +/* Compatibility for python 3.8, can be removed later */ +#if PY_VERSION_HEX < 0x030900A4 && !defined(Py_SET_TYPE) +static inline void _Py_SET_TYPE(PyObject *ob, PyTypeObject *type) +{ ob->ob_type = type; } +#define Py_SET_TYPE(ob, type) _Py_SET_TYPE((PyObject*)(ob), type) +#endif + /* Tuple (None, None, None), initialized as needed */ static PyObject* NoneNoneNone; diff --git a/src/sage/libs/gmp/pylong.pyx b/src/sage/libs/gmp/pylong.pyx index e772b60e3e0..2f7ed35be9d 100644 --- a/src/sage/libs/gmp/pylong.pyx +++ b/src/sage/libs/gmp/pylong.pyx @@ -32,6 +32,14 @@ from cpython.longintrepr cimport _PyLong_New, py_long, digit, PyLong_SHIFT from .mpz cimport * cdef extern from *: + """ + /* Compatibility for python 3.8, can be removed later */ + #if PY_VERSION_HEX < 0x030900A4 && !defined(Py_SET_SIZE) + static inline void _Py_SET_SIZE(PyVarObject *ob, Py_ssize_t size) + { ob->ob_size = size; } + #define Py_SET_SIZE(ob, size) _Py_SET_SIZE((PyVarObject*)(ob), size) + #endif + """ void Py_SET_SIZE(object, Py_ssize_t) int hash_bits """ #ifdef _PyHASH_BITS From 64d11dd9b7f64f4084040e4821cb14cc5c6c1ca7 Mon Sep 17 00:00:00 2001 From: sheerluck Date: Wed, 2 Nov 2022 13:41:55 +0300 Subject: [PATCH 32/40] Trac #?????: tox.ini: Add gentoo-python3.11 --- .github/workflows/docker.yml | 1 + tox.ini | 1 + 2 files changed, 2 insertions(+) diff --git a/.github/workflows/docker.yml b/.github/workflows/docker.yml index 3a90fcee237..d5d1811b70c 100644 --- a/.github/workflows/docker.yml +++ b/.github/workflows/docker.yml @@ -46,6 +46,7 @@ on: "centos-stream-9-python3.9", "gentoo-python3.9", "gentoo-python3.10", + "gentoo-python3.11", "archlinux-latest", "opensuse-15.3-gcc_11-python3.9", "opensuse-15.4-gcc_11-python3.10", diff --git a/tox.ini b/tox.ini index 89541088306..ff9f7611f41 100644 --- a/tox.ini +++ b/tox.ini @@ -299,6 +299,7 @@ setenv = gentoo: BASE_IMAGE=sheerluck/sage-on-gentoo-stage4 gentoo-python3.9: BASE_TAG=latest-py39 gentoo-python3.10: BASE_TAG=latest-py10 + gentoo-python3.11: BASE_TAG=latest-py11 gentoo: IGNORE_MISSING_SYSTEM_PACKAGES=no # # https://hub.docker.com/_/archlinux/ From 57d89ee13db91440436ae0eafc9759ac1706bb44 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Mon, 14 Nov 2022 21:53:59 -0800 Subject: [PATCH 33/40] src/sage/repl/attach.py: Fix doctest markup --- src/sage/repl/attach.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/sage/repl/attach.py b/src/sage/repl/attach.py index 20b848e4f04..3ae3e7ad0cf 100644 --- a/src/sage/repl/attach.py +++ b/src/sage/repl/attach.py @@ -53,8 +53,7 @@ ... exec(code, globals) File ".../foobar.sage....py", line ..., in - raise ValueError("third") # this should appear in the source snippet - ... + raise ValueError("third") # this should appear in the source snippet... ValueError: third sage: detach(src) """ From fd4d697579053a65c7504ee0798fcb9c9e88a9a2 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Mon, 14 Nov 2022 21:56:38 -0800 Subject: [PATCH 34/40] src/sage/misc/fpickle.pyx: Fix docstring markup --- src/sage/misc/fpickle.pyx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sage/misc/fpickle.pyx b/src/sage/misc/fpickle.pyx index c5d544765bb..793041d1422 100644 --- a/src/sage/misc/fpickle.pyx +++ b/src/sage/misc/fpickle.pyx @@ -35,7 +35,7 @@ def reduce_code(co): sage: sage.misc.fpickle.reduce_code(foo.__code__) (, ...) - Test that the constructed code matches the original code: + Test that the constructed code matches the original code:: sage: ctor, args = sage.misc.fpickle.reduce_code(foo.__code__) sage: ctor(*args) == foo.__code__ From d7b029436482fd3ef264892effc8d92dbfdad539 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Tue, 15 Nov 2022 09:47:15 -0800 Subject: [PATCH 35/40] build/pkgs/python3/spkg-configure.m4: Accept system python 3.11 --- build/pkgs/python3/spkg-configure.m4 | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/build/pkgs/python3/spkg-configure.m4 b/build/pkgs/python3/spkg-configure.m4 index 65cc548d8f3..19642b59dd9 100644 --- a/build/pkgs/python3/spkg-configure.m4 +++ b/build/pkgs/python3/spkg-configure.m4 @@ -1,8 +1,8 @@ SAGE_SPKG_CONFIGURE([python3], [ m4_pushdef([MIN_VERSION], [3.8.0]) m4_pushdef([MIN_NONDEPRECATED_VERSION], [3.8.0]) - m4_pushdef([LT_STABLE_VERSION], [3.11.0]) - m4_pushdef([LT_VERSION], [3.11.0]) + m4_pushdef([LT_STABLE_VERSION], [3.12.0]) + m4_pushdef([LT_VERSION], [3.12.0]) AC_ARG_WITH([python], [AS_HELP_STRING([--with-python=PYTHON3], [Python 3 executable to use for the Sage venv; default: python3])]) From 7099e5147174bce8dabe8b2a8ef5931ac60e7f50 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Thu, 24 Nov 2022 13:11:21 -0800 Subject: [PATCH 36/40] Revert "build/pkgs/cypari/patches/trashcan.patch: Remove" This reverts commit 34c5c94963138aa79bcec01a432d2d6a522f28c0. --- build/pkgs/cypari/patches/trashcan.patch | 47 ++++++++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 build/pkgs/cypari/patches/trashcan.patch diff --git a/build/pkgs/cypari/patches/trashcan.patch b/build/pkgs/cypari/patches/trashcan.patch new file mode 100644 index 00000000000..f4918d4cd39 --- /dev/null +++ b/build/pkgs/cypari/patches/trashcan.patch @@ -0,0 +1,47 @@ +commit 78e6dcf937c960c51132132e14f86bddbbe5b7d9 +Author: Jeroen Demeyer +Date: Tue Feb 19 11:50:49 2019 +0100 + + Use the trashcan for Gen + +diff --git a/cypari2/gen.pxd b/cypari2/gen.pxd +index 2ac0669..664d57d 100644 +--- a/cypari2/gen.pxd ++++ b/cypari2/gen.pxd +@@ -1,3 +1,4 @@ ++cimport cython + from cpython.object cimport PyObject + from .types cimport GEN, pari_sp + +diff --git a/cypari2/gen.pyx b/cypari2/gen.pyx +index d268cf1..687f5b2 100644 +--- a/cypari2/gen.pyx ++++ b/cypari2/gen.pyx +@@ -135,6 +135,7 @@ cdef extern from *: + GEN new_nfeltup(GEN nf, GEN x, GEN zknf) + + ++@cython.trashcan(True) + cdef class Gen(Gen_base): + """ + Wrapper for a PARI ``GEN`` with memory management. +diff --git a/cypari2/pari_instance.pyx b/cypari2/pari_instance.pyx +index ba82438..d13bc45 100644 +--- a/cypari2/pari_instance.pyx ++++ b/cypari2/pari_instance.pyx +@@ -243,6 +243,15 @@ Reset default precision for the following tests: + + >>> pari.set_real_precision_bits(53) + ++Test the trashcan mechanism (without the trashcan, this would cause ++a stack overflow): ++ ++>>> pari.allocatemem(2**27, silent=True) ++>>> L = [pari(i) for i in range(2**20)] ++>>> x = pari.Pi() ++>>> del L ++>>> del x ++ + Test that interrupts work properly: + + >>> pari.allocatemem(8000000, 2**29) From 8df4d8b64c62822235748a2b19e64c1d7a8fee31 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Thu, 24 Nov 2022 13:11:32 -0800 Subject: [PATCH 37/40] Revert "build/pkgs/cython/patches/trashcan.patch: Remove" This reverts commit 2df72dfa9ecb5ae76fea92379a751c4d46358dea. --- build/pkgs/cython/patches/trashcan.patch | 180 +++++++++++++++++++++++ 1 file changed, 180 insertions(+) create mode 100644 build/pkgs/cython/patches/trashcan.patch diff --git a/build/pkgs/cython/patches/trashcan.patch b/build/pkgs/cython/patches/trashcan.patch new file mode 100644 index 00000000000..18e1b4a7052 --- /dev/null +++ b/build/pkgs/cython/patches/trashcan.patch @@ -0,0 +1,180 @@ +See https://github.com/cython/cython/pull/2842 + +commit c47c4ef735c4b7f1863b21bbe6f112b06c4aad05 +Author: Jeroen Demeyer +Date: Thu Feb 14 10:02:41 2019 +0100 + + @cython.trashcan directive to enable the Python trashcan for deallocations + +diff --git a/Cython/Compiler/ModuleNode.py b/Cython/Compiler/ModuleNode.py +index d5742de..27fcad6 100644 +--- a/Cython/Compiler/ModuleNode.py ++++ b/Cython/Compiler/ModuleNode.py +@@ -1426,6 +1426,7 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): + + is_final_type = scope.parent_type.is_final_type + needs_gc = scope.needs_gc() ++ needs_trashcan = scope.needs_trashcan() + + weakref_slot = scope.lookup_here("__weakref__") if not scope.is_closure_class_scope else None + if weakref_slot not in scope.var_entries: +@@ -1464,6 +1465,11 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): + # running this destructor. + code.putln("PyObject_GC_UnTrack(o);") + ++ if needs_trashcan: ++ code.globalstate.use_utility_code( ++ UtilityCode.load_cached("PyTrashcan", "ExtensionTypes.c")) ++ code.putln("__Pyx_TRASHCAN_BEGIN(o, %s)" % slot_func_cname) ++ + # call the user's __dealloc__ + self.generate_usr_dealloc_call(scope, code) + +@@ -1537,6 +1543,10 @@ class ModuleNode(Nodes.Node, Nodes.BlockNode): + code.putln("(*Py_TYPE(o)->tp_free)(o);") + if freelist_size: + code.putln("}") ++ ++ if needs_trashcan: ++ code.putln("__Pyx_TRASHCAN_END") ++ + code.putln( + "}") + +diff --git a/Cython/Compiler/Options.py b/Cython/Compiler/Options.py +index d859c19..19d96f1 100644 +--- a/Cython/Compiler/Options.py ++++ b/Cython/Compiler/Options.py +@@ -313,6 +313,7 @@ directive_types = { + 'freelist': int, + 'c_string_type': one_of('bytes', 'bytearray', 'str', 'unicode'), + 'c_string_encoding': normalise_encoding_name, ++ 'trashcan': bool, + } + + for key, val in _directive_defaults.items(): +@@ -355,6 +356,7 @@ directive_scopes = { # defaults to available everywhere + 'np_pythran': ('module',), + 'fast_gil': ('module',), + 'iterable_coroutine': ('module', 'function'), ++ 'trashcan' : ('cclass',), + } + + +diff --git a/Cython/Compiler/PyrexTypes.py b/Cython/Compiler/PyrexTypes.py +index 3b572d6..f200c5f 100644 +--- a/Cython/Compiler/PyrexTypes.py ++++ b/Cython/Compiler/PyrexTypes.py +@@ -1136,6 +1136,7 @@ class PyObjectType(PyrexType): + is_extern = False + is_subclassed = False + is_gc_simple = False ++ builtin_trashcan = False # builtin type using trashcan + + def __str__(self): + return "Python object" +@@ -1190,10 +1191,14 @@ class PyObjectType(PyrexType): + + + builtin_types_that_cannot_create_refcycles = set([ +- 'bool', 'int', 'long', 'float', 'complex', ++ 'object', 'bool', 'int', 'long', 'float', 'complex', + 'bytearray', 'bytes', 'unicode', 'str', 'basestring' + ]) + ++builtin_types_with_trashcan = set([ ++ 'dict', 'list', 'set', 'frozenset', 'tuple', 'type', ++]) ++ + + class BuiltinObjectType(PyObjectType): + # objstruct_cname string Name of PyObject struct +@@ -1218,6 +1223,7 @@ class BuiltinObjectType(PyObjectType): + self.typeptr_cname = "(&%s)" % cname + self.objstruct_cname = objstruct_cname + self.is_gc_simple = name in builtin_types_that_cannot_create_refcycles ++ self.builtin_trashcan = name in builtin_types_with_trashcan + if name == 'type': + # Special case the type type, as many C API calls (and other + # libraries) actually expect a PyTypeObject* for type arguments. +diff --git a/Cython/Compiler/Symtab.py b/Cython/Compiler/Symtab.py +index f7443cb..d44484d 100644 +--- a/Cython/Compiler/Symtab.py ++++ b/Cython/Compiler/Symtab.py +@@ -2085,6 +2085,22 @@ class CClassScope(ClassScope): + return not self.parent_type.is_gc_simple + return False + ++ def needs_trashcan(self): ++ # If the trashcan directive is explicitly set to False, ++ # unconditionally disable the trashcan. ++ directive = self.directives.get('trashcan') ++ if directive is False: ++ return False ++ # If the directive is set to True and the class has Python-valued ++ # C attributes, then it should use the trashcan in tp_dealloc. ++ if directive and self.has_cyclic_pyobject_attrs: ++ return True ++ # Use the trashcan if the base class uses it ++ base_type = self.parent_type.base_type ++ if base_type and base_type.scope is not None: ++ return base_type.scope.needs_trashcan() ++ return self.parent_type.builtin_trashcan ++ + def needs_tp_clear(self): + """ + Do we need to generate an implementation for the tp_clear slot? Can +diff --git a/Cython/Utility/ExtensionTypes.c b/Cython/Utility/ExtensionTypes.c +index 50d0e21..ca2adbe 100644 +--- a/Cython/Utility/ExtensionTypes.c ++++ b/Cython/Utility/ExtensionTypes.c +@@ -74,6 +74,49 @@ static int __Pyx_PyType_Ready(PyTypeObject *t) { + return r; + } + ++/////////////// PyTrashcan.proto /////////////// ++ ++// These macros are taken from https://github.com/python/cpython/pull/11841 ++// Unlike the Py_TRASHCAN_SAFE_BEGIN/Py_TRASHCAN_SAFE_END macros, they ++// allow dealing correctly with subclasses. ++ ++// This requires CPython version >= 2.7.4 ++// (or >= 3.2.4 but we don't support such old Python 3 versions anyway) ++#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x02070400 ++#define __Pyx_TRASHCAN_BEGIN_CONDITION(op, cond) \ ++ do { \ ++ PyThreadState *_tstate = NULL; \ ++ // If "cond" is false, then _tstate remains NULL and the deallocator ++ // is run normally without involving the trashcan ++ if (cond) { \ ++ _tstate = PyThreadState_GET(); \ ++ if (_tstate->trash_delete_nesting >= PyTrash_UNWIND_LEVEL) { \ ++ // Store the object (to be deallocated later) and jump past ++ // Py_TRASHCAN_END, skipping the body of the deallocator ++ _PyTrash_thread_deposit_object((PyObject*)(op)); \ ++ break; \ ++ } \ ++ ++_tstate->trash_delete_nesting; \ ++ } ++ // The body of the deallocator is here. ++#define __Pyx_TRASHCAN_END \ ++ if (_tstate) { \ ++ --_tstate->trash_delete_nesting; \ ++ if (_tstate->trash_delete_later && _tstate->trash_delete_nesting <= 0) \ ++ _PyTrash_thread_destroy_chain(); \ ++ } \ ++ } while (0); ++ ++#define __Pyx_TRASHCAN_BEGIN(op, dealloc) __Pyx_TRASHCAN_BEGIN_CONDITION(op, \ ++ Py_TYPE(op)->tp_dealloc == (destructor)(dealloc)) ++ ++#else ++// The trashcan is a no-op on other Python implementations ++// or old CPython versions ++#define __Pyx_TRASHCAN_BEGIN(op, dealloc) ++#define __Pyx_TRASHCAN_END ++#endif ++ + /////////////// CallNextTpDealloc.proto /////////////// + + static void __Pyx_call_next_tp_dealloc(PyObject* obj, destructor current_tp_dealloc); From 0e458dbd362924aa8f73c6613b566b94e1d42b24 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Thu, 24 Nov 2022 13:23:00 -0800 Subject: [PATCH 38/40] build/pkgs/cython/patches/trashcan.patch: Update using https://github.com/cython/cython/pull/4475 --- build/pkgs/cython/package-version.txt | 2 +- build/pkgs/cython/patches/trashcan.patch | 11 +++++++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/build/pkgs/cython/package-version.txt b/build/pkgs/cython/package-version.txt index 6ca43241e34..babe4be9be1 100644 --- a/build/pkgs/cython/package-version.txt +++ b/build/pkgs/cython/package-version.txt @@ -1 +1 @@ -0.29.32.p1 +0.29.32.p2 diff --git a/build/pkgs/cython/patches/trashcan.patch b/build/pkgs/cython/patches/trashcan.patch index 18e1b4a7052..e1e88ebe465 100644 --- a/build/pkgs/cython/patches/trashcan.patch +++ b/build/pkgs/cython/patches/trashcan.patch @@ -1,5 +1,7 @@ See https://github.com/cython/cython/pull/2842 +and https://github.com/cython/cython/pull/4475 + commit c47c4ef735c4b7f1863b21bbe6f112b06c4aad05 Author: Jeroen Demeyer Date: Thu Feb 14 10:02:41 2019 +0100 @@ -128,7 +130,7 @@ diff --git a/Cython/Utility/ExtensionTypes.c b/Cython/Utility/ExtensionTypes.c index 50d0e21..ca2adbe 100644 --- a/Cython/Utility/ExtensionTypes.c +++ b/Cython/Utility/ExtensionTypes.c -@@ -74,6 +74,49 @@ static int __Pyx_PyType_Ready(PyTypeObject *t) { +@@ -74,6 +74,54 @@ static int __Pyx_PyType_Ready(PyTypeObject *t) { return r; } @@ -140,7 +142,12 @@ index 50d0e21..ca2adbe 100644 + +// This requires CPython version >= 2.7.4 +// (or >= 3.2.4 but we don't support such old Python 3 versions anyway) -+#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x02070400 ++#if CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x03080000 ++// https://github.com/python/cpython/pull/11841 merged so Cython reimplementation ++// is no longer necessary ++#define __Pyx_TRASHCAN_BEGIN Py_TRASHCAN_BEGIN ++#define __Pyx_TRASHCAN_END Py_TRASHCAN_END ++#elif CYTHON_COMPILING_IN_CPYTHON && PY_VERSION_HEX >= 0x02070400 +#define __Pyx_TRASHCAN_BEGIN_CONDITION(op, cond) \ + do { \ + PyThreadState *_tstate = NULL; \ From bc69b339108b007615f9768f273bf03af273c316 Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Thu, 24 Nov 2022 18:17:53 -0800 Subject: [PATCH 39/40] build/pkgs/babel: Update to 2.11.0 --- build/pkgs/babel/checksums.ini | 6 +++--- build/pkgs/babel/package-version.txt | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/build/pkgs/babel/checksums.ini b/build/pkgs/babel/checksums.ini index a98fa598a37..70beeda6613 100644 --- a/build/pkgs/babel/checksums.ini +++ b/build/pkgs/babel/checksums.ini @@ -1,5 +1,5 @@ tarball=Babel-VERSION.tar.gz -sha1=1ce15f82eba5184cabe6ac1491cb58262e27adfd -md5=7166099733d78aa857d74fa50d8ff58c -cksum=1695340328 +sha1=75baeb68d7481a67ba203191aa460c56b0221fda +md5=9ee7784fd452d456206ecd3a12694010 +cksum=227595701 upstream_url=https://pypi.io/packages/source/b/babel/Babel-VERSION.tar.gz diff --git a/build/pkgs/babel/package-version.txt b/build/pkgs/babel/package-version.txt index dedcc7d4335..46b81d815a2 100644 --- a/build/pkgs/babel/package-version.txt +++ b/build/pkgs/babel/package-version.txt @@ -1 +1 @@ -2.9.1 +2.11.0 From c928c2c79788631da240ae0c3713aeafad43854d Mon Sep 17 00:00:00 2001 From: Matthias Koeppe Date: Thu, 24 Nov 2022 18:40:08 -0800 Subject: [PATCH 40/40] src/sage/all.py: Filter out imghdr deprecation warnings --- src/sage/all.py | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/sage/all.py b/src/sage/all.py index fedf2a17aab..037fc482cd4 100644 --- a/src/sage/all.py +++ b/src/sage/all.py @@ -120,6 +120,11 @@ message=r'(path|read_binary) is deprecated\. Use files\(\) instead\.', module='sage.repl.rich_output.output_(graphics|graphics3d|video)') +# triggered by sphinx +warnings.filterwarnings('ignore', category=DeprecationWarning, + message="'imghdr' is deprecated and slated for removal in Python 3.13", + module='sphinx.util.images') + ################ end setup warnings ###############################