mirror of
https://github.com/triqs/dft_tools
synced 2025-01-09 12:44:03 +01:00
Use ccache to speed up compilation
This commit is contained in:
parent
ab04e46ebf
commit
2e3e7d7feb
34
.github/workflows/build.yml
vendored
34
.github/workflows/build.yml
vendored
@ -6,6 +6,17 @@ on:
|
|||||||
pull_request:
|
pull_request:
|
||||||
branches: [ unstable ]
|
branches: [ unstable ]
|
||||||
|
|
||||||
|
env:
|
||||||
|
CMAKE_C_COMPILER_LAUNCHER: ccache
|
||||||
|
CMAKE_CXX_COMPILER_LAUNCHER: ccache
|
||||||
|
CCACHE_COMPILERCHECK: content
|
||||||
|
CCACHE_BASEDIR: ${{ github.workspace }}
|
||||||
|
CCACHE_DIR: ${{ github.workspace }}/.ccache
|
||||||
|
CCACHE_MAXSIZE: 500M
|
||||||
|
CCACHE_SLOPPINESS: pch_defines,time_macros,include_file_mtime,include_file_ctime
|
||||||
|
CCACHE_COMPRESS: "1"
|
||||||
|
CCACHE_COMPRESSLEVEL: "1"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
|
|
||||||
@ -16,13 +27,20 @@ jobs:
|
|||||||
- {os: ubuntu-22.04, cc: gcc-12, cxx: g++-12}
|
- {os: ubuntu-22.04, cc: gcc-12, cxx: g++-12}
|
||||||
- {os: ubuntu-22.04, cc: clang-15, cxx: clang++-15}
|
- {os: ubuntu-22.04, cc: clang-15, cxx: clang++-15}
|
||||||
- {os: macos-12, cc: gcc-12, cxx: g++-12}
|
- {os: macos-12, cc: gcc-12, cxx: g++-12}
|
||||||
- {os: macos-12, cc: /usr/local/opt/llvm/bin/clang, cxx: /usr/local/opt/llvm/bin/clang++}
|
- {os: macos-12, cc: clang, cxx: clang++}
|
||||||
|
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- uses: actions/cache/restore@v3
|
||||||
|
with:
|
||||||
|
path: ${{ env.CCACHE_DIR }}
|
||||||
|
key: ccache-${{ matrix.os }}-${{ matrix.cc }}-${{ github.run_id }}
|
||||||
|
restore-keys:
|
||||||
|
ccache-${{ matrix.os }}-${{ matrix.cc }}-
|
||||||
|
|
||||||
- name: Install ubuntu dependencies
|
- name: Install ubuntu dependencies
|
||||||
if: matrix.os == 'ubuntu-22.04'
|
if: matrix.os == 'ubuntu-22.04'
|
||||||
run: >
|
run: >
|
||||||
@ -30,6 +48,7 @@ jobs:
|
|||||||
sudo apt-get install lsb-release wget software-properties-common &&
|
sudo apt-get install lsb-release wget software-properties-common &&
|
||||||
wget -O /tmp/llvm.sh https://apt.llvm.org/llvm.sh && sudo chmod +x /tmp/llvm.sh && sudo /tmp/llvm.sh 15 &&
|
wget -O /tmp/llvm.sh https://apt.llvm.org/llvm.sh && sudo chmod +x /tmp/llvm.sh && sudo /tmp/llvm.sh 15 &&
|
||||||
sudo apt-get install
|
sudo apt-get install
|
||||||
|
ccache
|
||||||
clang-15
|
clang-15
|
||||||
g++-12
|
g++-12
|
||||||
gfortran
|
gfortran
|
||||||
@ -63,13 +82,14 @@ jobs:
|
|||||||
- name: Install homebrew dependencies
|
- name: Install homebrew dependencies
|
||||||
if: matrix.os == 'macos-12'
|
if: matrix.os == 'macos-12'
|
||||||
run: |
|
run: |
|
||||||
brew install gcc@12 llvm boost fftw hdf5 open-mpi openblas
|
brew install ccache gcc@12 llvm boost fftw hdf5 open-mpi openblas
|
||||||
pip3 install mako numpy scipy mpi4py
|
pip3 install mako numpy scipy mpi4py
|
||||||
pip3 install -r requirements.txt
|
pip3 install -r requirements.txt
|
||||||
|
|
||||||
- name: add clang cxxflags
|
- name: add clang cxxflags
|
||||||
if: ${{ contains(matrix.cxx, 'clang') }}
|
if: ${{ contains(matrix.cxx, 'clang') }}
|
||||||
run:
|
run:
|
||||||
|
echo "PATH=/usr/local/opt/llvm/bin:$PATH" >> $GITHUB_ENV
|
||||||
echo "CXXFLAGS=-stdlib=libc++" >> $GITHUB_ENV
|
echo "CXXFLAGS=-stdlib=libc++" >> $GITHUB_ENV
|
||||||
|
|
||||||
- name: Build & Install TRIQS
|
- name: Build & Install TRIQS
|
||||||
@ -100,3 +120,13 @@ jobs:
|
|||||||
source $HOME/install/share/triqs/triqsvars.sh
|
source $HOME/install/share/triqs/triqsvars.sh
|
||||||
cd build
|
cd build
|
||||||
ctest -j2 --output-on-failure
|
ctest -j2 --output-on-failure
|
||||||
|
|
||||||
|
- name: ccache statistics
|
||||||
|
if: always()
|
||||||
|
run: ccache -sv
|
||||||
|
|
||||||
|
- uses: actions/cache/save@v3
|
||||||
|
if: always()
|
||||||
|
with:
|
||||||
|
path: ${{ env.CCACHE_DIR }}
|
||||||
|
key: ccache-${{ matrix.os }}-${{ matrix.cc }}-${{ github.run_id }}
|
||||||
|
Loading…
Reference in New Issue
Block a user