From a2ae052c82dd7165184c031242d0be8f6b67e5ce Mon Sep 17 00:00:00 2001 From: Alvin Wong Date: Sat, 4 Jul 2020 22:32:18 +0800 Subject: [PATCH] Add `serde` example --- examples/serde.rs | 74 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 examples/serde.rs diff --git a/examples/serde.rs b/examples/serde.rs new file mode 100644 index 00000000..ae3ae6a9 --- /dev/null +++ b/examples/serde.rs @@ -0,0 +1,74 @@ +#[cfg(not(feature = "serde"))] +fn main() { + println!("This example requires the feature `serde`. Use `cargo run --features serde --example serde`."); +} + +#[cfg(feature = "serde")] +fn main() { + example::ser(); + println!(); + example::de(); +} + +#[cfg(feature = "serde")] +mod example { + use rhai::{de::from_dynamic, ser::to_dynamic}; + use rhai::{Dynamic, Engine, Map}; + + #[derive(Debug, serde::Serialize, serde::Deserialize)] + struct Point { + x: f64, + y: f64, + } + + #[derive(Debug, serde::Serialize, serde::Deserialize)] + struct MyStruct { + a: i64, + b: Vec, + c: bool, + d: Point, + } + + pub fn ser() { + let x = MyStruct { + a: 42, + b: vec!["hello".into(), "world".into()], + c: true, + d: Point { + x: 123.456, + y: 999.0, + }, + }; + + println!("Source struct: {:#?}", x); + + // Convert the 'MyStruct' into a 'Dynamic' + let map: Dynamic = to_dynamic(x).unwrap(); + + assert!(map.is::()); + println!("Serialized to Dynamic: {:#?}", map); + } + + pub fn de() { + let engine = Engine::new(); + let result: Dynamic = engine + .eval( + r#" + #{ + a: 42, + b: [ "hello", "world" ], + c: true, + d: #{ x: 123.456, y: 999.0 } + } + "#, + ) + .unwrap(); + + println!("Source Dynamic: {:#?}", result); + + // Convert the 'Dynamic' object map into 'MyStruct' + let x: MyStruct = from_dynamic(&result).unwrap(); + + println!("Deserialized to struct: {:#?}", x); + } +}