From 80cbd58eb7eac3adfd69ef4851a8d90c92875e11 Mon Sep 17 00:00:00 2001 From: Jerry James Date: Tue, 16 Jan 2024 10:18:12 -0700 Subject: [PATCH 1/8] Update the incompatible pointer patch from the PR --- sympy-incompatible-pointer.patch | 33 ++++++++++++++++++++++---------- sympy.spec | 1 + 2 files changed, 24 insertions(+), 10 deletions(-) diff --git a/sympy-incompatible-pointer.patch b/sympy-incompatible-pointer.patch index b0a7580..2c5a9a8 100644 --- a/sympy-incompatible-pointer.patch +++ b/sympy-incompatible-pointer.patch @@ -5,34 +5,47 @@ wrapper_module_15.c:32:60: error: initialization of ‘void (*)(char **, const n | ^ error: command '/usr/bin/gcc' failed with exit code 1 ---- sympy-sympy-1.12/sympy/utilities/autowrap.py.orig 2023-05-09 17:42:05.000000000 -0600 -+++ sympy-sympy-1.12/sympy/utilities/autowrap.py 2023-11-30 13:26:06.612852361 -0700 -@@ -714,7 +714,7 @@ static PyMethodDef ${module}Methods[] = +diff --git a/sympy/utilities/autowrap.py b/sympy/utilities/autowrap.py +index 566fd2ee21..feff051ded 100644 +--- a/sympy/utilities/autowrap.py ++++ b/sympy/utilities/autowrap.py +@@ -714,7 +714,11 @@ def binary_function(symfunc, expr, **kwargs): _ufunc_outcalls = Template("*((double *)out${outnum}) = ${funcname}(${call_args});") _ufunc_body = Template("""\ --static void ${funcname}_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) ++#ifdef NPY_1_19_API_VERSION +static void ${funcname}_ufunc(char **args, const npy_intp *dimensions, const npy_intp* steps, void* data) ++#else + static void ${funcname}_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) ++#endif { npy_intp i; npy_intp n = dimensions[0]; ---- sympy-sympy-1.12/sympy/utilities/tests/test_autowrap.py.orig 2023-05-09 17:42:05.000000000 -0600 -+++ sympy-sympy-1.12/sympy/utilities/tests/test_autowrap.py 2023-11-30 12:42:03.489842964 -0700 -@@ -284,7 +284,7 @@ static PyMethodDef wrapper_module_%(num) +diff --git a/sympy/utilities/tests/test_autowrap.py b/sympy/utilities/tests/test_autowrap.py +index 2d6d1796d5..acb0e9a5ef 100644 +--- a/sympy/utilities/tests/test_autowrap.py ++++ b/sympy/utilities/tests/test_autowrap.py +@@ -284,7 +284,11 @@ def test_ufuncify_source(): {NULL, NULL, 0, NULL} }; --static void test_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) ++#ifdef NPY_1_19_API_VERSION +static void test_ufunc(char **args, const npy_intp *dimensions, const npy_intp* steps, void* data) ++#else + static void test_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) ++#endif { npy_intp i; npy_intp n = dimensions[0]; -@@ -378,7 +378,7 @@ static PyMethodDef wrapper_module_%(num) +@@ -378,7 +382,11 @@ def test_ufuncify_source_multioutput(): {NULL, NULL, 0, NULL} }; --static void multitest_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) ++#ifdef NPY_1_19_API_VERSION +static void multitest_ufunc(char **args, const npy_intp *dimensions, const npy_intp* steps, void* data) ++#else + static void multitest_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) ++#endif { npy_intp i; npy_intp n = dimensions[0]; diff --git a/sympy.spec b/sympy.spec index 638d570..c98cc0c 100644 --- a/sympy.spec +++ b/sympy.spec @@ -20,6 +20,7 @@ Patch0: %{name}-circuitplot.patch # Adapt to python 3.12 Patch1: %{name}-python3.12.patch # Fix incompatible pointers, which are an error with GCC 14 +# https://github.com/sympy/sympy/pull/25968 Patch2: %{name}-incompatible-pointer.patch # This package used to be noarch, and should still be noarch. However, because From 226a78ea724f921d2daa93629d1805c9b05930ed Mon Sep 17 00:00:00 2001 From: Fedora Release Engineering Date: Sat, 27 Jan 2024 05:04:29 +0000 Subject: [PATCH 2/8] Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild --- sympy.spec | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/sympy.spec b/sympy.spec index c98cc0c..10bae85 100644 --- a/sympy.spec +++ b/sympy.spec @@ -7,7 +7,7 @@ Name: sympy Version: 1.12 -Release: 3%{?dist} +Release: 4%{?dist} Summary: A Python library for symbolic mathematics # The project as a whole is BSD-3-Clause. @@ -244,6 +244,9 @@ fi %{_docdir}/%{name}-doc/html %changelog +* Sat Jan 27 2024 Fedora Release Engineering - 1.12-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild + * Thu Nov 30 2023 Jerry James - 1.12-3 - Fix incompatible pointer types for GCC 14 compatibility From a5e26426688c214e90ba73d6aadc5007cbffef58 Mon Sep 17 00:00:00 2001 From: Jerry James Date: Fri, 22 Mar 2024 10:51:21 -0600 Subject: [PATCH 3/8] Convert to %autorelease and %autochangelog [skip changelog] --- changelog | 361 ++++++++++++++++++++++++++++++++++++++++++++++++++++ sympy.spec | 364 +---------------------------------------------------- 2 files changed, 363 insertions(+), 362 deletions(-) create mode 100644 changelog diff --git a/changelog b/changelog new file mode 100644 index 0000000..fc2cfd9 --- /dev/null +++ b/changelog @@ -0,0 +1,361 @@ +* Sat Jan 27 2024 Fedora Release Engineering - 1.12-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild + +* Thu Nov 30 2023 Jerry James - 1.12-3 +- Fix incompatible pointer types for GCC 14 compatibility + +* Sat Jul 22 2023 Fedora Release Engineering - 1.12-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_39_Mass_Rebuild + +* Thu Jun 29 2023 Jerry James - 1.12-1 +- Version 1.12 +- Add patch for python 3.12 compatibility + +* Thu Jun 29 2023 Python Maint - 1.11.1-5 +- Rebuilt for Python 3.12 + +* Tue Feb 21 2023 Jerry James - 1.11.1-4 +- Fix the antlr4 Recommends (bz 2172030) +- Dynamically generate BuildRequires (to the extent possible) + +* Sat Jan 21 2023 Fedora Release Engineering - 1.11.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_38_Mass_Rebuild + +* Tue Sep 27 2022 Jerry James - 1.11.1-2 +- Do not run antlr on i386 where it doesn't exist +- Be archful so we don't BR a package that doesn't exist on i386 + +* Tue Sep 6 2022 Jerry James - 1.11.1-1 +- Version 1.11.1 +- Convert License tag to SPDX +- Drop upstreamed patches: -tests, -distutils, -signature +- Drop fastcache dependency +- Regenerate ANTLR4 files + +* Sat Jul 23 2022 Fedora Release Engineering - 1.10.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild + +* Wed Jun 15 2022 Python Maint - 1.10.1-2 +- Rebuilt for Python 3.11 + +* Sat Mar 19 2022 Jerry James - 1.10.1-1 +- Version 1.10.1 + +* Thu Mar 17 2022 Jerry James - 1.10-1 +- Version 1.10 +- Drop upstreamed patches: -python3, -png-decoder, -gmpy2-mpq, + and -rational-exponent + +* Sat Jan 22 2022 Fedora Release Engineering - 1.9-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild + +* Fri Oct 8 2021 Jerry James - 1.9-1 +- Version 1.9 +- Drop theano support due to incompatibility with the Fedora version +- Add -tests, -distutils, -gmpy2-mpq, and -rational-exponent patches to + work around test failures + +* Fri Jul 23 2021 Fedora Release Engineering - 1.8-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild + +* Thu Jun 10 2021 Zbigniew Jędrzejewski-Szmek - 1.8-2~bootstrap +- Build in bootstrap mode to work-around missing theano + +* Fri Jun 04 2021 Python Maint - 1.8-2 +- Rebuilt for Python 3.10 + +* Mon Apr 12 2021 Jerry James - 1.8-1 +- Version 1.8 +- Drop the -float patch and only run tests on x86_64 +- Add -circuitplot patch to skip tests that fail with no display +- Drop the -texmacs subpackage; the TeXmacs package ships its own sympy plugin + +* Wed Jan 27 2021 Fedora Release Engineering - 1.7.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Sat Dec 12 2020 Jerry James - 1.7.1-1 +- Version 1.7.1 + +* Thu Dec 10 2020 Jerry James - 1.7-2 +- Fix preview of PNG images (bz 1906363) +- Add missing Recommends needed to preview images (bz 1906363) + +* Sat Nov 28 2020 Jerry James - 1.7-1 +- Version 1.7 + +* Thu Nov 26 2020 Jerry James - 1.6.2-2 +- Update Theano dependency for Theano-PyMC +- Add -theano-pymc patch to adapt + +* Mon Aug 10 2020 Jerry James - 1.6.2-1 +- Version 1.6.2 + +* Wed Jul 29 2020 Fedora Release Engineering - 1.6.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Thu Jul 2 2020 Jerry James - 1.6.1-1 +- Version 1.6.1 +- Drop upstreamed -ast patch + +* Wed Jun 24 2020 Jerry James - 1.6-2 +- Add setuptools BR +- Add -ast patch to fix compilation with python 3.9 + +* Fri May 29 2020 Jerry James - 1.6-1 +- Version 1.6 +- Drop upstreamed -doc and -sample-set patches +- Disable testing on 32-bit systems; too many tests need 64-bit integers + +* Tue May 26 2020 Miro Hrončok - 1.5.1-4 +- Rebuilt for Python 3.9 + +* Mon May 11 2020 Jerry James - 1.5.1-3 +- Add -sample-set patch to fix test failure with python 3.9 + +* Fri Jan 31 2020 Fedora Release Engineering - 1.5.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Wed Jan 8 2020 Jerry James - 1.5.1-1 +- Update to 1.5.1 +- Drop upstreamed patches +- Drop upstreamed workaround for numpy with a release candidate version + +* Mon Nov 4 2019 Jerry James - 1.4-6 +- Fix broken dependencies in the -texmacs subpackage +- Recommend numexpr + +* Fri Sep 13 2019 Jerry James - 1.4-5 +- Add one more patch to fix a python 3.8 warning + +* Sat Aug 24 2019 Robert-André Mauchin - 1.4-4 +- Add patches to fix build with Python 3.8 and Numpy 1.17 + +* Mon Aug 19 2019 Miro Hrončok - 1.4-3 +- Rebuilt for Python 3.8 + +* Sat Jul 27 2019 Fedora Release Engineering - 1.4-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Wed Apr 17 2019 Jerry James - 1.4-1 +- Update to 1.4 +- Drop -factorial patch + +* Sun Feb 03 2019 Fedora Release Engineering - 1.3-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild + +* Wed Jan 30 2019 Jerry James - 1.3-2 +- Add -sympify and -factorial patches to work around test failures + +* Mon Jan 14 2019 Jerry James - 1.3-2 +- Drop Requires from the -doc subpackage (bz 1665767) + +* Sat Oct 6 2018 Jerry James - 1.3-1 +- Update to 1.3 +- Drop upstreamed patches: subexpr-lambdify, test-code-quality, tex-encoding +- Drop the python2 subpackage +- Add -python3 patch to ask cython to generate python 3 code + +* Tue Aug 14 2018 Miro Hrončok - 1.2-2 +- Fix _subexpr method in lambdify + +* Sat Jul 21 2018 Jerry James - 1.2-1 +- Update to 1.2 (bz 1599502) +- Drop upstreamed -python3 patch +- Add -test-code-quality and -doc patches + +* Sat Jul 14 2018 Fedora Release Engineering - 1.1.1-6 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild + +* Tue Jun 19 2018 Miro Hrončok - 1.1.1-5 +- Rebuilt for Python 3.7 + +* Wed Feb 21 2018 Iryna Shcherbina - 1.1.1-4 +- Update Python 2 dependency declarations to new packaging standards + (See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3) + +* Fri Feb 09 2018 Fedora Release Engineering - 1.1.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild + +* Sat Aug 19 2017 Zbigniew Jędrzejewski-Szmek - 1.1.1-2 +- Python 2 binary package renamed to python2-sympy + See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3 + +* Thu Jul 27 2017 Jerry James - 1.1.1-1 +- Update to 1.1.1 (bz 1468405) + +* Thu Jul 27 2017 Fedora Release Engineering - 1.1-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild + +* Mon Jul 24 2017 Jerry James - 1.1-3 +- Fix dependency on python2 from python3 package (bz 1471886) + +* Sat Jul 8 2017 Jerry James - 1.1-2 +- Disable tests that fail due to overflow on some 32-bit architectures + +* Fri Jul 7 2017 Jerry James - 1.1-1 +- Update to 1.1 (bz 1468405) +- All patches have been upstreamed; drop them all + +* Sat Apr 1 2017 Jerry James - 1.0-7 +- Update theano test for theano 0.9 + +* Sat Feb 11 2017 Fedora Release Engineering - 1.0-6 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild + +* Fri Jan 20 2017 Iryna Shcherbina - 1.0-5 +- Make documentation scripts non-executable to avoid + autogenerating Python 2 dependency in sympy-examples (#1360766) + +* Fri Jan 13 2017 Zbigniew Jędrzejewski-Szmek - 1.0-4 +- Run tests in parallel +- Work around some broken tests +- Use python3 in texmacs-sympy (#1360766) + +* Thu Dec 22 2016 Miro Hrončok - 1.0-4 +- Rebuild for Python 3.6 + +* Fri Jul 22 2016 Jerry James - 1.0-3 +- Update the -test patch for the latest matplotlib release + +* Tue Jul 19 2016 Fedora Release Engineering - 1.0-3 +- https://fedoraproject.org/wiki/Changes/Automatic_Provides_for_Python_RPM_Packages + +* Sat Apr 2 2016 Jerry James - 1.0-2 +- Fix bad /usr/bin/env substitution + +* Thu Mar 31 2016 Jerry James - 1.0-1 +- Update to 1.0 +- All patches have been upstreamed; drop them all +- Add -test patch to fix test failures with recent mpmath +- Recommend scipy + +* Fri Feb 05 2016 Fedora Release Engineering - 0.7.6.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild + +* Tue Nov 10 2015 Fedora Release Engineering +- Rebuilt for https://fedoraproject.org/wiki/Changes/python3.5 + +* Thu Sep 3 2015 Jerry James - 0.7.6.1-1 +- Update to 0.7.6.1 (bz 1259971) + +* Mon Jul 6 2015 Zbigniew Jędrzejewski-Szmek - 0.7.6-3 +- Fix failure in tests (#1240097) + +* Fri Jun 19 2015 Fedora Release Engineering - 0.7.6-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild + +* Fri Dec 5 2014 Jerry James - 0.7.6-1 +- Update to 0.7.6 +- Drop upstreamed -test and -is-tangent patches +- Drop obsolete bug workarounds +- Add python(3)-fastcache BR and R +- Recommend python-theano +- Fix executable bits on tm_sympy + +* Tue Sep 16 2014 Jerry James - 0.7.5-4 +- Drop python3-six BR and R now that bz 1140413 is fixed +- Use gmpy2 + +* Wed Sep 3 2014 Jerry James - 0.7.5-3 +- Install both isympy and python3-isympy to comply with packaging standards +- Add -is-tangent patch (bz 1135677) +- Temporarily disable tests that fail due to mpmath bugs (bz 1127796) +- Fix license handling +- Add python3-six BR and R; see bz 1140413 for details + +* Sun Jun 08 2014 Fedora Release Engineering - 0.7.5-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild + +* Mon May 19 2014 Bohuslav Kabrda - 0.7.5-2 +- Rebuilt for https://fedoraproject.org/wiki/Changes/Python_3.4 + +* Thu Mar 13 2014 Jerry James - 0.7.5-1 +- Update to 0.7.5 (bz 1066951) +- Binaries now default to using python3 +- Use py3dir macro to simplify python3 build +- Add BRs for more comprehensive testing +- Workaround bz 1075826 +- Add -test patch to fix Unicode problem in the tests + +* Mon Dec 9 2013 Jerry James - 0.7.4-1 +- Update to 0.7.4 +- Python 2 and 3 sources are now in the same tarball + +* Fri Oct 18 2013 Jerry James - 0.7.3-2 +- Build a python3 subpackage (bz 982759) + +* Fri Aug 2 2013 Jerry James - 0.7.3-1 +- Update to 0.7.3 +- Upstream dropped all tutorial translations +- Add graphviz BR for documentation +- Sources now distributed from github instead of googlecode +- Adapt to versionless _docdir in Rawhide + +* Mon Jun 17 2013 Jerry James - 0.7.2-1 +- Update to 0.7.2 (bz 866044) +- Add python-pyglet R (bz 890312) +- Package the TeXmacs integration +- Build and provide documentation +- Provide examples +- Minor spec file cleanups + +* Fri Feb 15 2013 Fedora Release Engineering - 0.7.1-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_19_Mass_Rebuild + +* Sat Jul 21 2012 Fedora Release Engineering - 0.7.1-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild + +* Sat Jan 14 2012 Fedora Release Engineering - 0.7.1-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_17_Mass_Rebuild + +* Tue Oct 11 2011 Jussi Lehtola - 0.7.1-1 +- Update to 0.7.1. + +* Wed Feb 09 2011 Fedora Release Engineering - 0.6.7-6 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_15_Mass_Rebuild + +* Mon Aug 30 2010 Jussi Lehtola - 0.6.7-5 +- Patch around BZ #564504. + +* Sat Jul 31 2010 David Malcolm - 0.6.7-4 +- fix a python 2.7 incompatibility + +* Thu Jul 22 2010 David Malcolm - 0.6.7-3 +- Rebuilt for https://fedoraproject.org/wiki/Features/Python_2.7/MassRebuild + +* Tue Apr 27 2010 Jussi Lehtola - 0.6.7-2 +- Added %%check phase. + +* Tue Apr 27 2010 Jussi Lehtola - 0.6.7-1 +- Update to 0.6.7. + +* Mon Feb 15 2010 Conrad Meyer - 0.6.6-3 +- Patch around private copy nicely; avoid breakage from trying to replace + a directory with a symlink. + +* Mon Feb 15 2010 Conrad Meyer - 0.6.6-2 +- Remove private copy of system lib 'mpmath' (rhbz #551576). + +* Sun Dec 27 2009 Jussi Lehtola - 0.6.6-1 +- Update to 0.6.6. + +* Sat Nov 07 2009 Jussi Lehtola - 0.6.5-1 +- Update to 0.6.5. + +* Sun Jul 26 2009 Fedora Release Engineering - 0.6.3-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_12_Mass_Rebuild + +* Wed Feb 25 2009 Fedora Release Engineering - 0.6.3-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_11_Mass_Rebuild + +* Thu Dec 4 2008 Conrad Meyer - 0.6.3-1 +- Bump to 0.6.3, supports python 2.6. + +* Sat Nov 29 2008 Ignacio Vazquez-Abrams - 0.6.2-3 +- Rebuild for Python 2.6 + +* Mon Oct 13 2008 Conrad Meyer - 0.6.2-2 +- Patch to remove extraneous shebangs. + +* Sun Oct 12 2008 Conrad Meyer - 0.6.2-1 +- Initial package. diff --git a/sympy.spec b/sympy.spec index 10bae85..c34d739 100644 --- a/sympy.spec +++ b/sympy.spec @@ -7,7 +7,7 @@ Name: sympy Version: 1.12 -Release: 4%{?dist} +Release: %autorelease Summary: A Python library for symbolic mathematics # The project as a whole is BSD-3-Clause. @@ -244,364 +244,4 @@ fi %{_docdir}/%{name}-doc/html %changelog -* Sat Jan 27 2024 Fedora Release Engineering - 1.12-4 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_40_Mass_Rebuild - -* Thu Nov 30 2023 Jerry James - 1.12-3 -- Fix incompatible pointer types for GCC 14 compatibility - -* Sat Jul 22 2023 Fedora Release Engineering - 1.12-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_39_Mass_Rebuild - -* Thu Jun 29 2023 Jerry James - 1.12-1 -- Version 1.12 -- Add patch for python 3.12 compatibility - -* Thu Jun 29 2023 Python Maint - 1.11.1-5 -- Rebuilt for Python 3.12 - -* Tue Feb 21 2023 Jerry James - 1.11.1-4 -- Fix the antlr4 Recommends (bz 2172030) -- Dynamically generate BuildRequires (to the extent possible) - -* Sat Jan 21 2023 Fedora Release Engineering - 1.11.1-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_38_Mass_Rebuild - -* Tue Sep 27 2022 Jerry James - 1.11.1-2 -- Do not run antlr on i386 where it doesn't exist -- Be archful so we don't BR a package that doesn't exist on i386 - -* Tue Sep 6 2022 Jerry James - 1.11.1-1 -- Version 1.11.1 -- Convert License tag to SPDX -- Drop upstreamed patches: -tests, -distutils, -signature -- Drop fastcache dependency -- Regenerate ANTLR4 files - -* Sat Jul 23 2022 Fedora Release Engineering - 1.10.1-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_37_Mass_Rebuild - -* Wed Jun 15 2022 Python Maint - 1.10.1-2 -- Rebuilt for Python 3.11 - -* Sat Mar 19 2022 Jerry James - 1.10.1-1 -- Version 1.10.1 - -* Thu Mar 17 2022 Jerry James - 1.10-1 -- Version 1.10 -- Drop upstreamed patches: -python3, -png-decoder, -gmpy2-mpq, - and -rational-exponent - -* Sat Jan 22 2022 Fedora Release Engineering - 1.9-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_36_Mass_Rebuild - -* Fri Oct 8 2021 Jerry James - 1.9-1 -- Version 1.9 -- Drop theano support due to incompatibility with the Fedora version -- Add -tests, -distutils, -gmpy2-mpq, and -rational-exponent patches to - work around test failures - -* Fri Jul 23 2021 Fedora Release Engineering - 1.8-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_35_Mass_Rebuild - -* Thu Jun 10 2021 Zbigniew Jędrzejewski-Szmek - 1.8-2~bootstrap -- Build in bootstrap mode to work-around missing theano - -* Fri Jun 04 2021 Python Maint - 1.8-2 -- Rebuilt for Python 3.10 - -* Mon Apr 12 2021 Jerry James - 1.8-1 -- Version 1.8 -- Drop the -float patch and only run tests on x86_64 -- Add -circuitplot patch to skip tests that fail with no display -- Drop the -texmacs subpackage; the TeXmacs package ships its own sympy plugin - -* Wed Jan 27 2021 Fedora Release Engineering - 1.7.1-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild - -* Sat Dec 12 2020 Jerry James - 1.7.1-1 -- Version 1.7.1 - -* Thu Dec 10 2020 Jerry James - 1.7-2 -- Fix preview of PNG images (bz 1906363) -- Add missing Recommends needed to preview images (bz 1906363) - -* Sat Nov 28 2020 Jerry James - 1.7-1 -- Version 1.7 - -* Thu Nov 26 2020 Jerry James - 1.6.2-2 -- Update Theano dependency for Theano-PyMC -- Add -theano-pymc patch to adapt - -* Mon Aug 10 2020 Jerry James - 1.6.2-1 -- Version 1.6.2 - -* Wed Jul 29 2020 Fedora Release Engineering - 1.6.1-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild - -* Thu Jul 2 2020 Jerry James - 1.6.1-1 -- Version 1.6.1 -- Drop upstreamed -ast patch - -* Wed Jun 24 2020 Jerry James - 1.6-2 -- Add setuptools BR -- Add -ast patch to fix compilation with python 3.9 - -* Fri May 29 2020 Jerry James - 1.6-1 -- Version 1.6 -- Drop upstreamed -doc and -sample-set patches -- Disable testing on 32-bit systems; too many tests need 64-bit integers - -* Tue May 26 2020 Miro Hrončok - 1.5.1-4 -- Rebuilt for Python 3.9 - -* Mon May 11 2020 Jerry James - 1.5.1-3 -- Add -sample-set patch to fix test failure with python 3.9 - -* Fri Jan 31 2020 Fedora Release Engineering - 1.5.1-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild - -* Wed Jan 8 2020 Jerry James - 1.5.1-1 -- Update to 1.5.1 -- Drop upstreamed patches -- Drop upstreamed workaround for numpy with a release candidate version - -* Mon Nov 4 2019 Jerry James - 1.4-6 -- Fix broken dependencies in the -texmacs subpackage -- Recommend numexpr - -* Fri Sep 13 2019 Jerry James - 1.4-5 -- Add one more patch to fix a python 3.8 warning - -* Sat Aug 24 2019 Robert-André Mauchin - 1.4-4 -- Add patches to fix build with Python 3.8 and Numpy 1.17 - -* Mon Aug 19 2019 Miro Hrončok - 1.4-3 -- Rebuilt for Python 3.8 - -* Sat Jul 27 2019 Fedora Release Engineering - 1.4-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild - -* Wed Apr 17 2019 Jerry James - 1.4-1 -- Update to 1.4 -- Drop -factorial patch - -* Sun Feb 03 2019 Fedora Release Engineering - 1.3-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_30_Mass_Rebuild - -* Wed Jan 30 2019 Jerry James - 1.3-2 -- Add -sympify and -factorial patches to work around test failures - -* Mon Jan 14 2019 Jerry James - 1.3-2 -- Drop Requires from the -doc subpackage (bz 1665767) - -* Sat Oct 6 2018 Jerry James - 1.3-1 -- Update to 1.3 -- Drop upstreamed patches: subexpr-lambdify, test-code-quality, tex-encoding -- Drop the python2 subpackage -- Add -python3 patch to ask cython to generate python 3 code - -* Tue Aug 14 2018 Miro Hrončok - 1.2-2 -- Fix _subexpr method in lambdify - -* Sat Jul 21 2018 Jerry James - 1.2-1 -- Update to 1.2 (bz 1599502) -- Drop upstreamed -python3 patch -- Add -test-code-quality and -doc patches - -* Sat Jul 14 2018 Fedora Release Engineering - 1.1.1-6 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild - -* Tue Jun 19 2018 Miro Hrončok - 1.1.1-5 -- Rebuilt for Python 3.7 - -* Wed Feb 21 2018 Iryna Shcherbina - 1.1.1-4 -- Update Python 2 dependency declarations to new packaging standards - (See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3) - -* Fri Feb 09 2018 Fedora Release Engineering - 1.1.1-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild - -* Sat Aug 19 2017 Zbigniew Jędrzejewski-Szmek - 1.1.1-2 -- Python 2 binary package renamed to python2-sympy - See https://fedoraproject.org/wiki/FinalizingFedoraSwitchtoPython3 - -* Thu Jul 27 2017 Jerry James - 1.1.1-1 -- Update to 1.1.1 (bz 1468405) - -* Thu Jul 27 2017 Fedora Release Engineering - 1.1-4 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild - -* Mon Jul 24 2017 Jerry James - 1.1-3 -- Fix dependency on python2 from python3 package (bz 1471886) - -* Sat Jul 8 2017 Jerry James - 1.1-2 -- Disable tests that fail due to overflow on some 32-bit architectures - -* Fri Jul 7 2017 Jerry James - 1.1-1 -- Update to 1.1 (bz 1468405) -- All patches have been upstreamed; drop them all - -* Sat Apr 1 2017 Jerry James - 1.0-7 -- Update theano test for theano 0.9 - -* Sat Feb 11 2017 Fedora Release Engineering - 1.0-6 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild - -* Fri Jan 20 2017 Iryna Shcherbina - 1.0-5 -- Make documentation scripts non-executable to avoid - autogenerating Python 2 dependency in sympy-examples (#1360766) - -* Fri Jan 13 2017 Zbigniew Jędrzejewski-Szmek - 1.0-4 -- Run tests in parallel -- Work around some broken tests -- Use python3 in texmacs-sympy (#1360766) - -* Thu Dec 22 2016 Miro Hrončok - 1.0-4 -- Rebuild for Python 3.6 - -* Fri Jul 22 2016 Jerry James - 1.0-3 -- Update the -test patch for the latest matplotlib release - -* Tue Jul 19 2016 Fedora Release Engineering - 1.0-3 -- https://fedoraproject.org/wiki/Changes/Automatic_Provides_for_Python_RPM_Packages - -* Sat Apr 2 2016 Jerry James - 1.0-2 -- Fix bad /usr/bin/env substitution - -* Thu Mar 31 2016 Jerry James - 1.0-1 -- Update to 1.0 -- All patches have been upstreamed; drop them all -- Add -test patch to fix test failures with recent mpmath -- Recommend scipy - -* Fri Feb 05 2016 Fedora Release Engineering - 0.7.6.1-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild - -* Tue Nov 10 2015 Fedora Release Engineering -- Rebuilt for https://fedoraproject.org/wiki/Changes/python3.5 - -* Thu Sep 3 2015 Jerry James - 0.7.6.1-1 -- Update to 0.7.6.1 (bz 1259971) - -* Mon Jul 6 2015 Zbigniew Jędrzejewski-Szmek - 0.7.6-3 -- Fix failure in tests (#1240097) - -* Fri Jun 19 2015 Fedora Release Engineering - 0.7.6-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild - -* Fri Dec 5 2014 Jerry James - 0.7.6-1 -- Update to 0.7.6 -- Drop upstreamed -test and -is-tangent patches -- Drop obsolete bug workarounds -- Add python(3)-fastcache BR and R -- Recommend python-theano -- Fix executable bits on tm_sympy - -* Tue Sep 16 2014 Jerry James - 0.7.5-4 -- Drop python3-six BR and R now that bz 1140413 is fixed -- Use gmpy2 - -* Wed Sep 3 2014 Jerry James - 0.7.5-3 -- Install both isympy and python3-isympy to comply with packaging standards -- Add -is-tangent patch (bz 1135677) -- Temporarily disable tests that fail due to mpmath bugs (bz 1127796) -- Fix license handling -- Add python3-six BR and R; see bz 1140413 for details - -* Sun Jun 08 2014 Fedora Release Engineering - 0.7.5-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild - -* Mon May 19 2014 Bohuslav Kabrda - 0.7.5-2 -- Rebuilt for https://fedoraproject.org/wiki/Changes/Python_3.4 - -* Thu Mar 13 2014 Jerry James - 0.7.5-1 -- Update to 0.7.5 (bz 1066951) -- Binaries now default to using python3 -- Use py3dir macro to simplify python3 build -- Add BRs for more comprehensive testing -- Workaround bz 1075826 -- Add -test patch to fix Unicode problem in the tests - -* Mon Dec 9 2013 Jerry James - 0.7.4-1 -- Update to 0.7.4 -- Python 2 and 3 sources are now in the same tarball - -* Fri Oct 18 2013 Jerry James - 0.7.3-2 -- Build a python3 subpackage (bz 982759) - -* Fri Aug 2 2013 Jerry James - 0.7.3-1 -- Update to 0.7.3 -- Upstream dropped all tutorial translations -- Add graphviz BR for documentation -- Sources now distributed from github instead of googlecode -- Adapt to versionless _docdir in Rawhide - -* Mon Jun 17 2013 Jerry James - 0.7.2-1 -- Update to 0.7.2 (bz 866044) -- Add python-pyglet R (bz 890312) -- Package the TeXmacs integration -- Build and provide documentation -- Provide examples -- Minor spec file cleanups - -* Fri Feb 15 2013 Fedora Release Engineering - 0.7.1-4 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_19_Mass_Rebuild - -* Sat Jul 21 2012 Fedora Release Engineering - 0.7.1-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild - -* Sat Jan 14 2012 Fedora Release Engineering - 0.7.1-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_17_Mass_Rebuild - -* Tue Oct 11 2011 Jussi Lehtola - 0.7.1-1 -- Update to 0.7.1. - -* Wed Feb 09 2011 Fedora Release Engineering - 0.6.7-6 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_15_Mass_Rebuild - -* Mon Aug 30 2010 Jussi Lehtola - 0.6.7-5 -- Patch around BZ #564504. - -* Sat Jul 31 2010 David Malcolm - 0.6.7-4 -- fix a python 2.7 incompatibility - -* Thu Jul 22 2010 David Malcolm - 0.6.7-3 -- Rebuilt for https://fedoraproject.org/wiki/Features/Python_2.7/MassRebuild - -* Tue Apr 27 2010 Jussi Lehtola - 0.6.7-2 -- Added %%check phase. - -* Tue Apr 27 2010 Jussi Lehtola - 0.6.7-1 -- Update to 0.6.7. - -* Mon Feb 15 2010 Conrad Meyer - 0.6.6-3 -- Patch around private copy nicely; avoid breakage from trying to replace - a directory with a symlink. - -* Mon Feb 15 2010 Conrad Meyer - 0.6.6-2 -- Remove private copy of system lib 'mpmath' (rhbz #551576). - -* Sun Dec 27 2009 Jussi Lehtola - 0.6.6-1 -- Update to 0.6.6. - -* Sat Nov 07 2009 Jussi Lehtola - 0.6.5-1 -- Update to 0.6.5. - -* Sun Jul 26 2009 Fedora Release Engineering - 0.6.3-3 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_12_Mass_Rebuild - -* Wed Feb 25 2009 Fedora Release Engineering - 0.6.3-2 -- Rebuilt for https://fedoraproject.org/wiki/Fedora_11_Mass_Rebuild - -* Thu Dec 4 2008 Conrad Meyer - 0.6.3-1 -- Bump to 0.6.3, supports python 2.6. - -* Sat Nov 29 2008 Ignacio Vazquez-Abrams - 0.6.2-3 -- Rebuild for Python 2.6 - -* Mon Oct 13 2008 Conrad Meyer - 0.6.2-2 -- Patch to remove extraneous shebangs. - -* Sun Oct 12 2008 Conrad Meyer - 0.6.2-1 -- Initial package. +%autochangelog From 62c2be0673a76fc329325fa070e9f270a66a0bae Mon Sep 17 00:00:00 2001 From: Jerry James Date: Fri, 22 Mar 2024 10:51:57 -0600 Subject: [PATCH 4/8] Fix test failure with python 3.13 (rhbz#2271058) --- sympy-python3.12.patch | 52 ++++++++++++++++++++++++------------------ sympy.spec | 4 +++- 2 files changed, 33 insertions(+), 23 deletions(-) diff --git a/sympy-python3.12.patch b/sympy-python3.12.patch index 5c4a874..2458bc0 100644 --- a/sympy-python3.12.patch +++ b/sympy-python3.12.patch @@ -30,7 +30,7 @@ def visit_Lambda(self, node): args = [self.visit(arg) for arg in node.args.args] --- sympy-sympy-1.12/sympy/parsing/sympy_parser.py.orig 2023-05-09 17:42:05.000000000 -0600 -+++ sympy-sympy-1.12/sympy/parsing/sympy_parser.py 2023-06-29 17:42:24.574014070 -0600 ++++ sympy-sympy-1.12/sympy/parsing/sympy_parser.py 2024-03-22 10:22:05.814313289 -0600 @@ -627,7 +627,9 @@ def factorial_notation(tokens: List[TOKE result: List[TOKEN] = [] nfactorial = 0 @@ -42,62 +42,70 @@ op = tokval if op == '!': nfactorial += 1 -@@ -1135,7 +1137,7 @@ class EvaluateFalseTransformer(ast.NodeT +@@ -1135,9 +1137,7 @@ class EvaluateFalseTransformer(ast.NodeT new_node = ast.Call( func=ast.Name(id=sympy_class, ctx=ast.Load()), args=[left, right], - keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False, ctx=ast.Load()))], - starargs=None, - kwargs=None +- starargs=None, +- kwargs=None ++ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] ) -@@ -1167,8 +1169,8 @@ class EvaluateFalseTransformer(ast.NodeT + return new_node + return node +@@ -1167,10 +1167,8 @@ class EvaluateFalseTransformer(ast.NodeT if isinstance(node.op, ast.Sub): right = ast.Call( func=ast.Name(id='Mul', ctx=ast.Load()), - args=[ast.UnaryOp(op=ast.USub(), operand=ast.Num(1)), right], - keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], +- starargs=None, +- kwargs=None + args=[ast.UnaryOp(op=ast.USub(), operand=ast.Constant(1)), right], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False, ctx=ast.Load()))], - starargs=None, - kwargs=None ++ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] ) -@@ -1178,16 +1180,16 @@ class EvaluateFalseTransformer(ast.NodeT + elif isinstance(node.op, ast.Div): + if isinstance(node.left, ast.UnaryOp): +@@ -1178,18 +1176,14 @@ class EvaluateFalseTransformer(ast.NodeT rev = True left = ast.Call( func=ast.Name(id='Pow', ctx=ast.Load()), - args=[left, ast.UnaryOp(op=ast.USub(), operand=ast.Num(1))], - keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], +- starargs=None, +- kwargs=None + args=[left, ast.UnaryOp(op=ast.USub(), operand=ast.Constant(1))], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False, ctx=ast.Load()))], - starargs=None, - kwargs=None ++ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] ) else: right = ast.Call( func=ast.Name(id='Pow', ctx=ast.Load()), - args=[right, ast.UnaryOp(op=ast.USub(), operand=ast.Num(1))], - keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], +- starargs=None, +- kwargs=None + args=[right, ast.UnaryOp(op=ast.USub(), operand=ast.Constant(1))], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False, ctx=ast.Load()))], - starargs=None, - kwargs=None ++ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] ) -@@ -1197,7 +1199,7 @@ class EvaluateFalseTransformer(ast.NodeT + + if rev: # undo reversal +@@ -1197,9 +1191,7 @@ class EvaluateFalseTransformer(ast.NodeT new_node = ast.Call( func=ast.Name(id=sympy_class, ctx=ast.Load()), args=[left, right], - keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False, ctx=ast.Load()))], - starargs=None, - kwargs=None +- starargs=None, +- kwargs=None ++ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] ) -@@ -1212,7 +1214,7 @@ class EvaluateFalseTransformer(ast.NodeT + + if sympy_class in ('Add', 'Mul'): +@@ -1212,7 +1204,7 @@ class EvaluateFalseTransformer(ast.NodeT def visit_Call(self, node): new_node = self.generic_visit(node) if isinstance(node.func, ast.Name) and node.func.id in self.functions: - new_node.keywords.append(ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))) -+ new_node.keywords.append(ast.keyword(arg='evaluate', value=ast.Constant(value=False, ctx=ast.Load()))) ++ new_node.keywords.append(ast.keyword(arg='evaluate', value=ast.Constant(value=False))) return new_node diff --git a/sympy.spec b/sympy.spec index c34d739..392a7a3 100644 --- a/sympy.spec +++ b/sympy.spec @@ -14,10 +14,12 @@ Summary: A Python library for symbolic mathematics # The files in sympy/parsing/latex are MIT. License: BSD-3-Clause AND MIT URL: https://sympy.org/ -Source0: https://github.com/%{name}/%{name}/archive/%{name}-%{version}.tar.gz +VCS: https://github.com/sympy/sympy +Source0: %{vcs}/archive/%{name}-%{version}.tar.gz # Skip tests that require a display Patch0: %{name}-circuitplot.patch # Adapt to python 3.12 +# https://github.com/sympy/sympy/pull/26386 Patch1: %{name}-python3.12.patch # Fix incompatible pointers, which are an error with GCC 14 # https://github.com/sympy/sympy/pull/25968 From 8b72c8920584f168a653a58a9fe88cf27ca77851 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miro=20Hron=C4=8Dok?= Date: Mon, 10 Jun 2024 22:50:32 +0200 Subject: [PATCH 5/8] Drop unneeded build dependency on sphinx-autobuild sphinx-autobuild is useful for developers, but not needed to build the docs --- sympy.spec | 1 - 1 file changed, 1 deletion(-) diff --git a/sympy.spec b/sympy.spec index 392a7a3..be1a8f2 100644 --- a/sympy.spec +++ b/sympy.spec @@ -59,7 +59,6 @@ BuildRequires: %{py3_dist furo} BuildRequires: %{py3_dist linkify-it-py} BuildRequires: %{py3_dist mpmath} BuildRequires: %{py3_dist numpydoc} -BuildRequires: %{py3_dist sphinx-autobuild} BuildRequires: %{py3_dist sphinx-copybutton} BuildRequires: %{py3_dist sphinx-math-dollar} BuildRequires: %{py3_dist sphinx-reredirects} From b73de553a9a7777d2d59b97e3fcd126fe2321fe4 Mon Sep 17 00:00:00 2001 From: Python Maint Date: Mon, 10 Jun 2024 23:07:43 +0200 Subject: [PATCH 6/8] Rebuilt for Python 3.13 From 29d55a4f0eadb009264dab956f781e4ef0dbc25f Mon Sep 17 00:00:00 2001 From: Jerry James Date: Wed, 12 Jun 2024 12:01:43 -0600 Subject: [PATCH 7/8] Version 1.12.1 - Drop upstreamed python 3.12 patch --- sources | 2 +- sympy-python3.12.patch | 111 ----------------------------------------- sympy.spec | 10 +--- 3 files changed, 3 insertions(+), 120 deletions(-) delete mode 100644 sympy-python3.12.patch diff --git a/sources b/sources index 95d930c..80ecf06 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (sympy-1.12.tar.gz) = 96a89b88f6912d70c56f5bd1903dd3c518963118ff25d033cdcb7da2f260b8ee209d3ab4a4394dd2b5dc0b4585b71ccd55d55c8e5c6e28024cccbedf07ee4360 +SHA512 (sympy-1.12.1.tar.gz) = 5e7642b6e70332f521a3bc58a9c19a64f8eb3e9a6cc6cab63a3e02a9343e31a616f6f437b6c9af601f05fb4f3f69efee1b9811370721a456c14264b97697c965 diff --git a/sympy-python3.12.patch b/sympy-python3.12.patch deleted file mode 100644 index 2458bc0..0000000 --- a/sympy-python3.12.patch +++ /dev/null @@ -1,111 +0,0 @@ ---- sympy-sympy-1.12/sympy/logic/boolalg.py.orig 2023-05-09 17:42:05.000000000 -0600 -+++ sympy-sympy-1.12/sympy/logic/boolalg.py 2023-06-29 16:38:14.568908065 -0600 -@@ -1012,7 +1012,7 @@ class Xor(BooleanFunction): - for j in range(i + 1, len(rel)): - rj, cj = rel[j][:2] - if cj == nc: -- odd = ~odd -+ odd = not odd - break - elif cj == c: - break ---- sympy-sympy-1.12/sympy/parsing/ast_parser.py.orig 2023-05-09 17:42:05.000000000 -0600 -+++ sympy-sympy-1.12/sympy/parsing/ast_parser.py 2023-06-29 17:12:19.620751353 -0600 -@@ -23,7 +23,7 @@ from sympy.core.basic import Basic - from sympy.core.sympify import SympifyError - - from ast import parse, NodeTransformer, Call, Name, Load, \ -- fix_missing_locations, Str, Tuple -+ fix_missing_locations, Constant, Tuple - - class Transform(NodeTransformer): - -@@ -52,7 +52,7 @@ class Transform(NodeTransformer): - elif node.id in ['True', 'False']: - return node - return fix_missing_locations(Call(func=Name('Symbol', Load()), -- args=[Str(node.id)], keywords=[])) -+ args=[Constant(node.id)], keywords=[])) - - def visit_Lambda(self, node): - args = [self.visit(arg) for arg in node.args.args] ---- sympy-sympy-1.12/sympy/parsing/sympy_parser.py.orig 2023-05-09 17:42:05.000000000 -0600 -+++ sympy-sympy-1.12/sympy/parsing/sympy_parser.py 2024-03-22 10:22:05.814313289 -0600 -@@ -627,7 +627,9 @@ def factorial_notation(tokens: List[TOKE - result: List[TOKEN] = [] - nfactorial = 0 - for toknum, tokval in tokens: -- if toknum == ERRORTOKEN: -+ if toknum == OP and tokval == "!": -+ nfactorial += 1 -+ elif toknum == ERRORTOKEN: - op = tokval - if op == '!': - nfactorial += 1 -@@ -1135,9 +1137,7 @@ class EvaluateFalseTransformer(ast.NodeT - new_node = ast.Call( - func=ast.Name(id=sympy_class, ctx=ast.Load()), - args=[left, right], -- keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], -- starargs=None, -- kwargs=None -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] - ) - return new_node - return node -@@ -1167,10 +1167,8 @@ class EvaluateFalseTransformer(ast.NodeT - if isinstance(node.op, ast.Sub): - right = ast.Call( - func=ast.Name(id='Mul', ctx=ast.Load()), -- args=[ast.UnaryOp(op=ast.USub(), operand=ast.Num(1)), right], -- keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], -- starargs=None, -- kwargs=None -+ args=[ast.UnaryOp(op=ast.USub(), operand=ast.Constant(1)), right], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] - ) - elif isinstance(node.op, ast.Div): - if isinstance(node.left, ast.UnaryOp): -@@ -1178,18 +1176,14 @@ class EvaluateFalseTransformer(ast.NodeT - rev = True - left = ast.Call( - func=ast.Name(id='Pow', ctx=ast.Load()), -- args=[left, ast.UnaryOp(op=ast.USub(), operand=ast.Num(1))], -- keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], -- starargs=None, -- kwargs=None -+ args=[left, ast.UnaryOp(op=ast.USub(), operand=ast.Constant(1))], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] - ) - else: - right = ast.Call( - func=ast.Name(id='Pow', ctx=ast.Load()), -- args=[right, ast.UnaryOp(op=ast.USub(), operand=ast.Num(1))], -- keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], -- starargs=None, -- kwargs=None -+ args=[right, ast.UnaryOp(op=ast.USub(), operand=ast.Constant(1))], -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] - ) - - if rev: # undo reversal -@@ -1197,9 +1191,7 @@ class EvaluateFalseTransformer(ast.NodeT - new_node = ast.Call( - func=ast.Name(id=sympy_class, ctx=ast.Load()), - args=[left, right], -- keywords=[ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))], -- starargs=None, -- kwargs=None -+ keywords=[ast.keyword(arg='evaluate', value=ast.Constant(value=False))] - ) - - if sympy_class in ('Add', 'Mul'): -@@ -1212,7 +1204,7 @@ class EvaluateFalseTransformer(ast.NodeT - def visit_Call(self, node): - new_node = self.generic_visit(node) - if isinstance(node.func, ast.Name) and node.func.id in self.functions: -- new_node.keywords.append(ast.keyword(arg='evaluate', value=ast.NameConstant(value=False, ctx=ast.Load()))) -+ new_node.keywords.append(ast.keyword(arg='evaluate', value=ast.Constant(value=False))) - return new_node - - diff --git a/sympy.spec b/sympy.spec index be1a8f2..0528299 100644 --- a/sympy.spec +++ b/sympy.spec @@ -6,7 +6,7 @@ %global debug_package %{nil} Name: sympy -Version: 1.12 +Version: 1.12.1 Release: %autorelease Summary: A Python library for symbolic mathematics @@ -18,12 +18,9 @@ VCS: https://github.com/sympy/sympy Source0: %{vcs}/archive/%{name}-%{version}.tar.gz # Skip tests that require a display Patch0: %{name}-circuitplot.patch -# Adapt to python 3.12 -# https://github.com/sympy/sympy/pull/26386 -Patch1: %{name}-python3.12.patch # Fix incompatible pointers, which are an error with GCC 14 # https://github.com/sympy/sympy/pull/25968 -Patch2: %{name}-incompatible-pointer.patch +Patch1: %{name}-incompatible-pointer.patch # This package used to be noarch, and should still be noarch. However, because # there is no JDK available on i686 anymore, the antlr4 package is also not @@ -99,9 +96,6 @@ Recommends: %{py3_dist numexpr} Recommends: %{py3_dist pyglet} Recommends: %{py3_dist scipy} -# This can be removed when F38 reaches EOL -Obsoletes: sympy-texmacs < 1.8 - %description -n python3-%{name} SymPy aims to become a full-featured computer algebra system (CAS) while keeping the code as simple as possible in order to be From c93a0ad43879a194fda7ff67e6e68650dadc454a Mon Sep 17 00:00:00 2001 From: Jerry James Date: Thu, 11 Jul 2024 10:51:05 -0600 Subject: [PATCH 8/8] Version 1.13.0 - Drop unnecessary circuitplot patch - Drop upstreamed incompatible-pointer patch - Link duplicate documentation files - Run tests on all architectures --- sources | 2 +- sympy-circuitplot.patch | 13 ----- sympy-incompatible-pointer.patch | 51 ------------------- sympy.spec | 86 +++++++++++++++++--------------- 4 files changed, 47 insertions(+), 105 deletions(-) delete mode 100644 sympy-circuitplot.patch delete mode 100644 sympy-incompatible-pointer.patch diff --git a/sources b/sources index 80ecf06..0a3fd19 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (sympy-1.12.1.tar.gz) = 5e7642b6e70332f521a3bc58a9c19a64f8eb3e9a6cc6cab63a3e02a9343e31a616f6f437b6c9af601f05fb4f3f69efee1b9811370721a456c14264b97697c965 +SHA512 (sympy-1.13.0.tar.gz) = 864e0be68bf0c63187d7eeaaa9455a3cea27718e5cf75105e411c7bfadc671928544ec49babe4a513630e8b5d6d45a63c19fc9551ca4ef7c7a0d84c4d62a6e2c diff --git a/sympy-circuitplot.patch b/sympy-circuitplot.patch deleted file mode 100644 index 8cc556a..0000000 --- a/sympy-circuitplot.patch +++ /dev/null @@ -1,13 +0,0 @@ ---- sympy-sympy-1.8/sympy/physics/quantum/tests/test_circuitplot.py.orig 2021-04-09 16:29:50.000000000 -0600 -+++ sympy-sympy-1.8/sympy/physics/quantum/tests/test_circuitplot.py 2021-04-12 13:27:55.241417177 -0600 -@@ -4,7 +4,9 @@ from sympy.physics.quantum.gate import C - from sympy.external import import_module - from sympy.testing.pytest import skip - --mpl = import_module('matplotlib') -+mpl = import_module( -+ 'matplotlib', import_kwargs={'fromlist': ['pyplot']}, -+ catch=(RuntimeError,)) # This is raised in environments that have no display. - - def test_render_label(): - assert render_label('q0') == r'$\left|q0\right\rangle$' diff --git a/sympy-incompatible-pointer.patch b/sympy-incompatible-pointer.patch deleted file mode 100644 index 2c5a9a8..0000000 --- a/sympy-incompatible-pointer.patch +++ /dev/null @@ -1,51 +0,0 @@ -Fixes this error with GCC 14 and numpy 1.19.0 or later: - -wrapper_module_15.c:32:60: error: initialization of ‘void (*)(char **, const npy_intp *, const npy_intp *, void *)’ {aka ‘void (*)(char **, const long int *, const long int *, void *)’} from incompatible pointer type ‘void (*)(char **, npy_intp *, npy_intp *, void *)’ {aka ‘void (*)(char **, long int *, long int *, void *)’} - 32 | PyUFuncGenericFunction wrapped_281000935073472_funcs[1] = {&wrapped_281000935073472_ufunc}; - | ^ -error: command '/usr/bin/gcc' failed with exit code 1 - -diff --git a/sympy/utilities/autowrap.py b/sympy/utilities/autowrap.py -index 566fd2ee21..feff051ded 100644 ---- a/sympy/utilities/autowrap.py -+++ b/sympy/utilities/autowrap.py -@@ -714,7 +714,11 @@ def binary_function(symfunc, expr, **kwargs): - _ufunc_outcalls = Template("*((double *)out${outnum}) = ${funcname}(${call_args});") - - _ufunc_body = Template("""\ -+#ifdef NPY_1_19_API_VERSION -+static void ${funcname}_ufunc(char **args, const npy_intp *dimensions, const npy_intp* steps, void* data) -+#else - static void ${funcname}_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) -+#endif - { - npy_intp i; - npy_intp n = dimensions[0]; -diff --git a/sympy/utilities/tests/test_autowrap.py b/sympy/utilities/tests/test_autowrap.py -index 2d6d1796d5..acb0e9a5ef 100644 ---- a/sympy/utilities/tests/test_autowrap.py -+++ b/sympy/utilities/tests/test_autowrap.py -@@ -284,7 +284,11 @@ def test_ufuncify_source(): - {NULL, NULL, 0, NULL} - }; - -+#ifdef NPY_1_19_API_VERSION -+static void test_ufunc(char **args, const npy_intp *dimensions, const npy_intp* steps, void* data) -+#else - static void test_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) -+#endif - { - npy_intp i; - npy_intp n = dimensions[0]; -@@ -378,7 +382,11 @@ def test_ufuncify_source_multioutput(): - {NULL, NULL, 0, NULL} - }; - -+#ifdef NPY_1_19_API_VERSION -+static void multitest_ufunc(char **args, const npy_intp *dimensions, const npy_intp* steps, void* data) -+#else - static void multitest_ufunc(char **args, npy_intp *dimensions, npy_intp* steps, void* data) -+#endif - { - npy_intp i; - npy_intp n = dimensions[0]; diff --git a/sympy.spec b/sympy.spec index 0528299..457e92b 100644 --- a/sympy.spec +++ b/sympy.spec @@ -5,8 +5,10 @@ # We are archful (see below), but there are no ELF objects in the binary RPM. %global debug_package %{nil} +%global giturl https://github.com/sympy/sympy + Name: sympy -Version: 1.12.1 +Version: 1.13.0 Release: %autorelease Summary: A Python library for symbolic mathematics @@ -14,13 +16,8 @@ Summary: A Python library for symbolic mathematics # The files in sympy/parsing/latex are MIT. License: BSD-3-Clause AND MIT URL: https://sympy.org/ -VCS: https://github.com/sympy/sympy -Source0: %{vcs}/archive/%{name}-%{version}.tar.gz -# Skip tests that require a display -Patch0: %{name}-circuitplot.patch -# Fix incompatible pointers, which are an error with GCC 14 -# https://github.com/sympy/sympy/pull/25968 -Patch1: %{name}-incompatible-pointer.patch +VCS: git:%{giturl}.git +Source: %{giturl}/archive/%{name}-%{version}.tar.gz # This package used to be noarch, and should still be noarch. However, because # there is no JDK available on i686 anymore, the antlr4 package is also not @@ -31,21 +28,22 @@ Patch1: %{name}-incompatible-pointer.patch %ifarch %{java_arches} BuildRequires: antlr4 +BuildRequires: %{py3_dist antlr4-python3-runtime} %endif + +BuildRequires: fdupes BuildRequires: gcc BuildRequires: gcc-c++ BuildRequires: gcc-gfortran BuildRequires: python3-devel +BuildRequires: python3-clang BuildRequires: %{py3_dist cython} BuildRequires: %{py3_dist gmpy2} -BuildRequires: %{py3_dist llvmlite} BuildRequires: %{py3_dist matplotlib} -BuildRequires: %{py3_dist matplotlib-inline} -BuildRequires: %{py3_dist myst-parser} BuildRequires: %{py3_dist numexpr} +BuildRequires: %{py3_dist pycosat} BuildRequires: python3-numpy-f2py BuildRequires: %{py3_dist scipy} -BuildRequires: %{py3_dist wurlitzer} # Documentation BuildRequires: graphviz @@ -54,8 +52,10 @@ BuildRequires: librsvg2-tools BuildRequires: make BuildRequires: %{py3_dist furo} BuildRequires: %{py3_dist linkify-it-py} +BuildRequires: %{py3_dist matplotlib-inline} BuildRequires: %{py3_dist mpmath} -BuildRequires: %{py3_dist numpydoc} +BuildRequires: %{py3_dist myst-parser} +BuildRequires: %{py3_dist sphinx} BuildRequires: %{py3_dist sphinx-copybutton} BuildRequires: %{py3_dist sphinx-math-dollar} BuildRequires: %{py3_dist sphinx-reredirects} @@ -65,10 +65,25 @@ BuildRequires: tex(latex) BuildRequires: tex-dvipng # Tests -BuildRequires: parallel +%ifarch x86_64 +BuildRequires: lfortran +%endif BuildRequires: %{py3_dist autowrap} -BuildRequires: xorg-x11-fonts-Type1 -BuildRequires: xorg-x11-server-Xvfb +BuildRequires: %{py3_dist cloudpickle} +BuildRequires: %{py3_dist ipython} +# FIXME: parser failure in lark on ppc64le +%ifnarch ppc64le +BuildRequires: %{py3_dist lark} +%endif +# FIXME: Crashes in llvmlite on ppc64le and s390x +%ifnarch ppc64le s390x +BuildRequires: %{py3_dist llvmlite} +%endif +BuildRequires: %{py3_dist lxml} +BuildRequires: %{py3_dist pytest-split} +BuildRequires: %{py3_dist pytest-xdist} +BuildRequires: %{py3_dist wurlitzer} +BuildRequires: python3-z3 %global _description\ SymPy aims to become a full-featured computer algebra system (CAS)\ @@ -93,6 +108,7 @@ Recommends: %{py3_dist cython} Recommends: %{py3_dist gmpy2} Recommends: %{py3_dist matplotlib} Recommends: %{py3_dist numexpr} +Recommends: %{py3_dist pycosat} Recommends: %{py3_dist pyglet} Recommends: %{py3_dist scipy} @@ -148,12 +164,6 @@ fixtimestamp() { rm -f $1.orig } -# Do not depend on env -for fil in $(grep -rl "^#\![[:blank:]]*%{_bindir}/env" .); do - sed -i.orig 's,^\(#\![[:blank:]]*%{_bindir}/\)env python,\1python3,' $fil - fixtimestamp $fil -done - # Remove bogus shebangs for fil in sympy/physics/mechanics/models.py \ sympy/physics/optics/polarization.py; do @@ -161,12 +171,22 @@ for fil in sympy/physics/mechanics/models.py \ fixtimestamp $fil done +# Do not depend on env +for fil in $(grep -rl "^#\![[:blank:]]*%{_bindir}/env" .); do + sed -i.orig 's,^\(#\![[:blank:]]*%{_bindir}/\)env python,\1python3,' $fil + fixtimestamp $fil +done + # Use local objects.inv for intersphinx sed -e "s|\('https://mpmath\.org/doc/current/', \)None|\1'%{_docdir}/python-mpmath-doc/html/objects.inv'|" \ -i doc/src/conf.py +# Permit use of antlr4 4.13 +sed -i s'/4\.11/4.13/g' sympy/parsing/autolev/_parse_autolev_antlr.py \ + sympy/parsing/latex/_parse_latex_antlr.py + %generate_buildrequires -%pyproject_buildrequires +%pyproject_buildrequires -x dev %build %ifarch %{java_arches} @@ -197,32 +217,18 @@ chmod -R a-x+X examples chmod 0755 %{buildroot}%{python3_sitelib}/sympy/benchmarks/bench_symbench.py \ %{buildroot}%{python3_sitelib}/sympy/testing/tests/diagnose_imports.py -# Install the HTML documentation +# Install the HTML documentation and link duplicates mkdir -p %{buildroot}%{_docdir}/%{name}-doc cp -a doc/_build/html %{buildroot}%{_docdir}/%{name}-doc rm -f %{buildroot}%{_docdir}/%{name}-doc/html/.buildinfo rm -fr %{buildroot}%{_docdir}/%{name}-doc/i18n +%fdupes %{buildroot}%{_docdir}/%{name}-doc # Try to get rid of pyc files, which aren't useful for documentation find examples/ -name '*.py[co]' -print -delete %check -# Many tests assume they are running on an x86_64 machine. Some assume that -# native 64-bit integers are available. Some assume that 80-bit floating point -# numbers are available. Some assume that certain operations always produce -# numpy float64 values (but produce float32 values on some architectures). I -# used to try to keep the test suite working on all architectures, but it has -# become too much of a burden. Only run tests if we happen to build on x86_64. -# We cannot use %%ifarch here because this is a noarch package. -if [ "$(uname -m)" = "x86_64" ]; then - # Split into many small chunks to reduce waiting in the end-game - jobs=%{?_smp_mflags}; jobs=${jobs#-j}; jobs=$((jobs * 3)) - - xvfb-run -d \ - parallel %{?_smp_mflags} \ - %{python3} bin/test -v --split {}/$jobs \ - ::: $(bash -c "echo {1..$jobs}") -fi +%{python3} bin/test -v --parallel %files -n python3-%{name} -f %{pyproject_files} %doc AUTHORS README.md