diff --git a/.gitignore b/.gitignore index bb9cfad..1ab33d3 100644 --- a/.gitignore +++ b/.gitignore @@ -27,3 +27,4 @@ /eigen-3.3.7.tar.bz2 /eigen-3.3.8.tar.bz2 /eigen-3.3.9.tar.bz2 +/eigen-3.4.0.tar.bz2 diff --git a/eigen3.spec b/eigen3.spec index f7d1a73..1adfd0d 100644 --- a/eigen3.spec +++ b/eigen3.spec @@ -10,16 +10,13 @@ %endif -%if 0%{?fedora} >= 33 +%if 0%{?fedora} >= 33 || 0%{?rhel} >= 9 %global blaslib flexiblas +%global cmake_blas_flags -DBLA_VENDOR=FlexiBLAS %else %global blaslib openblas -%endif - -%if 0%{?rhel} >= 8 -%bcond_with qt -%else -%bcond_without qt +%global blasvar o +%global cmake_blas_flags -DBLAS_LIBRARIES=%{_libdir}/lib%{blaslib}%{blasvar}.so %endif %bcond_with sparsehash @@ -29,18 +26,14 @@ %bcond_with metis Name: eigen3 -Version: 3.3.9 -Release: 8%{?dist} +Version: 3.4.0 +Release: 1%{?dist} Summary: A lightweight C++ template library for vector and matrix math -License: MPLv2.0 and LGPLv2+ and BSD and Minpack +License: ASL 2.0 and MPLv2.0 and LGPLv2+ and BSD and Minpack URL: http://eigen.tuxfamily.org/index.php?title=Main_Page Source0: https://gitlab.com/libeigen/eigen/-/archive/%{version}/eigen-%{version}.tar.bz2 -# Backport fix for conflicting declarations of log1p -# https://gitlab.com/libeigen/eigen/-/commit/d55d392e7b1136655b4223bea8e99cb2fe0a8afd.patch -Patch0: eigen3_logp.patch - BuildRequires: %{blaslib}-devel BuildRequires: fftw-devel BuildRequires: gmp-devel @@ -50,9 +43,6 @@ BuildRequires: mpfr-devel %{?with_suitesparse:BuildRequires: suitesparse-devel} BuildRequires: gcc-gfortran %{?with_SuperLU:BuildRequires: SuperLU-devel} -%if %{with qt} -BuildRequires: qt-devel -%endif %{?with_scotch:BuildRequires: scotch-devel} %{?with_metis:BuildRequires: metis-devel} @@ -93,12 +83,13 @@ Developer documentation for Eigen. %build %cmake \ - -DINCLUDE_INSTALL_DIR=include/%{name} \ - -DBLAS_LIBRARIES="-l%{blaslib}" \ + -DINCLUDE_INSTALL_DIR=%{_includedir}/%{name} \ + %{cmake_blas_flags} \ %{?with_SuperLU:-DSUPERLU_INCLUDES=%{_includedir}/SuperLU} \ %{?with_scotch:-DSCOTCH_INCLUDES=%{_includedir} -DSCOTCH_LIBRARIES="scotch"} \ %{?with_metis:-DMETIS_INCLUDES=%{_includedir} -DMETIS_LIBRARIES="metis"} \ - -DCMAKEPACKAGE_INSTALL_DIR=share/cmake/%{name} + -DCMAKEPACKAGE_INSTALL_DIR=%{_datadir}/cmake/%{name} \ + -DEIGEN_TEST_CXX11=ON %cmake_build %cmake_build --target doc @@ -112,14 +103,13 @@ rm -f %{_vpath_builddir}/doc/html/unsupported/installdox %check -# Run tests but make failures non-fatal. Note that upstream doesn't expect the -# tests to pass consistently since they're seeded randomly. +# Test fail to build due to compiler crashes #cmake_build --target buildtests -#cmake_build --target test -- test ARGS="-V" || : +#ctest %files devel -%license COPYING.README COPYING.BSD COPYING.MPL2 COPYING.LGPL COPYING.MINPACK +%license COPYING.README COPYING.APACHE COPYING.BSD COPYING.MPL2 COPYING.GPL COPYING.LGPL COPYING.MINPACK %{_includedir}/%{name} %{_datadir}/cmake/%{name} %{_datadir}/pkgconfig/%{name}.pc @@ -129,6 +119,10 @@ rm -f %{_vpath_builddir}/doc/html/unsupported/installdox %changelog +* Wed Feb 16 2022 Jiri Kucera - 3.4.0-1 +- Update to 3.4.0 + Resolves: #2032423 + * Mon Aug 09 2021 Mohan Boddu - 3.3.9-8 - Rebuilt for IMA sigs, glibc 2.34, aarch64 flags Related: rhbz#1991688 diff --git a/eigen3_logp.patch b/eigen3_logp.patch deleted file mode 100644 index 5ebfa20..0000000 --- a/eigen3_logp.patch +++ /dev/null @@ -1,27 +0,0 @@ -diff -rupN --no-dereference eigen-3.3.9/Eigen/src/Core/MathFunctions.h eigen-3.3.9-new/Eigen/src/Core/MathFunctions.h ---- eigen-3.3.9/Eigen/src/Core/MathFunctions.h 2020-12-04 22:53:41.000000000 +0100 -+++ eigen-3.3.9-new/Eigen/src/Core/MathFunctions.h 2021-01-19 12:32:05.328624222 +0100 -@@ -485,12 +485,22 @@ struct log1p_impl { - EIGEN_STATIC_ASSERT_NON_INTEGER(Scalar) - #if EIGEN_HAS_CXX11_MATH - using std::log1p; -- #endif -+ #else - using std_fallback::log1p; -+ #endif - return log1p(x); - } - }; - -+// Specialization for complex types that are not supported by std::log1p. -+template -+struct log1p_impl > { -+ EIGEN_DEVICE_FUNC static inline std::complex run( -+ const std::complex& x) { -+ EIGEN_STATIC_ASSERT_NON_INTEGER(RealScalar) -+ return std_fallback::log1p(x); -+ } -+}; - - template - struct log1p_retval diff --git a/sources b/sources index 1b3ce68..76fc948 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -SHA512 (eigen-3.3.9.tar.bz2) = 6f222e27480d02d90f258c94a4a4787771491fc30c73d5fb025a8089484fdeb2c65d464172f5c29d0c3096b69ff98027a18a40c04b006da670733a2c75f55b65 +SHA512 (eigen-3.4.0.tar.bz2) = cc488eb111e0e248744d2bc4475b345b5fb82361dff226a5b73a33bd0388de8c219cff8cffcf8f476b672fc0e223f339e8c6a1cfb6293840a4a6abf232438a89