Skip to content

C++ project template : CMake, Test, Travis CI, Appveyor, CodeCoverage, Doxygen

License

Notifications You must be signed in to change notification settings

johanLsp/CPP_Template

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

C++ Template

Jumpstart a C++ project in no time

Build Status Build status codecov

This is a cross-plateform (Linux/OSX/Windows) CMake based C++ template shipped with :

  • Continuous Integration with Travis CI & Appveyor
  • Unit testing with Catch
  • Documentation with Doxygen
  • Code coverage with CodeCov

Each of these features can be disabled / enabled if needed

Pre-requisites

You can skip this if you just want to use the CMake template without additional features. Otherwise, the following dependencies have to be installed :

doxygen
boost test-unit-framework
lcov

Usage

The template is shipped with extra features disabled. Just clone or fork the repository, and follow the usual CMake build from the project directory :

mkdir build
cd build
cmake ..
make

By default, two targets are generated: an executable in bin/, and a library in lib/ The CMake configuration accepts the following options :

  • -DENABLE_DOC=1 : Generates the documentation target
  • -DENABLE_TEST=1 : Turns on testing
  • -DENABLE_COVERAGE=1 : Generates the coverage build

Features

Documentation

cmake -DENABLE_DOC=1 ..
make doc

Generates the doxygen documentation in doc/html A base doxygen configuration is provided in doc/documentation-config.doxygen.in, along with a few page templates.

Unit testing

cmake -DENABLE_TESTING=1 ..
make test

Runs the tests defined in test

Code Coverage

cmake -DENABLE_COVERAGE=1 ..
make test

Enabling code coverage automatically enables unit testing. Running the test generates a coverage report

Travis CI

Integration with Travis CI is configured in .travis.yml The default configuration builds and run tests on different version of Ubuntu & OSX, and generate a coverage report

Appveyor

Integration with Appveyor is configured in appveyor.yml The default configuration builds and run tests on different Visual Studio generators

CodeCov

Integration with CodeCov is configured in .codecov.yml The default Travis configuration automatically push the coverage report to CodeCov.io

Contributing

If you think something is missing, feel free to open an issue or give me a hint. To contribute to the repository :

  1. Fork it (https://github.com/yourname/yourproject/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Commit your changes (git commit -am 'Add some fooBar')
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a new Pull Request

About

C++ project template : CMake, Test, Travis CI, Appveyor, CodeCoverage, Doxygen

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published