xo-umbrella2/xo-cmake
Roland Conybeare 84c7ab2b78 git subrepo push xo-cmake
subrepo:
  subdir:   "xo-cmake"
  merged:   "b9e10837"
upstream:
  origin:   "git@github.com:Rconybea/xo-cmake.git"
  branch:   "main"
  commit:   "b9e10837"
git-subrepo:
  version:  "0.4.9"
  origin:   "???"
  commit:   "???"
2026-06-06 21:37:42 -04:00
..
.github/workflows git subrepo clone git@github.com:Rconybea/xo-cmake.git xo-cmake 2026-06-06 21:19:03 -04:00
bin xo-cmake: now via git subrepo [GIT] 2026-06-06 21:22:31 -04:00
cmake/xo_macros xo-cmake: now via git subrepo [GIT] 2026-06-06 21:22:31 -04:00
docs/history/2026 git subrepo clone git@github.com:Rconybea/xo-cmake.git xo-cmake 2026-06-06 21:19:03 -04:00
etc/xo xo-cmake: now via git subrepo [GIT] 2026-06-06 21:22:31 -04:00
share/xo-macros git subrepo clone git@github.com:Rconybea/xo-cmake.git xo-cmake 2026-06-06 21:19:03 -04:00
.gitignore git subrepo clone git@github.com:Rconybea/xo-cmake.git xo-cmake 2026-06-06 21:19:03 -04:00
.gitrepo git subrepo push xo-cmake 2026-06-06 21:37:42 -04:00
CMakeLists.txt git subrepo clone git@github.com:Rconybea/xo-cmake.git xo-cmake 2026-06-06 21:19:03 -04:00
FAQ git subrepo clone git@github.com:Rconybea/xo-cmake.git xo-cmake 2026-06-06 21:19:03 -04:00
README.md git subrepo clone git@github.com:Rconybea/xo-cmake.git xo-cmake 2026-06-06 21:19:03 -04:00

XO cmake modules

Collects cmake macros to be shared across XO projects (e.g. indentlog, reflect, kalman, ..)

Features

  • support for both manyrepo and monorepo projects
  • support for generating cmake xxxConfig.cmake files, so cmake find_package() works reliably
  • support for header-only libraries
  • support for pybind11 libraries
  • documentation generation using doxygen + breathe + sphinx
  • code coverage using ccov + lcov

Getting Started

copy repo

$ git clone https://github.com:rconybea/xo-cmake.git

configure + install

$ cd xo-cmake
$ cmake -DCMAKE_INSTALL_PREFIX=/usr/local -B .build -S .   # ..or desired prefix
$ cmake --install .build

use from a cmake project

In some project foo:

$ cd foo
$ mkdir cmake
$ cp $PREFIX/share/xo-macros/xo-bootstrap-macros.cmake cmake/

xo-bootstrap-macros-cmake has two vital jobs:

  1. set XO_CMAKE_CONFIG_EXECUTABLE (locate xo-cmake-config)
  2. set CMAKE_MODULE_PATH (obtained from xo-cmake-config --cmake-module-path)

then in foo/CMakeLists.txt:

include(cmake/xo-bootstrap-macros.cmake)

xo_cxx_toplevel_options3()

Now as long as $PREFIX/bin is in PATH:

$ cd mybuild
$ cmake path/to/foo/source

or set XO_CMAKE_CONFIG_EXECUTABLE and CMAKE_MODULE_PATH

In some project foo:

$ cd mybuild
$ cmake -DXO_CMAKE_CONFIG_EXECUTABLE=xo-cmake-config -DCMAKE_MODULE_PATH=$(xo-cmake-config --cmake-module-path) path/to/foo/source