Overview
This project template provides a robust foundation for C++ projects using CMake as the build system. It includes CI/CD integration, documentation setup with Doxygen, unit testing using Google Test, and modularized CMakeLists.txt for easy project management.
Features
- CI/CD Integration: GitHub Actions workflows for Ubuntu CI (testing) and Documentation (GitHub Pages).
- Documentation: Doxygen setup with customizable Doxyfile.in for generating API documentation.
- Unit Testing: Google Test framework for writing and running unit tests.
- Modular CMakeLists: Abstracted CMakeLists.txt files for each module (app, user modules, test suite).
- CMake Modules: Includes modules for adding git submodules, enabling sanitizers, adding warning flags, etc.
Folder Structure
├───.github
│ └───workflows
│ ├───documentation.yml // GitHub Actions for Documentation (GitHub Pages)
│ └───Ubuntu.yml // GitHub Actions for Ubuntu CI for Testing
├───app
│ ├───CMakeLists.txt // CMakeLists for main app module
│ └───main.cpp
├───build // Default build directory
├───cmake
│ ├───AddGitSubmodule.cmake // CMake module to add git submodules
│ ├───Docs.cmake // CMake module to generate documentation
│ ├───Sanitizer.cmake // CMake module to add sanitizer flags
│ └───Warnings.cmake // CMake module to add warning flags
├───docs
│ ├───diagrams
│ │ ├───mermaid
│ │ └───plantuml
│ └───doxygen
│ └───Doxyfile.in // Doxygen configuration file
├───lib
│ └───json // Sample lib submodule (can be replaced)
├───src
│ └───Module
│ └───CMakeLists.txt // CMakeLists for user module
├───tests
│ ├───Test_suite // Test Suite
│ │ └───CMakeLists.txt // CMakeLists for test suite
│ ├───lib
│ │ └───googletest
│ └───test_suite
├───CMakeLists.txt // Root CMakeLists.txt for project configuration
├─.clang-uml // Clang UML configuration file
├─.clang-format // Clang format configuration file
└─.clang-tidy // Clang tidy configuration file
Getting Started
- Clone the Repository:
https://github.com/7osssam/CPP_Project_Template
cd CPP_Project_Template
Install Dependencies:
This command installs necessary dependencies including compilers, CMake, LLVM, Ninja, Doxygen, Graphviz, and other tools based on your operating system.
Prepare the Build Environment:
make clean-cache-reconfigure
Cleans the cache and reconfigures the build environment using CMake, setting up for a Debug build with Ninja Generator (recommended).
Build the Project:
Configures and builds the project in Debug mode using CMake and Ninja.
Run the Project:
Executes the compiled project executable. This command automatically detects the OS to run the correct executable file.
Generate Documentation:
Generates HTML and PDF documentation using Doxygen from the configured Doxyfile.in.
Run Unit Tests:
Executes unit tests using Google Test framework (You can add your own testing framework, as long as it is supported by CMake).
- Generate Diagrams (Optional):
- Using Clang UML to generate UML diagrams from C++ code (Check
.clang-uml
file for configuration).
Generates diagrams (PlantUML and Mermaid) from diagrams stored in docs/diagrams
.
TODO
- [ ] Add support for Windows CI/CD.
- [ ] Add support for macOS CI/CD.
- [ ] Add support for Code Coverage.
- [ ] Add support for Static Code Analysis (linting).
Contributing
Contributions are welcome! Please follow these steps to contribute:
- Fork the repository.
- Create a new branch (
git checkout -b feature/feature-name
).
- Commit your changes (
git commit -am [Feature message]
).
- Push to the branch (
git push origin feature/feature-name
).
- Create a new Pull Request.
[!NOTE]
The Banking System project files in this template are for demonstration purposes only. You can replace them with your own project files and modules.
License
Feel free to use this project template for your own projects.
This project is licensed under the [MIT License](LICENSE).