This repository provides a base project for C++ projects.
It is licensed under the MIT license so you may use any license in the project you create.
Features:
- CMake build script.
- cz and Tracy integration.
- GNU Global tag generation.
- Build scripts (debug, release, release-debug, tracy).
- Catch2 tests.
Getting started:
- Clone the repository by following step 1 of Building.
- Change all instances of
MYPROJECTURL
with the url of your project. - Change all instances of
MYPROJECT
with the name of your project. - Delete this part of the readme.
- Clone the repository and the submodules.
git clone MYPROJECTURL
cd MYPROJECT
git submodule init
git submodule update
- Build MYPROJECT by running (on all platforms):
./build-release
- After building, MYPROJECT can be ran via
./build/release/MYPROJECT
.
We use Tracy to optimize MYPROJECT. See the manual for more information.
To prepare we have to build MYPROJECT with Tracy enabled and also build Tracy's profiler. Once both are built, we then run the profiler and MYPROJECT at the same time.
Build MYPROJECT with Tracy enabled:
./build-tracy
Build tracy/profiler
by following the instructions in the Tracy manual. On *nix:
cd tracy/profiler/build/unix
make release
Then we run Tracy:
./tracy/profiler/build/unix/Tracy-release
Then run MYPROJECT with Tracy enabled. Run it as the super user to enable context switching recognition.
sudo ./build/tracy/MYPROJECT