A YAML parser and emitter in C++
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Go to file
Jeremy Nimmer 73ef0060aa Avoid including <iostream> in library code
Including iostream means introducing the static (global) constructors
and destructors for std::cin, std::cerr, and std::cout. That extra
init and fini code is undesirable when those streams are not actually
used.

Instead, we'll use the narrower includes for exactly what's needed,
i.e., <istream> or <ostream>.
3 weeks ago
.github Exclude ubuntu/C++ 11/googletest system from the test matrix since it doesn't compile. 1 month ago
docs doc, fix: invalid liquid '{{...}}' tags 6 months ago
include/yaml-cpp emitter: Support std::string_view 4 weeks ago
src Avoid including <iostream> in library code 3 weeks ago
test emitter: Support std::string_view 4 weeks ago
util Resolve warnings about unreferenced parameter 'style' in NullEventHandlers (#1193) 1 year ago
.bazelignore bzlmodded (#1224) 1 year ago
.clang-format Update .clang-format to use C++ 11 style. 9 years ago
.codedocs test: Upgrade googlemock 1.7.0 to googletest 1.8.0 8 years ago
.gitignore Add bazel Support (#724) 5 years ago
BUILD.bazel Improve bazel build for Windows. (#1100) 3 years ago
CMakeLists.txt Run format target from project root 6 months ago
CONTRIBUTING.md Update CONTRIBUTING.md 4 weeks ago
LICENSE Rename license file and update copyright date. 10 years ago
MODULE.bazel bzlmodded (#1224) 1 year ago
MODULE.bazel.lock Fix bazel build, and commit module lock file. 1 month ago
README.md Update README.md 1 month ago
SECURITY.md Create Security-Policy (#1189) 1 year ago
cmake_uninstall.cmake.in Add the "make uninstall" target (#1130) 2 years ago
install.txt Added newline to install and license files 15 years ago
yaml-cpp-config.cmake.in Update yaml-cpp-config.cmake.in 1 year ago
yaml-cpp.pc.in Fix .pc paths for absolute GNUInstallDirs (#1058) 3 years ago

README.md

yaml-cpp Build Status Documentation

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. Run cmake 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.

  • Debug mode of the GNU standard C++ library can be used when both yaml-cpp and client code is compiled with the _GLIBCXX_DEBUG flag (e.g. by calling CMake with -D CMAKE_CXX_FLAGS_DEBUG='-g -D_GLIBCXX_DEBUG' option).

    Note that for yaml-cpp unit tests to run successfully, the GoogleTest library also must be built with this flag, i.e. the system one cannot be used (the YAML_USE_SYSTEM_GTEST CMake option must be OFF, which is the default).

  • 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.

How to Integrate it within your project using CMake

You can use for example FetchContent :

include(FetchContent)

FetchContent_Declare(
  yaml-cpp
  GIT_REPOSITORY https://github.com/jbeder/yaml-cpp.git
  GIT_TAG <tag_name> # Can be a tag (yaml-cpp-x.x.x), a commit hash, or a branch name (master)
)
FetchContent_MakeAvailable(yaml-cpp)

target_link_libraries(YOUR_LIBRARY PUBLIC yaml-cpp::yaml-cpp) # The library or executable that require yaml-cpp library

Recent Releases

yaml-cpp 0.7.0 released!

yaml-cpp 0.3.0 is still available if you want the old API.

The old API will stop receiving bugfixes in 2026. The 0.3.x versions provide the old API, and 0.5.x and above all provide the new API.

API Documentation

The autogenerated API reference is hosted on CodeDocs

Third Party Integrations

The following projects are not officially supported: