Skip to content

chore(deps): bump fsfe/reuse-action from 3 to 4 #20

chore(deps): bump fsfe/reuse-action from 3 to 4

chore(deps): bump fsfe/reuse-action from 3 to 4 #20

Workflow file for this run

# SPDX-FileCopyrightText: 2022 leha-bot and contributors
#
# SPDX-License-Identifier: BSL-1.0 OR BlueOak-1.0.0
name: 'Build project'
on:
push:
branches:
- '**'
paths:
- '.github/workflows/**'
- 'include/**'
- 'src/**'
- 'tests/**'
- '**/CMakeLists.txt'
pull_request:
branches:
- 'master'
paths:
- '.github/workflows/**'
- 'include/**'
- 'src/**'
- 'tests/**'
- '**/CMakeLists.txt'
defaults:
run:
shell: sh
jobs:
build:
name: 'Build'
strategy:
matrix:
system:
- windows-2022
- macos-14
- ubuntu-22.04
config:
- Release
# The CMake configure and build commands are platform agnostic and should work equally well on Windows or Mac.
# You can convert this to a matrix build if you need cross-platform coverage.
# See: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/managing-complex-workflows#using-a-build-matrix
runs-on: ${{ matrix.system }}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Conan
uses: imesense/[email protected]
# Detect the build profile for futher Conan interactions
- name: Detect build profile
run: |
conan profile detect
# Install dependencies in the same build folder as will be used in CMake. This path also will be used for CMake's find_package() mode
# via CMAKE_MODULE_PATH and CMAKE_PREFIX_PATH
- name: Install dependencies
run: |
conan install . \
--build=missing \
-of conan-deps \
-s build_type=${{ matrix.config }}
- name: Set path (Windows)
if: ${{ runner.os == 'Windows' }}
shell: pwsh
run: |
$github_workspace = "${{ github.workspace }}"
$workspace = ($github_workspace -replace '\\','/')
Add-Content -Path $env:GITHUB_ENV -Value "workspace=$workspace"
- name: Set path (macOS/Linux)
if: ${{ runner.os != 'Windows' }}
run: |
export workspace=${{ github.workspace }}
echo "workspace=$workspace" >> $GITHUB_ENV
- name: Configure project
# Configure CMake in a 'build' subdirectory. `CMAKE_BUILD_TYPE` is only required if you are using a single-configuration generator such as make.
# See https://cmake.org/cmake/help/latest/variable/CMAKE_BUILD_TYPE.html?highlight=cmake_build_type
# Also set PREFIX and MODULE paths for find_package() via CMAKE_MODULE_PATH and CMAKE_PREFIX_PATH variables.
# See https://cmake.org/cmake/help/latest/command/find_package.html?highlight=find_package for search modes.
run: |
cmake -B ${{ env.workspace }}/build \
-DCMAKE_BUILD_TYPE=${{ matrix.config }} \
-DCMAKE_PREFIX_PATH="${{ env.workspace }}/conan-deps" \
-DCMAKE_MODULE_PATH="${{ env.workspace }}/conan-deps"
- name: Build project
working-directory: ${{ env.workspace }}/build
# Build your program with the given configuration
run: |
cmake --build . --config ${{ matrix.config }}
- name: Test project
working-directory: ${{ env.workspace }}/build
# Execute tests defined by the CMake configuration.
# See https://cmake.org/cmake/help/latest/manual/ctest.1.html for more detail
run: |
ctest -C ${{ matrix.config }}