1 unstable release
0.1.0 | Apr 19, 2023 |
---|
#2621 in Parser implementations
41KB
600 lines
Json Pointer and Operator Overload
Overview
Though it is wonderful to use serde
crate to serialize and deserialize json
between native rust type, there is still case to use untyped json tree
directely, may because the json tree is too freely or too loose to map to some
strong type well, for example the json schema structure, or any other reason.
This crate focus to operate on a single node in json tree, based on json pointer, mainly followed the standard json pointer syntax, and with operator overload to make it more convenient and intuitive.
- Use
path()
orpath_mut()
method to create an json pointer or mutable one, we need new type to support operator overlaod. - Use path opeator
/
to point to further deeper sub node. - Use pipe operator
|
to read scalar primitive value from pointed node, may finallize the/
operator chian, which would read asget_or
. - Use operator
<<
to put a new scalar value to node, or push more item to array or object node. - Also overralod operator
*
and so the pointer can implicitly used asOpion<&Value>
.
Dependency
serde_json
, the json pointer is pointing toserde_json::Value
.toml
, if enable featuretoml
, as the data structure of toml is very similar to json.
Extension
The json or toml pointer is actually concrete type of more generic Value
pointer. So it is possible to implement pointer and operator overload for
other json-like data structure, or common value node origanized in a tree,
provided implement the following trait:
ValuePath
, for opertor/
;ValueReader
, for opertor|
;ValueWriter
, for opertor<<
.
If you implemnt some Value
struct from begining youself, then it is further
possible to overload operator for &Value
directely, no need to use path()
method to begin a /
operator chain.
Example View
let v: Value = "{...}".parse().unwrap(); # got a Value tree from anywhere
let node = v.path() / "sub" / 0 / "subdeep";
let node = v.path() / "sub/0/subdeep";
let node = v.pathto("sub/0/subdeep");
let scalar = node | 0;
let scalar = v.path() / "path" / "to" / "string-node" | "";
let mut v: Value = ...;
let _ = v.path_mut() / "path" / "to" / "leaf" << "some new value";
let _ = v.path_mut() / "path" / "to" / "object" << ("key", "val") << ("k2", "v2");
let _ = v.path_mut() / "path" / "to" / "array" << ("val",) << ["v2"];
Please refer to documatation for more detailed and runable examples and tests.
Dependencies
~0.5–1MB
~21K SLoC