mirror of
https://github.com/TheLartians/ModernCppStarter.git
synced 2025-10-30 17:51:34 +01: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.