1 unstable release
0.1.0-alpha.1 | Sep 18, 2024 |
---|
#792 in Encoding
30KB
759 lines
serde-ast
Define an AST representation of serde
serialization.
use serde::{Deserialize, Serialize};
use serde_ast::to_ast;
#[derive(Serialize, Deserialize)]
struct Example {
hello: String,
}
let example = Example { hello: "World".to_string() };
let ast = to_ast(&example).expect("serialize to_ast");
println!("{}", ast);
Struct {
name: "Example",
len: 1,
ops: [
Field {
key: "hello",
value: Str(
"World",
),
},
],
}
Serializing the [Ast] is equivalent to directly serializing the original value.
// serialize the ast
let output = serde_json::to_string(&ast).expect("serde_json::to_string");
// serialize the value directly
let direct = serde_json::to_string(&example).expect("serde_json::to_string");
// the result is the same
assert_eq!(output, direct);
lib.rs
:
Implements an [Ast] representation of [serde] serialization.
This allows to see the serialization calls made, inspect them, traverse, edit, or serialize with a serde::Serializer.
#[derive(Serialize, Deserialize)]
struct Example {
hello: String,
}
let example = Example { hello: "World".to_string() };
let ast = to_ast(&example).expect("serialize to_ast");
println!("{}", ast);
Struct {
name: "Example",
len: 1,
ops: [
Field {
key: "hello",
value: Str(
"World",
),
},
],
}
Serializing the [Ast] is equivalent to directly serializing the original value.
// serialize the ast
let output = serde_json::to_string(&ast).expect("serde_json::to_string");
// serialize the value directly
let direct = serde_json::to_string(&example).expect("serde_json::to_string");
// the result is the same
assert_eq!(output, direct);
Dependencies
~0.3–1MB
~21K SLoC