schematika arithmetic with facets + multi-argument runtime polymorphism
  • C++ 94.2%
  • CMake 5.8%
Find a file
2024-04-17 10:57:11 -04:00
cmake xo-flatstring: build: + GNUInstallDirs 2024-04-16 21:38:27 -04:00
docs xo-flatstring: docs: + source code link + tweaks 2024-04-17 10:56:47 -04:00
example tidy: cleanup stray stringlit -> flatstring naming 2024-04-16 21:37:48 -04:00
include/xo/flatstring xo-flatstring: ++ doc improvements 2024-04-16 17:44:55 -04:00
utest xo-flatstring: bugfix: include path in utest 2024-04-17 10:57:11 -04:00
.gitignore xo-flatstring: + .gitignore 2024-04-16 17:26:19 -04:00
CMakeLists.txt xo-flatstring: build: + GNUInstallDirs 2024-04-16 21:38:27 -04:00
LICENSE xo-flatstring: + LICENSE 2024-04-16 21:39:13 -04:00
README.md xo-flatstring: ++ README 2024-04-16 21:38:59 -04:00

flatstring library

Fixed-length no-allocation string implementation.

Features:

  • char array representation with maximum size set at compile time.
  • compile time construction from char array and string concatenation
  • pointer-free implementation, instances can be used as template arguments
  • To the extent practical, provides the same api as std::string: includes iterators, access methods, assignment, conversion operators.

Limitations:

  • requires c++20
  • not resizable.
  • does not support wide characters.
  • (asof April 2024) missing features: insert, erase, push_back, append, replace, find, compare, starts_with, ends_with, contains, substr.

Getting started

build + install

$ cd xo-flatstring
$ mkdir .build
$ PREFIX=/usr/local   # for example
$ cmake -DCMAKE_INSTALL_PREFIX=${PREFIX} -B .build
$ cmake --build .build
$ cmake --install .build

build documentation

$ cd xo-flatstring
$ cmake --build .build -- docs

When complete, point local browser to xo-flatstring/.build/docs/sphinx/index.html

build with test coverage

$ cd xo-flatstring
$ mkdir .build-ccov
$ cmake -DCMAKE_INSTALL_PREFIX=$PREFIX -DCODE_COVERAGE=ON -DCMAKE_BUILD_TYPE=Debug -B .build-ccov
$ cmake --build .build-ccov

run coverage-enabled unit tests

$ (cd .build-ccov && ctest)

generate html+text coverage report

$ .build-ccov/gen-ccov

browse to .build-ccov/ccov/html/index.html

LSP support

$ cd xo-flatstring
$ ln -s .build/compile_commands.json