Go to file
Ted Lyngmo 07c4846d04 Make pseudo enum classes into proper enum classes
This changes some constructs like this

    struct FmtScope {
      enum value { Local, Global };
    };
    struct GroupType {
      enum value { NoType, Seq, Map };
    };
    struct FlowType {
      enum value { NoType, Flow, Block };
    };

into this

    enum class FmtScope { Local, Global };
    enum class GroupType { NoType, Seq, Map };
    enum class FlowType { NoType, Flow, Block };

The full list of pseudo enum classes now turned into real enum classes:

enum class State { WaitingForSequenceEntry, WaitingForKey, WaitingForValue };
enum class EmitterNodeType { NoType, Property, Scalar, FlowSeq, BlockSeq, FlowMap, BlockMap };
enum class Type { Verbatim, PrimaryHandle, NamedHandle };
enum class EmitterStyle { Default, Block, Flow };
enum class iterator_type { NoneType, Sequence, Map };
enum class NodeType { Undefined, Null, Scalar, Sequence, Map };
enum class CollectionType { NoCollection, BlockMap, BlockSeq, FlowMap, FlowSeq, CompactMap };
enum class FmtScope { Local, Global };
enum class GroupType { NoType, Seq, Map };
enum class FlowType { NoType, Flow, Block };
enum class StringFormat { Plain, SingleQuoted, DoubleQuoted, Literal };
enum class StringEscaping { None, NonAscii, JSON };

Signed-off-by: Ted Lyngmo <ted@lyncon.se>
2021-04-23 15:38:18 +02:00
docs Support as<uint8_t>/as<int8_t>. 2020-06-15 10:31:59 -05:00
include/yaml-cpp Make pseudo enum classes into proper enum classes 2021-04-23 15:38:18 +02:00
src Make pseudo enum classes into proper enum classes 2021-04-23 15:38:18 +02:00
test Make pseudo enum classes into proper enum classes 2021-04-23 15:38:18 +02:00
util Make pseudo enum classes into proper enum classes 2021-04-23 15:38:18 +02:00
.clang-format Update .clang-format to use C++ 11 style. 2016-04-01 20:06:28 -05:00
.codedocs test: Upgrade googlemock 1.7.0 to googletest 1.8.0 2017-08-24 22:49:17 -05:00
.gitignore Add bazel Support (#724) 2019-09-27 10:11:38 -05:00
.travis.yml Update travis config to use updated versions of OS and compilers. (#845) 2020-04-07 22:46:47 -05:00
appveyor.yml Add the AppVeyor configuration file (#927) 2020-07-23 23:04:02 -05:00
BUILD.bazel Allow including yaml-cpp as system headers (#829) 2020-02-29 22:27:16 -06:00
CMakeLists.txt Enable CMP0091 to use MSVC_RUNTIME_LIBRARY (#913) 2020-07-07 20:38:10 -05:00
CONTRIBUTING.md Update CONTRIBUTING.md 2016-03-28 23:47:21 -05:00
install.txt Added newline to install and license files 2009-12-21 20:35:27 +00:00
LICENSE Rename license file and update copyright date. 2015-03-30 20:32:46 -05:00
README.md Add Qt wrapper gist (#853) 2020-04-26 16:53:02 -05:00
WORKSPACE Add bazel Support (#724) 2019-09-27 10:11:38 -05:00
yaml-cpp-config.cmake.in Add yaml-cpp-config.cmake and yaml-cpp-config-version.cmake files for importing yaml-cpp into external projects (through find_package). 2015-01-24 11:21:26 -06:00
yaml-cpp.pc.in Refactor CMake to use more modern paradigms (#741) 2019-09-27 09:59:53 -05:00

yaml-cpp Build Status Documentation

yaml-cpp is a YAML parser and emitter in C++ matching the YAML 1.2 spec.

To get a feel for how it can be used, see the Tutorial or How to Emit YAML. For the old API (version < 0.5.0), see How To Parse A Document.

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. The basic steps to build are:

  1. Download and install CMake (Resources -> Download).

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, and type:
mkdir build
cd build
  1. Run CMake. The basic syntax is:
cmake [-G generator] [-DYAML_BUILD_SHARED_LIBS=ON|OFF] ..
  • The generator is whatever type of build system you'd like to use. To see a full list of generators on your platform, just run cmake (with no arguments). For example:

    • On Windows, you might use "Visual Studio 12 2013" to generate a Visual Studio 2013 solution or "Visual Studio 14 2015 Win64" to generate a 64-bit Visual Studio 2015 solution.
    • On OS X, you might use "Xcode" to generate an Xcode project
    • On a UNIX-y system, simply omit the option to generate a makefile
  • yaml-cpp defaults to building a static library, but you may build a shared library by specifying -DYAML_BUILD_SHARED_LIBS=ON.

  • For more options on customizing the build, see the CMakeLists.txt file.

  1. Build it!

  2. To clean up, just remove the build directory.

Recent Release

yaml-cpp 0.6.0 has been 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: