You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
GitHub Action
CMake Action
v1.1.0
Configure, build, and test a CMake project on GitHub Actions.
Use this action to simplify the workflow run of your CMake project.
This action will configure a build environment for your project using the cmake
command,
then it will build your project by running a cmake --build
command,
and last it could test your project using the ctest
command.
- Configure and build a project using the cmake command.
- Optionally test a project using the ctest command.
- Auto-detect and install required dependencies.
- Specify multiple CMake options directly from the Action inputs.
For more information, see action.yml and GitHub Actions guide.
Name | Value Type | Description |
---|---|---|
source-dir |
Path | Source directory of the CMake project. Defaults to current directory. |
build-dir |
Path | Build directory of the CMake project. Defaults to build directory inside the source directory. |
targets |
Multiple strings | List of build targets. |
run-test |
true or false |
If enabled, run testing using CTest. Defaults to false . |
generator |
String | Build system generator of the CMake project. |
c-compiler |
String | Preferred executable for compiling C language files. |
cxx-compiler |
String | Preferred executable for compiling C++ language files. |
c-flags |
Multiple strings | Additional flags passed when compiling C language files. |
cxx-flags |
Multiple strings | Additional flags passed when compiling C++ language files. |
args |
Multiple strings | Additional arguments passed during the CMake configuration. |
test-args |
Multiple strings | Additional arguments passed during the CTest run. |
Note: Multiple strings mean that the input could be specified with more than one value. Separate each value with a space or a new line.
Note: All inputs are optional.
name: build
on:
push:
jobs:
build-project:
runs-on: ubuntu-latest
steps:
- name: Check out this repository
uses: actions/checkout@v3.3.0
- name: Configure and build this project
uses: threeal/cmake-action@latest
Note: You can replace
@latest
with any version you like. See this.
- name: Configure and build this project
uses: threeal/cmake-action@latest
with:
source-dir: submodules
build-dir: submodules/out
- name: Configure and build this project
uses: threeal/cmake-action@latest
with:
targets: hello_mars hello_sun
- name: Configure, build, and test this project
uses: threeal/cmake-action@latest
with:
args: -DBUILD_TESTING=ON
run-test: true
- name: Configure and build this project
uses: threeal/cmake-action@latest
with:
generator: Ninja
c-compiler: clang
cxx-compiler: clang++
This project is licensed under the terms of the MIT License.
Copyright © 2023 Alfi Maulana