2 unstable releases
0.2.0 | Apr 12, 2020 |
---|---|
0.1.0 | Apr 10, 2020 |
#5 in #introspect
Used in spectacle
4KB
Spectacle
Spectacle
recursively walks down the structure on which it is called, visiting each struct field, enum variant, etc. It operates via the Any
trait. It also includes the trail of accessors and selectors describing how to get to the current location from the root object. Given those two things, it is straightforward to find and access the portion of data of interest.
Introspection should not generally be the tool of first resort. However, there are occasions when they are indespensible. The use case which prompted the invention of this crate: writing a strongly-typed serde codec for large, complex, deeply-nested, underspecified JSON blobs. Working from the outside in, it was possible to write types for the outermost containers without much trouble. However, determining the appropriate type for certain uncommon, inner fields was complicated, as there were many examples, deeply nested.
The solution was to introspect, visiting in particular all those values which were still a serde_json::Value
. By printing the representation of each, it was possible to discover the appropriate encoding to use.
Features
-
Spectacle
trait: visitor over contained fields, variants, etc -
impl Spectacle for $primitive
- (default) feature-gated
impl Spectacle for $collection
- feature-gated
impl Spectacle for serde_json::Value
-
#[derive(Spectacle)]
lib.rs
:
Don't use this crate. It's intended for use in exactly one place: spectacle. It does exactly one thing, for spectacle. It is likely to break in other contexts.
Dependencies
~1.5MB
~37K SLoC