73ef0060aa
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 | 1 month ago | |
docs | 6 months ago | |
include/yaml-cpp | 1 month ago | |
src | 3 weeks ago | |
test | 1 month ago | |
util | 1 year ago | |
.bazelignore | 1 year ago | |
.clang-format | 9 years ago | |
.codedocs | 8 years ago | |
.gitignore | 5 years ago | |
BUILD.bazel | 3 years ago | |
CMakeLists.txt | 6 months ago | |
CONTRIBUTING.md | 1 month ago | |
LICENSE | 10 years ago | |
MODULE.bazel | 1 year ago | |
MODULE.bazel.lock | 1 month ago | |
README.md | 1 month ago | |
SECURITY.md | 1 year ago | |
cmake_uninstall.cmake.in | 2 years ago | |
install.txt | 15 years ago | |
yaml-cpp-config.cmake.in | 1 year ago | |
yaml-cpp.pc.in | 3 years ago |
README.md
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
. -
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: