Rust:
Arbeider med YAML

Hvordan:

Rust støtter ikke YAML i sitt standardbibliotek, så vi bruker vanligvis tredjepartsbiblioteker som serde (for serialisering og deserialisering av data) i kombinasjon med serde_yaml.

Først, legg til avhengigheter i din Cargo.toml:

[dependencies]
serde = { version = "1.0", features = ["derive"] }
serde_yaml = "0.8"

Nå, la oss se på hvordan man deserialiserer en YAML-streng til en Rust-struktur og serialiserer en Rust-struktur tilbake til en YAML-streng.

Deserialisere YAML til Rust-strukturer

Definer en Rust-struktur som speiler dataene du forventer i YAML. Bruk Serde-attributter for tilpasning om nødvendig.

use serde::{Deserialize, Serialize};
use serde_yaml;

#[derive(Debug, PartialEq, Serialize, Deserialize)]
struct Config {
    name: String,
    durability: i32,
    owner: Owner,
}

#[derive(Debug, PartialEq, Serialize, Deserialize)]
struct Owner {
    name: String,
    age: i32,
}

fn main() {
    let yaml_data = "
name: Shield
durability: 300
owner:
  name: Steve
  age: 25
";

    let deserialized_config: Config = serde_yaml::from_str(yaml_data).unwrap();
    println!("{:?}", deserialized_config);
}

Eksempelutdata ved kjøring av ovennevnte Rust-kode vil være:

Config { name: "Shield", durability: 300, owner: Owner { name: "Steve", age: 25 } }

Serialisere Rust-strukturer til YAML

Dette eksemplet tar Config-strukturen fra forrige seksjon og serialiserer den tilbake til YAML-format.

fn main() {
    let config = Config {
        name: String::from("Axe"),
        durability: 120,
        owner: Owner {
            name: String::from("Alex"),
            age: 30,
        },
    };

    let serialized_yaml = serde_yaml::to_string(&config).unwrap();
    println!("{}", serialized_yaml);
}

Forventet utdata vil være en YAML-formatert streng:

---
name: Axe
durability: 120
owner:
  name: Alex
  age: 30

Disse kodestykkene demonstrerer hvordan du effektivt kan integrere YAML-analyse og -generering i dine Rust-applikasjoner, ved bruk av de populære serde og serde_yaml-bibliotekene, imøtekomme komplekse datastrukturer og tilby enkle, menneskelesbare konfigurasjoner.