- Hardcode the default Python 3 version in the SRPM macros - Provide python38-foo for python3-foo and the other way around (future RHEL compatibility) Fixes https://bugzilla.redhat.com/show_bug.cgi?id=1812087 $ rpm --eval '%python_provide python38-setuptools' Provides: python-setuptools = %{version}-%{release} Provides: python3-setuptools = %{version}-%{release} Obsoletes: python-setuptools < %{version}-%{release} $ rpm --eval '%python_provide python3-setuptools' Provides: python-setuptools = %{version}-%{release} Provides: python38-setuptools = %{version}-%{release} Obsoletes: python-setuptools < %{version}-%{release} $ rpm --eval '%python_provide python39-setuptools' $ rpm --define 'python3_pkgversion 39' --eval '%python_provide python%{python3_pkgversion}-setuptools' To make the implementation of %python_provide easier, any names starting with "python" or "pypy" are recognized as valid arguments. Previously, this was an ERROR: $ rpm --eval '%python_provide pythonista' %python_provide: ERROR: pythonista not recognized. Now it is a no-op. The behavior was never documented and the change is backwards compatible for working spec files.
102 lines
3.8 KiB
Plaintext
102 lines
3.8 KiB
Plaintext
# unversioned macros: used with user defined __python, no longer part of rpm >= 4.15
|
|
# __python is defined to error by default in the srpm macros
|
|
%python_sitelib %(%{__python} -Esc "from distutils.sysconfig import get_python_lib; print(get_python_lib())")
|
|
%python_sitearch %(%{__python} -Esc "from distutils.sysconfig import get_python_lib; print(get_python_lib(1))")
|
|
%python_version %(%{__python} -Esc "import sys; sys.stdout.write('{0.major}.{0.minor}'.format(sys.version_info))")
|
|
%python_version_nodots %(%{__python} -Esc "import sys; sys.stdout.write('{0.major}{0.minor}'.format(sys.version_info))")
|
|
|
|
%py_setup setup.py
|
|
%py_shbang_opts -s
|
|
%py_shbang_opts_nodash %(opts=%{py_shbang_opts}; echo ${opts#-})
|
|
|
|
# Use the slashes after expand so that the command starts on the same line as
|
|
# the macro
|
|
%py_build() %{expand:\\\
|
|
CFLAGS="${CFLAGS:-${RPM_OPT_FLAGS}}" LDFLAGS="${LDFLAGS:-${RPM_LD_FLAGS}}"\\\
|
|
%{__python} %{py_setup} %{?py_setup_args} build --executable="%{__python} %{py_shbang_opts}" %{?*}
|
|
sleep 1
|
|
}
|
|
|
|
%py_build_egg() %{expand:\\\
|
|
CFLAGS="${CFLAGS:-${RPM_OPT_FLAGS}}" LDFLAGS="${LDFLAGS:-${RPM_LD_FLAGS}}"\\\
|
|
%{__python} %{py_setup} %{?py_setup_args} bdist_egg %{?*}
|
|
sleep 1
|
|
}
|
|
|
|
%py_build_wheel() %{expand:\\\
|
|
CFLAGS="${CFLAGS:-${RPM_OPT_FLAGS}}" LDFLAGS="${LDFLAGS:-${RPM_LD_FLAGS}}"\\\
|
|
%{__python} %{py_setup} %{?py_setup_args} bdist_wheel %{?*}
|
|
sleep 1
|
|
}
|
|
|
|
%py_install() %{expand:\\\
|
|
CFLAGS="${CFLAGS:-${RPM_OPT_FLAGS}}" LDFLAGS="${LDFLAGS:-${RPM_LD_FLAGS}}"\\\
|
|
%{__python} %{py_setup} %{?py_setup_args} install -O1 --skip-build --root %{buildroot} %{?*}
|
|
rm -rfv %{buildroot}%{_bindir}/__pycache__
|
|
}
|
|
|
|
%py_install_egg() %{expand:\\\
|
|
mkdir -p %{buildroot}%{python_sitelib}
|
|
easy_install -m --prefix %{buildroot}%{_prefix} -Z dist/*-py%{python_version}.egg %{?*}
|
|
rm -rfv %{buildroot}%{_bindir}/__pycache__
|
|
}
|
|
|
|
%py_install_wheel() %{expand:\\\
|
|
pip install -I dist/%{1} --root %{buildroot} --strip-file-prefix %{buildroot} --no-deps
|
|
rm -rfv %{buildroot}%{_bindir}/__pycache__
|
|
}
|
|
|
|
%python_provide() %{lua:
|
|
function string.starts(String,Start)
|
|
return string.sub(String,1,string.len(Start))==Start
|
|
end
|
|
package = rpm.expand("%{?1}")
|
|
vr = rpm.expand("%{?epoch:%{epoch}:}%{version}-%{release}")
|
|
if (string.starts(package, "python3-")) then
|
|
print("\\nProvides: python-")
|
|
print(string.sub(package,9,string.len(package)))
|
|
print(" = ")
|
|
print(vr)
|
|
print("\\nProvides: python" .. rpm.expand("%{__default_python3_pkgversion}") .. "-")
|
|
print(string.sub(package,9,string.len(package)))
|
|
print(" = ")
|
|
print(vr)
|
|
--Obsoleting the previous default python package (if it doesn't have isa)
|
|
if (string.sub(package, "-1") ~= ")") then
|
|
print("\\nObsoletes: python-")
|
|
print(string.sub(package,9,string.len(package)))
|
|
print(" < ")
|
|
print(vr)
|
|
end
|
|
elseif (string.starts(package, "python" .. rpm.expand("%{__default_python3_pkgversion}") .. "-")) then
|
|
print("\\nProvides: python-")
|
|
l = 8 + string.len(rpm.expand("%{__default_python3_pkgversion}"))
|
|
print(string.sub(package,l,string.len(package)))
|
|
print(" = ")
|
|
print(vr)
|
|
print("\\nProvides: python3-")
|
|
print(string.sub(package,l,string.len(package)))
|
|
print(" = ")
|
|
print(vr)
|
|
--Obsoleting the previous default python package (if it doesn't have isa)
|
|
if (string.sub(package, "-1") ~= ")") then
|
|
print("\\nObsoletes: python-")
|
|
print(string.sub(package,l,string.len(package)))
|
|
print(" < ")
|
|
print(vr)
|
|
end
|
|
elseif (string.starts(package, "python")) then
|
|
--No unversioned provides as other python3 cases are not the default
|
|
elseif (string.starts(package, "pypy")) then
|
|
--No unversioned provides as pypy is not default either
|
|
else
|
|
print("%python_provide: ERROR: ")
|
|
print(package)
|
|
print(" not recognized.")
|
|
end
|
|
}
|
|
|
|
%python_disable_dependency_generator() \
|
|
%undefine __pythondist_requires \
|
|
%{nil}
|