commit | 9018a7820cc8e1fa08a27fe43096608cc0e336aa | [log] [tgz] |
---|---|---|
author | Android Build Coastguard Worker <[email protected]> | Wed Nov 15 00:14:26 2023 +0000 |
committer | Android Build Coastguard Worker <[email protected]> | Wed Nov 15 00:14:26 2023 +0000 |
tree | bc9a93f9b6ee795502937b958fe2a7df6bce38f1 | |
parent | dbaa37bcc3b6bbcba4216ac875066fc2c89db919 [diff] | |
parent | 20db17911dc856eefef9058804f30401ed0a3e7b [diff] |
Snap for 11097608 from 20db17911dc856eefef9058804f30401ed0a3e7b to 24Q1-release Change-Id: I40fec677a51814e83653f67fb4d5d5ecaa62cdc1
This crate allows you to parse and modify toml documents, while preserving comments, spaces and relative order or items.
toml_edit
is primarily tailored for cargo-edit needs.
use toml_edit::{Document, value}; fn main() { let toml = r#" "hello" = 'toml!' # comment ['a'.b] "#; let mut doc = toml.parse::<Document>().expect("invalid doc"); assert_eq!(doc.to_string(), toml); // let's add a new key/value pair inside a.b: c = {d = "hello"} doc["a"]["b"]["c"]["d"] = value("hello"); // autoformat inline table a.b.c: { d = "hello" } doc["a"]["b"]["c"].as_inline_table_mut().map(|t| t.fmt()); let expected = r#" "hello" = 'toml!' # comment ['a'.b] c = { d = "hello" } "#; assert_eq!(doc.to_string(), expected); }
Things it does not preserve:
Licensed under either of
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.