148 lines
5.0 KiB
RPMSpec
148 lines
5.0 KiB
RPMSpec
%bcond_without tests
|
|
# Sphinx-generated HTML documentation is not suitable for packaging; see
|
|
# https://bugzilla.redhat.com/show_bug.cgi?id=2006555 for discussion.
|
|
#
|
|
# We can generate PDF documentation as a substitute.
|
|
%bcond_without doc_pdf
|
|
|
|
%global forgeurl https://github.com/numba/llvmlite
|
|
|
|
Name: python-llvmlite
|
|
Version: 0.39.1
|
|
Release: %{autorelease}
|
|
Summary: Lightweight LLVM Python binding for writing JIT compilers
|
|
|
|
%forgemeta
|
|
|
|
# The entire source is BSD-2-Clause, except:
|
|
# - The bundled versioneer.py, and the _version.py it generates (which is
|
|
# packaged) is LicenseRef-Fedora-Public-Domain. In later versions of
|
|
# versioneer, this becomes CC0-1.0 and then Unlicense.
|
|
# Public-domain text added to fedora-license-data in commit
|
|
# 830d88d4d89ee5596839de5b2c1f48426488841f:
|
|
# https://gitlab.com/fedora/legal/fedora-license-data/-/merge_requests/210
|
|
# Additionally, the following does not affect the license of the binary RPMs:
|
|
# - conda-recipes/appveyor/run_with_env.cmd is CC0-1.0; for distribution in
|
|
# the source RPM, it is covered by “Existing uses of CC0-1.0 on code files
|
|
# in Fedora packages prior to 2022-08-01, and subsequent upstream versions
|
|
# of those files in those packages, continue to be allowed. We encourage
|
|
# Fedora package maintainers to ask upstreams to relicense such files.”
|
|
# https://gitlab.com/fedora/legal/fedora-license-data/-/issues/91#note_1151947383
|
|
License: BSD-2-Clause AND LicenseRef-Fedora-Public-Domain
|
|
|
|
URL: http://llvmlite.pydata.org/
|
|
Source0: %{forgesource}
|
|
|
|
# Backport upstream commit:
|
|
# Remove maximum Python version limit
|
|
#
|
|
# Allow any new version of Python for llvmlite. Closes #912
|
|
# https://github.com/numba/llvmlite/commit/9ea5668fff6d0e4099d7907aafae40df5b4c8655
|
|
# Fixes:
|
|
# “Escape hatch” for maximum Python version check
|
|
# https://github.com/numba/llvmlite/issues/912
|
|
# See also:
|
|
# python 3.10 support
|
|
# https://github.com/numba/llvmlite/issues/740
|
|
# To be released in 0.40.0 and 0.41.0. Cherry-picked onto tag v0.39.1:
|
|
Patch: 0001-Remove-maximum-Python-version-limit.patch
|
|
|
|
BuildRequires: pyproject-rpm-macros
|
|
BuildRequires: python3-devel
|
|
# 0.39.1 only supports llvm11
|
|
BuildRequires: llvm11-devel
|
|
BuildRequires: gcc-c++
|
|
|
|
%global _description %{expand:
|
|
llvmlite provides a Python binding to LLVM for use in Numba.
|
|
|
|
Numba previously relied on llvmpy. While llvmpy exposed large parts of the
|
|
LLVM C++ API for direct calls into the LLVM library, llvmlite takes an entirely
|
|
different approach. Llvmlite starts from the needs of a JIT compiler and splits
|
|
them into two decoupled tasks:
|
|
|
|
- Construction of a Module, function by function, Instruction by instruction.
|
|
- Compilation and optimization of the module into machine code.
|
|
|
|
The construction of an LLVM module does not call the LLVM C++ API. Rather, it
|
|
constructs the LLVM intermediate representation (IR) in pure Python. This is
|
|
the role of the IR layer.
|
|
|
|
The compilation of an LLVM module takes the IR in textual form and feeds it
|
|
into LLVM's parsing API. It then returns a thin wrapper around LLVM's C++
|
|
module object. This is the role of the binding layer.
|
|
|
|
Once parsed, the module's source code cannot be modified, which loses the
|
|
flexibility of the direct mapping of C++ APIs into Python that was provided by
|
|
llvmpy but saves a great deal of maintenance.}
|
|
|
|
|
|
%description %_description
|
|
|
|
%package -n python3-llvmlite
|
|
Summary: %{summary}
|
|
|
|
|
|
%description -n python3-llvmlite %_description
|
|
|
|
%package doc
|
|
Summary: %{summary}
|
|
%if %{with doc_pdf}
|
|
BuildRequires: make
|
|
BuildRequires: python3dist(sphinx)
|
|
BuildRequires: python3-sphinx-latex
|
|
BuildRequires: latexmk
|
|
# The HTML theme is imported in conf.py even when not generating HTML
|
|
BuildRequires: python3dist(sphinx-rtd-theme)
|
|
%endif
|
|
|
|
%description doc
|
|
Documentation for %{name}.
|
|
|
|
%prep
|
|
%forgeautosetup -p1
|
|
|
|
# increase verbosity of tests to 2
|
|
sed -i 's/\(def run_tests.*verbosity=\)1/\12/' llvmlite/tests/__init__.py
|
|
|
|
# Comment out to remove /usr/bin/env shebangs
|
|
# Can use something similar to correct/remove /usr/bin/python shebangs also
|
|
# find . -type f -name "*.py" -exec sed -i '/^#![ ]*\/usr\/bin\/env.*$/ d' {} 2>/dev/null ';'
|
|
|
|
# No network access
|
|
echo 'intersphinx_mapping.clear()' >> docs/source/conf.py
|
|
|
|
%generate_buildrequires
|
|
%pyproject_buildrequires
|
|
|
|
%build
|
|
export LLVM_CONFIG="%{_libdir}/llvm11/bin/llvm-config"
|
|
%pyproject_wheel
|
|
|
|
%if %{with doc_pdf}
|
|
%make_build -C docs latex SPHINXOPTS='%{?_smp_mflags}'
|
|
%make_build -C docs/_build/latex LATEXMKOPTS='-quiet'
|
|
%endif
|
|
|
|
%install
|
|
%pyproject_install
|
|
%pyproject_save_files llvmlite
|
|
|
|
%check
|
|
%if %{with tests}
|
|
LD_LIBRARY_PATH="%{buildroot}%{python3_sitearch}/llvmlite/binding/" PYTHONPATH="$PYTHONPATH:%{buildroot}%{python3_sitearch}:%{buildroot}%{python3_sitelib}" %{python3} runtests.py
|
|
%endif
|
|
|
|
%files -n python3-llvmlite -f %{pyproject_files}
|
|
%doc CHANGE_LOG README.rst
|
|
|
|
%files doc
|
|
%license LICENSE
|
|
%doc examples/
|
|
%if %{with doc_pdf}
|
|
%doc docs/_build/latex/llvmlite.pdf
|
|
%endif
|
|
|
|
%changelog
|
|
%autochangelog
|