cppidioms
cppidioms-cn
项目起源于群友们的建议,介绍一些惯用法
请点击page标签页查看
参与步骤
0. 安装format工具
pip install clang-format==14.0.6 cmake_format==0.6.11 pyyaml ··· 1. documentation pages目录下添加文档,使用template模板 2. include/source目录下添加实现 3. test目录下添加测试 4. 运行build.sh 这个项目使用ModernCppStarter,在此表示感谢,以下是详细用法 ## Usage ### Build and run test suite Use the following commands from the project's root directory to run the test suite.
bash cmake -S test -B build/test cmake –build build/test CTEST_OUTPUT_ON_FAILURE=1 cmake –build build/test –target test
or simply call the executable:
./build/test/cppidiomsTests
To collect code coverage information, run CMake with the `-DENABLE_TEST_COVERAGE=1` option. ### Run clang-format Use the following commands from the project's root directory to check and fix C++ and CMake source style. This requires _clang-format_, _cmake-format_ and _pyyaml_ to be installed on the current system.
bash cmake -S test -B build/test
view changes
cmake –build build/test –target format
apply changes
cmake –build build/test –target fix-format
See [Format.cmake](https://github.com/TheLartians/Format.cmake) for details. These dependencies can be easily installed using pip.
bash pip install clang-format==14.0.6 cmake_format==0.6.11 pyyaml ### Build the documentation bash cmake -S documentation -B build/doc cmake –build build/doc –target GenerateDocs
view the docs
open build/doc/doxygen/html/index.html
To build the documentation locally, you will need Doxygen, jinja2 and Pygments installed on your system. ### Build everything at once The project also includes an `all` directory that allows building all targets at the same time. This is useful during development, as it exposes all subprojects to your IDE and avoids redundant builds of the library.
bash cmake -S all -B build cmake –build build
run tests
./build/test/cppidiomsTests
format code
cmake –build build –target fix-format
build docs
cmake –build build –target GenerateDocs ```
Additional tools
The test subprojects include the tools.cmake file which is used to import additional tools on-demand through CMake configuration arguments. The following are currently supported.
Sanitizers
Sanitizers can be enabled by configuring CMake with ‘-DUSE_SANITIZER=<Address | Memory | MemoryWithOrigins | Undefined | Thread | Leak | 'Address;Undefined’>`.
Static Analyzers
Static Analyzers can be enabled by setting -DUSE_STATIC_ANALYZER=<clang-tidy | iwyu | cppcheck>, or a combination of those in quotation marks, separated by semicolons. By default, analyzers will automatically find configuration files such as .clang-format. Additional arguments can be passed to the analyzers by setting the CLANG_TIDY_ARGS, IWYU_ARGS or CPPCHECK_ARGS variables.
Ccache
Ccache can be enabled by configuring with -DUSE_CCACHE=<ON | OFF>.