- Switch from %primary_interpreter to prjconf-defined

%primary_python (gh#openSUSE/python-rpm-macros#127).

OBS-URL: https://build.opensuse.org/package/show/devel:languages:python:Factory/python310?expand=0&rev=46
This commit is contained in:
Matej Cepl 2022-07-21 14:25:07 +00:00 committed by Git OBS Bridge
parent 84e54ed87f
commit 318a36b4de
2 changed files with 29 additions and 29 deletions

View File

@ -1,3 +1,9 @@
-------------------------------------------------------------------
Thu Jul 21 14:19:52 UTC 2022 - Matej Cepl <mcepl@suse.com>
- Switch from %primary_interpreter to prjconf-defined
%primary_python (gh#openSUSE/python-rpm-macros#127).
------------------------------------------------------------------- -------------------------------------------------------------------
Thu Jun 9 16:43:30 UTC 2022 - Matej Cepl <mcepl@suse.com> Thu Jun 9 16:43:30 UTC 2022 - Matej Cepl <mcepl@suse.com>

View File

@ -36,6 +36,8 @@
%bcond_without general %bcond_without general
%endif %endif
%define python_pkg_name python310
%if 0%{?sle_version} && 0%{?suse_version} < 1550 %if 0%{?sle_version} && 0%{?suse_version} < 1550
# Obsoleting previous "latest" Python versions # Obsoleting previous "latest" Python versions
# Next versions will get more lines like for older versions # Next versions will get more lines like for older versions
@ -59,14 +61,6 @@ Obsoletes: python39%{?1:-%{1}}
%else %else
%define tarversion %{version} %define tarversion %{version}
%endif %endif
%define python_pkg_name python310
# Will provide the python3-* provides
# Will do the /usr/bin/python3 and all the core links
%if 0%{?sle_version} || 0%{?suse_version} < 1550
%define primary_interpreter 0
%else
%define primary_interpreter 1
%endif
# We don't process beta signs well # We don't process beta signs well
%define folderversion 3.10.5 %define folderversion 3.10.5
%define tarname Python-%{tarversion} %define tarname Python-%{tarversion}
@ -224,7 +218,7 @@ Recommends: %{python_pkg_name}-curses
Recommends: %{python_pkg_name}-dbm Recommends: %{python_pkg_name}-dbm
Recommends: %{python_pkg_name}-pip Recommends: %{python_pkg_name}-pip
%obsolete_python_versioned %obsolete_python_versioned
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3 = %{python_version} Provides: python3 = %{python_version}
%endif %endif
%endif %endif
@ -247,7 +241,7 @@ development environment (python3-idle).
Summary: TkInter, a Python Tk Interface Summary: TkInter, a Python Tk Interface
Requires: %{python_pkg_name} = %{version} Requires: %{python_pkg_name} = %{version}
%obsolete_python_versioned tk %obsolete_python_versioned tk
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-tk = %{version} Provides: python3-tk = %{version}
%endif %endif
@ -258,7 +252,7 @@ Python interface to Tk. Tk is the GUI toolkit that comes with Tcl.
Summary: Python Interface to the (N)Curses Library Summary: Python Interface to the (N)Curses Library
Requires: %{python_pkg_name} = %{version} Requires: %{python_pkg_name} = %{version}
%obsolete_python_versioned curses %obsolete_python_versioned curses
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-curses Provides: python3-curses
%endif %endif
@ -270,7 +264,7 @@ Console User Interface.
Summary: Python Interface to the GDBM Library Summary: Python Interface to the GDBM Library
Requires: %{python_pkg_name} = %{version} Requires: %{python_pkg_name} = %{version}
%obsolete_python_versioned dbm %obsolete_python_versioned dbm
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-dbm Provides: python3-dbm
%endif %endif
@ -283,7 +277,7 @@ Summary: An Integrated Development Environment for Python
Requires: %{python_pkg_name} = %{version} Requires: %{python_pkg_name} = %{version}
Requires: %{python_pkg_name}-tk Requires: %{python_pkg_name}-tk
%obsolete_python_versioned idle %obsolete_python_versioned idle
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-idle = %{version} Provides: python3-idle = %{version}
%endif %endif
@ -297,7 +291,7 @@ a debugger.
Summary: Package Documentation for Python 3 Summary: Package Documentation for Python 3
Enhances: %{python_pkg_name} = %{python_version} Enhances: %{python_pkg_name} = %{python_version}
%obsolete_python_versioned doc %obsolete_python_versioned doc
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-doc = %{version} Provides: python3-doc = %{version}
%endif %endif
@ -309,7 +303,7 @@ Python, and Macintosh Module Reference in HTML format.
%package -n %{python_pkg_name}-doc-devhelp %package -n %{python_pkg_name}-doc-devhelp
Summary: Additional Package Documentation for Python 3 in devhelp format Summary: Additional Package Documentation for Python 3 in devhelp format
%obsolete_python_versioned doc-devhelp %obsolete_python_versioned doc-devhelp
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-doc-devhelp = %{version} Provides: python3-doc-devhelp = %{version}
%endif %endif
@ -336,7 +330,7 @@ Provides: %{python_pkg_name}-typing = %{version}
%obsolete_python_versioned typing %obsolete_python_versioned typing
# python3-xml was merged into python3, now moved into -base # python3-xml was merged into python3, now moved into -base
Provides: %{python_pkg_name}-xml = %{version} Provides: %{python_pkg_name}-xml = %{version}
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-asyncio = %{version} Provides: python3-asyncio = %{version}
Obsoletes: python3-asyncio < %{version} Obsoletes: python3-asyncio < %{version}
Provides: python3-base = %{version} Provides: python3-base = %{version}
@ -364,7 +358,7 @@ Requires: %{python_pkg_name}-base = %{version}
Provides: %{python_pkg_name}-2to3 = %{version} Provides: %{python_pkg_name}-2to3 = %{version}
Provides: %{python_pkg_name}-demo = %{version} Provides: %{python_pkg_name}-demo = %{version}
%obsolete_python_versioned tools %obsolete_python_versioned tools
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-2to3 = %{version} Provides: python3-2to3 = %{version}
Provides: python3-demo = %{version} Provides: python3-demo = %{version}
Provides: python3-tools = %{version} Provides: python3-tools = %{version}
@ -380,7 +374,7 @@ and a set of demonstration programs.
Summary: Include Files and Libraries Mandatory for Building Python Modules Summary: Include Files and Libraries Mandatory for Building Python Modules
Requires: %{python_pkg_name}-base = %{version} Requires: %{python_pkg_name}-base = %{version}
%obsolete_python_versioned devel %obsolete_python_versioned devel
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-devel = %{version} Provides: python3-devel = %{version}
%endif %endif
@ -400,7 +394,7 @@ Summary: Unit tests for Python and its standard library
Requires: %{python_pkg_name} = %{version} Requires: %{python_pkg_name} = %{version}
Requires: %{python_pkg_name}-tk = %{version} Requires: %{python_pkg_name}-tk = %{version}
%obsolete_python_versioned testsuite %obsolete_python_versioned testsuite
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
Provides: python3-testsuite = %{version} Provides: python3-testsuite = %{version}
%endif %endif
@ -443,7 +437,7 @@ other applications.
# drop Autoconf version requirement # drop Autoconf version requirement
sed -i 's/^AC_PREREQ/dnl AC_PREREQ/' configure.ac sed -i 's/^AC_PREREQ/dnl AC_PREREQ/' configure.ac
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
# fix shebangs - convert /usr/local/bin/python and /usr/bin/env/python to /usr/bin/python3 # fix shebangs - convert /usr/local/bin/python and /usr/bin/env/python to /usr/bin/python3
for dir in Lib Tools; do for dir in Lib Tools; do
# find *.py, filter to files that contain bad shebangs # find *.py, filter to files that contain bad shebangs
@ -696,7 +690,7 @@ rm -fv %{buildroot}%{dynlib nis}
ln -sf python%{python_version} %{buildroot}%{_bindir}/python3 ln -sf python%{python_version} %{buildroot}%{_bindir}/python3
# decide to ship python3 or just python3.X # decide to ship python3 or just python3.X
%if !%{primary_interpreter} %if "%{python_pkg_name}" != "%{primary_python}"
# base # base
rm %{buildroot}%{_bindir}/python3 rm %{buildroot}%{_bindir}/python3
rm %{buildroot}%{_bindir}/pydoc3 rm %{buildroot}%{_bindir}/pydoc3
@ -714,7 +708,7 @@ ln -s ../../libpython%{python_abi}.so %{buildroot}%{_libdir}/python%{python_vers
rm %{buildroot}%{_bindir}/idle3* rm %{buildroot}%{_bindir}/idle3*
# delete the generic 2to3 binary if we are not primary # delete the generic 2to3 binary if we are not primary
%if !%{primary_interpreter} %if "%{python_pkg_name}" != "%{primary_python}"
rm %{buildroot}%{_bindir}/2to3 rm %{buildroot}%{_bindir}/2to3
%endif %endif
@ -744,7 +738,7 @@ install -m 755 -D Tools/gdb/libpython.py %{buildroot}%{_datadir}/gdb/auto-load/%
#cp Makefile Makefile.pre.in Makefile.pre $RPM_BUILD_ROOT%{sitedir}/config-%{python_abi}/ #cp Makefile Makefile.pre.in Makefile.pre $RPM_BUILD_ROOT%{sitedir}/config-%{python_abi}/
# RPM macros # RPM macros
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
mkdir -p %{buildroot}%{_rpmconfigdir}/macros.d/ mkdir -p %{buildroot}%{_rpmconfigdir}/macros.d/
install -m 644 %{SOURCE7} %{buildroot}%{_rpmconfigdir}/macros.d/ # macros.python3 install -m 644 %{SOURCE7} %{buildroot}%{_rpmconfigdir}/macros.d/ # macros.python3
%endif %endif
@ -846,7 +840,7 @@ echo %{sitedir}/_import_failed > %{buildroot}/%{sitedir}/site-packages/zzzz-impo
%files -n %{python_pkg_name}-tools %files -n %{python_pkg_name}-tools
%defattr(644, root, root, 755) %defattr(644, root, root, 755)
%{sitedir}/turtledemo %{sitedir}/turtledemo
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
%{_bindir}/2to3 %{_bindir}/2to3
%endif %endif
%attr(755, root, root)%{_bindir}/2to3-%{python_version} %attr(755, root, root)%{_bindir}/2to3-%{python_version}
@ -855,7 +849,7 @@ echo %{sitedir}/_import_failed > %{buildroot}/%{sitedir}/site-packages/zzzz-impo
%files -n %{python_pkg_name}-devel %files -n %{python_pkg_name}-devel
%defattr(644, root, root, 755) %defattr(644, root, root, 755)
%{_libdir}/libpython%{python_abi}.so %{_libdir}/libpython%{python_abi}.so
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
%{_libdir}/libpython3.so %{_libdir}/libpython3.so
%endif %endif
%{_libdir}/pkgconfig/* %{_libdir}/pkgconfig/*
@ -863,7 +857,7 @@ echo %{sitedir}/_import_failed > %{buildroot}/%{sitedir}/site-packages/zzzz-impo
%{sitedir}/config-%{python_abi}-* %{sitedir}/config-%{python_abi}-*
%defattr(755, root, root) %defattr(755, root, root)
%{_bindir}/python%{python_abi}-config %{_bindir}/python%{python_abi}-config
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
%{_bindir}/python3-config %{_bindir}/python3-config
%endif %endif
# Own these directories to not depend on gdb # Own these directories to not depend on gdb
@ -896,14 +890,14 @@ echo %{sitedir}/_import_failed > %{buildroot}/%{sitedir}/site-packages/zzzz-impo
%doc %{_docdir}/%{name}/README.rst %doc %{_docdir}/%{name}/README.rst
%license LICENSE %license LICENSE
%doc %{_docdir}/%{name}/README.SUSE %doc %{_docdir}/%{name}/README.SUSE
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
%{_mandir}/man1/python3.1%{?ext_man} %{_mandir}/man1/python3.1%{?ext_man}
%endif %endif
%{_mandir}/man1/python%{python_version}.1%{?ext_man} %{_mandir}/man1/python%{python_version}.1%{?ext_man}
# license text, not a doc because the code can use it at run-time # license text, not a doc because the code can use it at run-time
%{sitedir}/LICENSE.txt %{sitedir}/LICENSE.txt
# RPM macros # RPM macros
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
%{_rpmconfigdir}/macros.d/macros.python3 %{_rpmconfigdir}/macros.d/macros.python3
%endif %endif
# binary parts # binary parts
@ -1008,7 +1002,7 @@ echo %{sitedir}/_import_failed > %{buildroot}/%{sitedir}/site-packages/zzzz-impo
%{sitedir}/_import_failed %{sitedir}/_import_failed
%{sitedir}/site-packages/zzzz-import-failed-hooks.pth %{sitedir}/site-packages/zzzz-import-failed-hooks.pth
# symlinks # symlinks
%if %{primary_interpreter} %if "%{python_pkg_name}" == "%{primary_python}"
%{_bindir}/python3 %{_bindir}/python3
%{_bindir}/pydoc3 %{_bindir}/pydoc3
%endif %endif