Using ryml in your project
Quickstart build samples
These samples show different ways of getting ryml into your application. All the samples use the same quickstart executable source, but are built in different ways, showing several alternatives to integrate ryml into your project. We also encourage you to refer to the quickstart docs, which extensively cover the functionality that you may want out of ryml.
If you’re in a rush to start, try this:
Note
Try the quickstart!
First create this CMakeLists.txt
:
cmake_minimum_required(VERSION 3.13)
project(my-quickstart LANGUAGES CXX)
include(FetchContent)
FetchContent_Declare(ryml
GIT_REPOSITORY https://github.com/biojppm/rapidyaml.git
GIT_TAG v0.6.0
GIT_SHALLOW FALSE # ensure submodules are checked out
)
FetchContent_MakeAvailable(ryml)
add_executable(my-quickstart ${ryml_SOURCE_DIR}/samples/quickstart.cpp)
target_link_libraries(my-quickstart ryml::ryml)
add_custom_target(run my-quickstart
COMMAND $<TARGET_FILE:my-quickstart>
DEPENDS my-quickstart)
Now run the following commands in the same folder:
# configure the project
cmake -S . -B build
# build and run
cmake --build build --target ryml-quickstart -j
# optionally, open in your IDE
cmake --open build
For alternative ways, continue reading this section.
Each sample brings a run.sh
script with the sequence of commands
required to successfully build and run the application (this is a bash
script and runs in Linux and MacOS, but it is also possible to run in
Windows via Git Bash or the WSL). Click on the links below to find out
more about each sample:
Sample name |
ryml is part of build? |
cmake file |
commands |
---|---|---|---|
yes
ryml brought as a single
header, not as a library
|
|||
yes
ryml brought as library
but from the single header
|
|||
yes |
|||
yes |
|||
no
needs prior install or package
|
As a single-header
ryml is provided chiefly as a cmake library project, but it can also be used as a single header file, and there is a tool to amalgamate the code into a single header file. The amalgamated header file is provided with each release, but you can also generate a customized file suiting your particular needs (or commit):
[user@host rapidyaml]$ python3 tools/amalgamate.py -h
usage: amalgamate.py [-h] [--c4core | --no-c4core] [--fastfloat | --no-fastfloat] [--stl | --no-stl] [output]
positional arguments:
output output file. defaults to stdout
optional arguments:
-h, --help show this help message and exit
--c4core amalgamate c4core together with ryml. this is the default.
--no-c4core amalgamate c4core together with ryml. the default is --c4core.
--fastfloat enable fastfloat library. this is the default.
--no-fastfloat enable fastfloat library. the default is --fastfloat.
--stl enable stl interop. this is the default.
--no-stl enable stl interop. the default is --stl.
The amalgamated header file contains all the function declarations and
definitions. To use it in the project, #include
the header at will
in any header or source file in the project, but in one source file,
and only in that one source file, #define
the macro
RYML_SINGLE_HDR_DEFINE_NOW
before including the header. This
will enable the function definitions. For example:
// foo.h
#include <ryml_all.hpp>
// foo.cpp
// ensure that foo.h is not included before this define!
#define RYML_SINGLE_HDR_DEFINE_NOW
#include <foo.h>
If you wish to package the single header into a shared library, then
you will need to define the preprocessor symbol RYML_SHARED
during
compilation.
From a package manager
ryml is available in most package managers (thanks to all the contributors!) and linux distributions.
Note
These packages are maintained downstream of this repository, so if you have issues with the package, file a report with the respective package maintainer.
Here’s a quick roundup (possibly outdated):
Package managers
Linux distributions:
Arch Linux/Manjaro:
-
dnf install rapidyaml-devel
dnf install python3-rapidyaml
Although package managers are very useful for quickly getting up to speed, the advised way is still to bring ryml as a submodule of your project, building both together. This makes it easy to track any upstream changes in ryml. Also, ryml is small and quick to build, so there’s not much of a cost for building it with your project.
As a library
The single header file is a good approach to quickly try the library, but if you wish to make good use of CMake and its tooling ecosystem, (and get better compile times), then ryml has you covered.
As with any other cmake library, you have the option to integrate ryml into your project’s build setup, thereby building ryml together with your project, or – prior to configuring your project – you can have ryml installed either manually or through package managers.
Currently cmake is required to build ryml; we recommend a recent cmake version, at least 3.13.
Note that ryml uses submodules. Take care to use the –recursive flag when cloning the repo, to ensure ryml’s submodules are checked out as well:
git clone --recursive https://github.com/biojppm/rapidyaml
If you omit –recursive, after cloning you will have to do git submodule update –init –recursive to ensure ryml’s submodules are checked out.
Forcing ryml to use a different c4core version
ryml is strongly coupled to c4core, and this is reinforced by the fact that c4core is a submodule of the current repo. However, it is still possible to use a c4core version different from the one in the repo (of course, only if there are no incompatibilities between the versions). You can find out how to achieve this by looking at the custom_c4core sample.
CMake build settings for ryml
The following cmake variables can be used to control the build behavior of ryml:
RYML_WITH_TAB_TOKENS=ON/OFF
. Enable/disable support for tabs as valid container tokens after:
and-
. Defaults toOFF
, because this may cost up to 10% in processing time.RYML_DEFAULT_CALLBACKS=ON/OFF
. Enable/disable ryml’s default implementation of error and allocation callbacks. Defaults toON
.RYML_DEFAULT_CALLBACK_USES_EXCEPTIONS=ON/OFF
- Enable/disable the same-named macro, which will make the default error handler provided by ryml throw astd::runtime_error
exception.RYML_USE_ASSERT
- enable assertions in the code regardless of build type. This is disabled by default. Failed assertions will trigger a call to the error callback.RYML_STANDALONE=ON/OFF
. ryml uses c4core, a C++ library with low-level multi-platform utilities for C++. WhenRYML_STANDALONE=ON
, c4core is incorporated into ryml as if it is the same library. Defaults toON
.RYML_INSTALL=ON/OFF
. enable/disable install target. Defaults toON
.
If you’re developing ryml or just debugging problems with ryml itself, the following cmake variables can be helpful:
RYML_DEV=ON/OFF
: a bool variable which enables development targets such as unit tests, benchmarks, etc. Defaults toOFF
.RYML_DBG=ON/OFF
: a bool variable which enables verbose prints from parsing code; can be useful to figure out parsing problems. Defaults toOFF
.