Skip to content

Commit

Permalink
Add examples of (de)serializing to & from strings
Browse files Browse the repository at this point in the history
  • Loading branch information
jwodder committed Oct 30, 2023
1 parent dbaf882 commit 8254c86
Showing 1 changed file with 66 additions and 2 deletions.
68 changes: 66 additions & 2 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -266,7 +266,40 @@ impl Format {
}

/// Serialize a value to a string in this format
///
#[cfg_attr(feature = "json", doc = concat!(
"# Example\n",
"\n",
"```\n",
"use cfgfifo::Format;\n",
"use serde::Serialize;\n",
"\n",
"#[derive(Clone, Debug, Eq, PartialEq, Serialize)]\n",
"struct Data {\n",
" name: String,\n",
" size: u32,\n",
" enabled: bool,\n",
"}\n",
"\n",
"let datum = Data {\n",
" name: String::from(\"Example\"),\n",
" size: 42,\n",
" enabled: true,\n",
"};\n",
"\n",
"let s = Format::Json.dump_to_string(&datum).unwrap();\n",
"\n",
"assert_eq!(\n",
" s,\n",
" concat!(\n",
" \"{\\n\",\n",
" \" \\\"name\\\": \\\"Example\\\",\\n\",\n",
" \" \\\"size\\\": 42,\\n\",\n",
" \" \\\"enabled\\\": true\\n\",\n",
" \"}\"\n",
" )\n",
");\n",
"```\n",
))]
/// # Errors
///
/// Returns an error if the underlying serializer returns an error.
Expand All @@ -292,7 +325,38 @@ impl Format {
}

/// Deserialize a string in this format
///
#[cfg_attr(feature = "json", doc = concat!(
"# Example\n",
"\n",
"```\n",
"use cfgfifo::Format;\n",
"use serde::Deserialize;\n",
"\n",
"#[derive(Clone, Debug, Deserialize, Eq, PartialEq)]\n",
"struct Data {\n",
" name: String,\n",
" size: u32,\n",
" enabled: bool,\n",
"}\n",
"\n",
"let s = concat!(\n",
" \"name: Example\\n\",\n",
" \"size: 42\\n\",\n",
" \"enabled: true\\n\",\n",
");\n",
"\n",
"let datum: Data = Format::Yaml.load_from_str(s).unwrap();\n",
"\n",
"assert_eq!(\n",
" datum,\n",
" Data {\n",
" name: String::from(\"Example\"),\n",
" size: 42,\n",
" enabled: true,\n",
" }\n",
");\n",
"```\n",
))]
/// # Errors
///
/// Returns an error if the underlying deserializer returns an error.
Expand Down

0 comments on commit 8254c86

Please sign in to comment.