This is a template of a cross-platform CMake-based C++ project.
- Run Cppcheck and Clang-Tidy.
- Ensure clean and robust code with a pre-configured set of warnings for Clang, GCC, and MSVC.
- Create sanitizer-instrumented builds by changing a single flag.
- Validate files structure and follow the Conventional Commits specification with pre-commit hooks.
- Build and test your project with GitHub Actions.
Run the following commands in the root of the repository after cloning:
poetry install
poetry run pre-commit install
poetry run conan profile detect
poetry shell
# install libraries
conan install -pr:b default -pr:h default \
-c:h tools.cmake.cmaketoolchain:generator=<CMake generator> \
-pr:h conan/<profile matching the compiler in use> \
-c:h tools.build:compiler_executables='{"c": "<CC>", "cpp": "<CXX>"}' \
-c:h tools.build:skip_test=<True|False> \
-s build_type=<Debug|RelWithDebInfo|Release|MinSizeRel> -b missing .
# configure
cmake --preset <preset> \
-D ENABLE_CPPCHECK=<bool> \
-D ENABLE_CLANG_TIDY=<bool> \
-D ENABLE_IPO=<bool> \
-D ENABLE_CACHE=<bool> \
-D CACHE_OPTION=<ccache or sccache> \
-D ENABLE_COVERAGE=<bool> \
-D ENABLE_HARDENINGS=<bool> \
-D ENABLE_FORTIFY_SOURCE=<bool> \
-D ENABLE_ASAN=<bool> \
-D ENABLE_LSAN=<bool> \
-D ENABLE_UBSAN=<bool> \
-D ENABLE_TSAN=<bool>
# build
cmake --build --preset <preset>
# run tests
ctest --preset <preset>
# collect test coverage if ENABLE_COVERAGE == TRUE
GCOV=<"gcov" for GCC, "llvm-cov gcov" for Clang> gcovr
# run tests and collect test coverage (Windows)
OpenCppCoverage.exe --export_type cobertura:coverage.xml --cover_children -- ctest --preset <preset>
- Change the LICENSE file
- Write a
README.md
- Fill in the community health files
- Edit
.github/CONTRIBUTING.md
(don't forget to update links) - Edit
.github/CODE_OF_CONDUCT.md
and insert contact method. - Edit
.github/SECURITY.md
- Edit
- Clean the
.git-blame-ignore-revs
file - Configure CODEOWNERS (
.github/CODEOWNERS
) - Configure Dependabot (
.github/dependabot.yml
)
The template uses the Unlicense license. A license with no conditions whatsoever which dedicates works to the public domain. Unlicensed works, modifications and larger works may be distributed under different terms and without source code. You likely want to use another license for your project. If you are not yet sure which one to use, this resource can help you.
Describe your project to the audience. People interested in your project don't need to read this text :)
And don't forget to update badge URLs if you decide to keep them.
Apart from README, there are a number of files in the .github directory that help people to interact with your project: submit issues and pull requests, security vulnerabilities. Please update the contents of these files with the links to your repository and contact methods.
The .git-blame-ignore-revs
file contains commit SHAs that you may want to skip
while viewing the git blame on GitHub as if using git blame --ignore-revs-file=.git-blame-ignore-revs
.
Code owners are automatically requested for review when someone opens a pull request that modifies code that they own. Code owners are not automatically requested to review draft pull requests.
Dependabot is a GitHub bot that helps you keep dependencies up to date.
Configure dependency scanning in the .github/dependabot.yml
file.