Go to file
David Tolnay e5c4294bdf
Remove pseudo copyright lines and boilerplate
2019-04-30 02:13:04 -07:00
src Remove pseudo copyright lines and boilerplate 2019-04-30 02:13:04 -07:00
tests Remove pseudo copyright lines and boilerplate 2019-04-30 02:13:04 -07:00
.gitignore Add redirect from top-level index.html 2016-02-24 23:55:19 -08:00
.travis.yml Update to stable clippy 2019-02-21 15:50:26 -08:00
Cargo.toml Release 0.8.8 2018-12-01 15:32:12 -08:00
LICENSE-APACHE Relicense under dual MIT/Apache-2.0 2016-02-27 15:08:48 -08:00
LICENSE-MIT Remove pseudo copyright lines and boilerplate 2019-04-30 02:13:04 -07:00
README.md Update documentation to 2018 edition 2019-04-30 02:08:14 -07:00

README.md

Serde YAML

Build Status Latest Version Rust Documentation

This crate is a Rust library for using the Serde serialization framework with data in YAML file format.

This library does not reimplement a YAML parser; it uses yaml-rust which is a pure Rust YAML 1.2 implementation.

Dependency

[dependencies]
serde = "1.0"
serde_yaml = "0.8"

Release notes are available under GitHub releases.

Using Serde YAML

API documentation is available in rustdoc form but the general idea is:

use std::collections::BTreeMap;

fn main() {
    // You have some type.
    let mut map = BTreeMap::new();
    map.insert("x".to_string(), 1.0);
    map.insert("y".to_string(), 2.0);

    // Serialize it to a YAML string.
    let s = serde_yaml::to_string(&map).unwrap();
    assert_eq!(s, "---\nx: 1\ny: 2");

    // Deserialize it back to a Rust type.
    let deserialized_map: BTreeMap<String, f64> = serde_yaml::from_str(&s).unwrap();
    assert_eq!(map, deserialized_map);
}

It can also be used with Serde's derive macros to handle structs and enums defined by your program.

[dependencies]
serde = { version = "1.0", features = ["derive"] }
serde_yaml = "0.8"
use serde::{Serialize, Deserialize};

#[derive(Debug, PartialEq, Serialize, Deserialize)]
struct Point {
    x: f64,
    y: f64,
}

fn main() {
    let point = Point { x: 1.0, y: 2.0 };

    let s = serde_yaml::to_string(&point).unwrap();
    assert_eq!(s, "---\nx: 1\ny: 2");

    let deserialized_point: Point = serde_yaml::from_str(&s).unwrap();
    assert_eq!(point, deserialized_point);
}

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Serde YAML by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.