@@ -12,52 +12,44 @@ defaults:
1212 shell : bash -e -l {0}
1313jobs :
1414 build :
15+ runs-on : ubuntu-24.04
1516 name : ${{ matrix.sys.compiler }} ${{ matrix.sys.version }} - ${{ matrix.sys.name }}
1617 strategy :
1718 fail-fast : false
1819 matrix :
1920 sys :
20- - {os: ubuntu-20.04, compiler: clang, version: '15', name: assert, flags: -DXTENSOR_ENABLE_ASSERT=ON}
21- - {os: ubuntu-20.04, compiler: clang, version: '16', name: column-major, flags: -DDEFAULT_COLUMN_MAJOR=ON}
22- - {os: ubuntu-20.04, compiler: gcc, version: '8', name: openmp, flags: -DXTENSOR_USE_OPENMP=ON}
23- - {os: ubuntu-20.04, compiler: gcc, version: '9', name: noexcept, flags: -DXTENSOR_DISABLE_EXCEPTIONS=ON}
24- - {os: ubuntu-22.04, compiler: gcc, version: '10', name: xsimd, flags: -DXTENSOR_USE_XSIMD=ON}
25- - {os: ubuntu-22.04, compiler: gcc, version: '11', name: c++17, flags: -DCPP17=ON}
26- - {os: ubuntu-22.04, compiler: gcc, version: '11', name: xsimd-tbb, flags: -DXTENSOR_USE_XSIMD=ON -DXTENSOR_USE_TBB=ON}
27- - {os: ubuntu-22.04, compiler: gcc, version: '11', name: tbb, flags: -DXTENSOR_USE_TBB=ON -DTBB_INCLUDE_DIR=$CONDA_PREFIX/include -DTBB_LIBRARY=$CONDA_PREFIX/lib}
28- - {os: ubuntu-22.04, compiler: gcc, version: '12', name: c++17, flags: -DCPP17=ON}
29- - {os: ubuntu-22.04, compiler: gcc, version: '12', name: xsimd-tbb, flags: -DXTENSOR_USE_XSIMD=ON -DXTENSOR_USE_TBB=ON}
30- - {os: ubuntu-22.04, compiler: gcc, version: '12', name: tbb, flags: -DXTENSOR_USE_TBB=ON -DTBB_INCLUDE_DIR=$CONDA_PREFIX/include -DTBB_LIBRARY=$CONDA_PREFIX/lib}
31- runs-on : ${{ matrix.sys.os }}
21+ - {compiler: clang, version: '17', name: assert, flags: -DXTENSOR_ENABLE_ASSERT=ON}
22+ - {compiler: clang, version: '18', name: column-major, flags: -DDEFAULT_COLUMN_MAJOR=ON}
23+ - {compiler: clang, version: '19', name: assert, flags: -DXTENSOR_ENABLE_ASSERT=ON}
24+ - {compiler: clang, version: '20', name: column-major, flags: -DDEFAULT_COLUMN_MAJOR=ON}
25+ - {compiler: gcc, version: '11', name: openmp, flags: -DXTENSOR_USE_OPENMP=ON}
26+ - {compiler: gcc, version: '11', name: noexcept, flags: -DXTENSOR_DISABLE_EXCEPTIONS=ON}
27+ - {compiler: gcc, version: '12', name: xsimd, flags: -DXTENSOR_USE_XSIMD=ON}
28+ - {compiler: gcc, version: '13', name: xsimd-tbb, flags: -DXTENSOR_USE_XSIMD=ON -DXTENSOR_USE_TBB=ON}
29+ - {compiler: gcc, version: '13', name: tbb, flags: -DXTENSOR_USE_TBB=ON -DTBB_INCLUDE_DIR=$CONDA_PREFIX/include -DTBB_LIBRARY=$CONDA_PREFIX/lib}
30+ - {compiler: gcc, version: '14', name: xsimd-tbb, flags: -DXTENSOR_USE_XSIMD=ON -DXTENSOR_USE_TBB=ON}
31+ - {compiler: gcc, version: '14', name: tbb, flags: -DXTENSOR_USE_TBB=ON -DTBB_INCLUDE_DIR=$CONDA_PREFIX/include -DTBB_LIBRARY=$CONDA_PREFIX/lib}
3232 steps :
33- - name : Setup GCC
34- if : ${{ matrix.sys.compiler == 'gcc' }}
35- run : |
36- GCC_VERSION=${{ matrix.sys.version }}
37- sudo apt-get update
38- sudo apt-get --no-install-suggests --no-install-recommends install g++-$GCC_VERSION
39- CC=gcc-$GCC_VERSION
40- echo "CC=$CC" >> $GITHUB_ENV
41- CXX=g++-$GCC_VERSION
42- echo "CXX=$CXX" >> $GITHUB_ENV
43- - name : Setup clang
44- if : ${{ matrix.sys.compiler == 'clang' }}
33+ - name : Install GCC
34+ if : matrix.sys.compiler == 'gcc'
35+ uses : egor-tensin/setup-gcc@v1
36+ with :
37+ version : ${{matrix.sys.version}}
38+ platform : x64
39+
40+ - name : Install LLVM and Clang
41+ if : matrix.sys.compiler == 'clang'
4542 run : |
46- LLVM_VERSION=${{ matrix.sys.version }}
47- wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | sudo apt-key add - || exit 1
48- if [[ $LLVM_VERSION -ge 13 ]]; then
49- sudo add-apt-repository "deb http://apt.llvm.org/focal/ llvm-toolchain-focal-$LLVM_VERSION main" || exit 1
50- else
51- sudo add-apt-repository "deb http://apt.llvm.org/focal/ llvm-toolchain-focal main" || exit 1
52- fi || exit 1
53- sudo apt-get update || exit 1
54- sudo apt-get --no-install-suggests --no-install-recommends install clang-$LLVM_VERSION || exit 1
55- sudo apt-get --no-install-suggests --no-install-recommends install g++-9 g++-9-multilib || exit 1
56- sudo ln -s /usr/include/asm-generic /usr/include/asm
57- CC=clang-$LLVM_VERSION
58- echo "CC=$CC" >> $GITHUB_ENV
59- CXX=clang++-$LLVM_VERSION
60- echo "CXX=$CXX" >> $GITHUB_ENV
43+ wget https://apt.llvm.org/llvm.sh
44+ chmod +x llvm.sh
45+ sudo ./llvm.sh ${{matrix.sys.version}}
46+ sudo apt-get install -y clang-tools-${{matrix.sys.version}}
47+ sudo update-alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-${{matrix.sys.version}} 200
48+ sudo update-alternatives --install /usr/bin/clang clang /usr/bin/clang-${{matrix.sys.version}} 200
49+ sudo update-alternatives --install /usr/bin/clang-scan-deps clang-scan-deps /usr/bin/clang-scan-deps-${{matrix.sys.version}} 200
50+ sudo update-alternatives --set clang /usr/bin/clang-${{matrix.sys.version}}
51+ sudo update-alternatives --set clang++ /usr/bin/clang++-${{matrix.sys.version}}
52+ sudo update-alternatives --set clang-scan-deps /usr/bin/clang-scan-deps-${{matrix.sys.version}}
6153
6254 - name : Checkout code
6355 uses : actions/checkout@v3
7365 ${{ (matrix.sys.name == 'tbb' || matrix.sys.name == 'xsimd-tbb' ) && 'tbb-devel' || '' }}
7466
7567 - name : Configure using CMake
76- # env:
77- # CC: ${{ env.CC }}
78- # CXX: ${{ env.CXX }}
79- run : cmake -G Ninja -Bbuild -DCMAKE_C_COMPILER=$CC -DCMAKE_CXX_COMPILER=$CXX -DCMAKE_INSTALL_PREFIX=$CONDA_PREFIX -DBUILD_TESTS=ON ${{ matrix.sys.flags }}
68+ run : |
69+ if [[ "${{matrix.sys.compiler}}" = "gcc" ]]; then export CC=gcc-${{matrix.sys.version}}; export CXX=g++-${{matrix.sys.version}}; else export CC=clang; export CXX=clang++; fi
70+ cmake -G Ninja -Bbuild -DCMAKE_C_COMPILER=$CC -DCMAKE_CXX_COMPILER=$CXX -DCMAKE_INSTALL_PREFIX=$CONDA_PREFIX -DBUILD_TESTS=ON ${{ matrix.sys.flags }}
8071
8172 - name : Install
8273 working-directory : build
0 commit comments