mirror of
https://github.com/TheLartians/ModernCppStarter.git
synced 2025-08-30 13:41:13 +02:00
🚀 Kick-start your C++! A template for modern C++ projects using CMake, CI, code coverage, clang-format, reproducible dependency management and much more.
https://thelartians.github.io/ModernCppStarter
bootstrapcccacheciclang-formatcmakecmakelistscodecovcontinuous-integrationcoveragecppdependency-managerfreegithub-workflowsmodern-cmakemodern-cmake-templateopen-sourcesanitizersstartertemplate
.github/workflows | ||
cmake | ||
include | ||
source | ||
test | ||
.clang-format | ||
.gitignore | ||
CMakeLists.txt | ||
README.md |
Greeter
A best-practice git template for modern C++ libraries and projects.
Features
- Modern CMakeLists.txt
- Suited for single header libraries and larger projects
- Creates a library that can be installed or included locally
- Integrated test suite
- Code formatting enforced via clang-format/Format.cmake
- Continuous integration via GitHub Workflows
- Reliable dependency management via CPM.cmake
- Check compiler warnings
Roadmap
- Add code coverage checks
- Add a script to automatically rename project / switch to single-header mode
Usage
Adjust the template to your needs
- Clone this repo and replace all occurrences of "Greeter" in the CMakeLists.txt
- Single-header libraries: see the comments in CMakeLists.txt
- Have fun!
Build and run test suite
cmake -Htest -Bbuild
cmake --build build
CTEST_OUTPUT_ON_FAILURE=1 cmake --build build --target test
# or simply call the executable:
./build/GreeterTests
Run clang-format
cmake -Htest -Bbuild
# view changes
cmake --build build --target format
# apply changes
cmake --build build --target fix-format
See Format.cmake for more options.