| .. | ||
| .github/workflows | ||
| cmake | ||
| docs | ||
| example | ||
| include/xo/unit | ||
| pkgs | ||
| utest | ||
| .gitignore | ||
| CMakeLists.txt | ||
| flake.nix | ||
| LICENSE | ||
| README.md | ||
unit library
Provides compile-time dimension checking and scaling.
Similar in spirit to boost::units, but:
- streamlined: assumes modern (c++20) support
- supports fractional dimensions (rational powers)
Documentation
- xo-unit documentation [under construction]: documentation
- unit test coverage here: coverage
Example
#include "xo/unit/quantity.hpp"
#include "xo/unit/quantity_iostream.hpp"
namespace q = xo::qty::qty;
namespace u = xo::qty::u;
constexpr auto t = q::minutes(2);
constexpr auto d = q::kilometers(2.5);
constexpr auto t2 = t*t; // unit will be min^-2
constexpr auto a = d / t2; // unit will be km.min^-2
// convert to m.s^-2
constexpr quantity<u::meter / (u::second * u::second)> a2 = a;
//constexpr quantity<u::meter> a3 = a; // dimension mismatch, will not compile
// get dimensionless scale value
double x = a2.scale();
Getting Started
See full install instructions for other installation strategies.
build + install xo-cmake dependency
Installs a few cmake ingredients, along with build assistant xo-build for XO projects such as this one.
build + install other XO dependencies
$ xo-build --clone --configure --build --install xo-flatstring
$ xo-build --clone --configure --build --install xo-ratio
Note: can use -n to dry-run here
copy xo-unit repository locally
$ xo-build --clone xo-unit
or equivalently
$ git clone https://github.com/rconybea/xo-unit
build + install xo-unit
$ xo-build --configure --build --install xo-unit
or equivalently:
$ PREFIX=/usr/local # or wherever you prefer
$ cmake -DCMAKE_INSTALL_PREFIX=${PREFIX} -S xo-unit -B xo-unit/.build
$ cmake --build xo-unit/.build -j
$ cmake --install xo-unit/.build
build documentation
$ cd xo-unit
$ cmake -DCMAKE_INSTALL_PREFIX=${PREFIX} --build .build -- sphinx
When this completes, can point local browser to xo-unit/.build/docs/sphinx/index.html.
build for unit test coverage
(Note that unit tests involve additional dependencies):
$ xo-build --clone --configure --build --install xo-indentlog
$ xo-build --clone --configure --build --install xo-randomgen
$ cmake -DCMAKE_BUILD_TYPE=coverage -DCMAKE_INSTALL_PREFIX=$PREFIX -DENABLE_TESTING=1 xo-unit/.build-ccov
$ cmake --build xo-unit/.build-ccov
run coverage-enabled unit tests:
$ cmake --build xo-unit/.build-ccov -- test
generate html+text coverage report:
$ xo-unit/.build-ccov/gen-ccov
To see coverage, can point local browser to xo-unit/.build-ccov/ccov/html/index.html
LSP support
$ cd xo-unit
$ ln -s .build/compile_commands.json # lsp will look for compile_commands.json in the root of the source tree