Description
yaml-cpp is a YAML parser and emitter in C++ matching the YAML 1.2 spec.
yaml-cpp alternatives and similar libraries
Based on the "JSON" category.
Alternatively, view yaml-cpp alternatives based on common mentions on social networks and blogs.
-
simdjson
Parsing gigabytes of JSON per second : used by Facebook/Meta Velox, the Node.js runtime, ClickHouse, WatermelonDB, Apache Doris, Milvus, StarRocks -
JSMN
Jsmn is a world fastest JSON parser/tokenizer. This is the official repo replacing the old one at Bitbucket -
json-c
https://github.com/json-c/json-c is the official code repository for json-c. See the wiki for release tarballs for download. API docs at http://json-c.github.io/json-c/ -
frozen
JSON parser and generator for C/C++ with scanf/printf like interface. Targeting embedded systems. -
json_dto
A small header-only library for converting data between json representation and c++ structs
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of yaml-cpp or a related project?
README
yaml-cpp
yaml-cpp
is a YAML parser and emitter in C++ matching the YAML 1.2 spec.
Usage
See Tutorial and How to Emit YAML for reference. For the old API (until 0.5.0), see How To Parse A Document.
Any Problems?
If you find a bug, post an issue! If you have questions about how to use yaml-cpp, please post it on http://stackoverflow.com and tag it yaml-cpp
.
How to Build
yaml-cpp
uses CMake to support cross-platform building. Install CMake (Resources -> Download) before proceeding. The basic steps to build are:
Note: If you don't use the provided installer for your platform, make sure that you add CMake
's bin folder to your path.
1. Navigate into the source directory, create build folder and run CMake
:
mkdir build
cd build
cmake [-G generator] [-DYAML_BUILD_SHARED_LIBS=on|OFF] ..
The
generator
option is the build system you'd like to use. Runcmake
without arguments to see a full list of available generators.- On Windows, you might use "Visual Studio 12 2013" (VS 2013 32-bits), or "Visual Studio 14 2015 Win64" (VS 2015 64-bits).
- On OS X, you might use "Xcode".
- On a UNIX-like system, omit the option (for a Makefile).
yaml-cpp
builds a static library by default, you may want to build a shared library by specifying-DYAML_BUILD_SHARED_LIBS=ON
.For more options on customizing the build, see the CMakeLists.txt file.
2. Build it!
- The command you'll need to run depends on the generator you chose earlier.
Note: To clean up, just remove the build
directory.
Recent Releases
yaml-cpp 0.6.0 released! This release requires C++11, and no longer depends on Boost.
yaml-cpp 0.3.0 is still available if you want the old API.
The old API will continue to be supported, and will still receive bugfixes! The 0.3.x and 0.4.x versions will be old API releases, and 0.5.x and above will all be new API releases.
API Documentation
The autogenerated API reference is hosted on CodeDocs
Third Party Integrations
The following projects are not officially supported: