clang-format and cmake-format for CMake
Format.cmake adds three additional targets to your CMake project.
formatShows which files are affected by clang-formatcheck-formatErrors if files are affected by clang-format (for CI integration)fix-formatApplies clang-format to all affected files
To run the targets, invoke CMake with cmake --build <build directory> --target <target name>.
To disable using cmake_format to format CMake files, set the cmake option FORMAT_SKIP_CMAKE to a truthy value, e.g. by invoking CMake with -DFORMAT_SKIP_CMAKE=YES, or enabling the option when adding the dependency (recommended).
To disable using clang_format to format clang-supported files, set the cmake option FORMAT_SKIP_CLANG to a truthy value, e.g. by invoking CMake with -DFORMAT_SKIP_CLANG=YES, or enabling the option when adding the dependency (recommended).
To specify a extra arguments for cmake-format, use the cmake option CMAKE_FORMAT_EXTRA_ARGS, e.g. by invoking CMake with -DCMAKE_FORMAT_EXTRA_ARGS="-c /path/to/cmake-format-config.{yaml,json,py}",
or by enabling the option when adding the dependency (recommended).
Using CPM.cmake (recommended)
After adding CPM.cmake, add the following line to the project's CMakeLists.txt after calling project(...).
include(cmake/CPM.cmake)
CPMAddPackage("gh:TheLartians/[email protected]")This package supports optional parameters that you can specify in the CPM.cmake OPTIONS argument.
CPMAddPackage(
NAME Format.cmake
VERSION 1.8.2
GITHUB_REPOSITORY TheLartians/Format.cmake
OPTIONS
# set to yes skip cmake formatting
"FORMAT_SKIP_CMAKE NO"
# set to yes skip clang formatting
"FORMAT_SKIP_CLANG NO"
# path to exclude (optional, supports regular expressions)
"CMAKE_FORMAT_EXCLUDE cmake/CPM.cmake"
# extra arguments for cmake_format (optional)
"CMAKE_FORMAT_EXTRA_ARGS -c /path/to/cmake-format.{yaml,json,py}"
)Run the following from the project's root directory.
git submodule add https://github.com/TheLartians/Format.cmakeIn add the following lines to the project's CMakeLists.txt after calling project(...).
add_subdirectory(Format.cmake)Format.cmake requires CMake, clang-format, python 2.7 or python 3, and cmake-format (optional).
