saphyr-serde/parser
2015-06-04 16:36:03 +08:00
..
examples Add LICENSE and build status 2015-05-31 00:13:21 +08:00
src Better code coverage 2015-06-04 16:10:43 +08:00
tests Add LICENSE and build status 2015-05-31 00:13:21 +08:00
.gitignore Fix warnings 2015-05-24 14:37:36 +08:00
.travis.yml Add document 2015-05-31 17:59:43 +08:00
appveyor.yml Add appveyor and example 2015-05-30 23:35:25 +08:00
Cargo.toml Add repository to Cargo.toml 2015-06-04 16:36:03 +08:00
LICENSE Add LICENSE and build status 2015-05-31 00:13:21 +08:00
Readme.md Update Readme.md 2015-06-02 00:53:32 +08:00

yaml-rust

The missing YAML 1.2 implementation for Rust.

Build Status Build status

yaml-rust is a pure Rust YAML 1.2 implementation without any FFI and crate dependencies, which enjoys the memory safe property and other benefits from the Rust language. The parser is heavily influenced by libyaml and yaml-cpp.

This crate works on all Rust supported platforms and Rust 1.0.0 and nightly!

See Document

NOTE: This library is still under heavily development.

WARNING: This library needs more tests and it is NOT ready for parsing arbitrary user input from untrusted source.

Quick Start

Adding the following to the Cargo.toml in your project:

[dependencies.yaml-rust]
git = "https://github.com/chyh1990/yaml-rust.git"

and import using extern crate:

extern crate yaml_rust;

Use yaml::YamlLoader to load the YAML documents and access it as Vec/HashMap:

extern crate yaml_rust;
use yaml_rust::{YamlLoader, YamlEmitter};

fn main() {
    let s =
"
foo:
    - list1
    - list2
bar:
    - 1
    - 2.0
";
    let docs = YamlLoader::load_from_str(s).unwrap();

    // Multi document support, doc is a yaml::Yaml
    let doc = &docs[0];

    // Debug support
    println!("{:?}", doc);

    // Index access for map & array
    assert_eq!(doc["foo"][0].as_str().unwrap(), "list1");
    assert_eq!(doc["bar"][1].as_f64().unwrap(), 2.0);

    // Chained key/array access is checked and won't panic,
    // return BadValue if they are not exist.
    assert!(doc["INVALID_KEY"][100].is_badvalue());
    
    // Dump the YAML object
    let mut out_str = String::new();
    {
        let mut emitter = YamlEmitter::new(&mut out_str);
        emitter.dump(doc).unwrap(); // dump the YAML object to a String
    }
    println!("{}", out_str);
}

Note that yaml::Yaml implements Index<&'a str> & Index<usize>:

  • Index<usize> assumes the container is an Array
  • Index<&'a str> assumes the container is a string to value Map
  • otherwise, Yaml::BadValue is returned

If your document does not conform to this convention (e.g. map with complex type key), you can use the Yaml::as_XXX family API to access your documents.

Features

  • Pure Rust
  • Ruby-like Array/Hash access API
  • Low-level YAML events emission

Specification Compliance

This implementation aims to provide YAML parser fully compatible with the YAML 1.2 specification. The pasrser can correctly parse almost all examples in the specification, except for the following known bugs:

  • Empty plain scalar in certain contexts

However, the widely used library libyaml also fails to parse these examples, so it may not be a huge problem for most users.

Goals

  • Encoder
  • Tag directive
  • Alias while desearilization

Contribution

Fork & PR on Github.