11 releases (6 stable)

1.1.3 Jul 25, 2024
1.1.2 Feb 1, 2020
1.1.0 Feb 8, 2019
1.0.1 Jan 2, 2017
0.0.1 May 6, 2015

#330 in Parser implementations

Download history 43/week @ 2024-08-05 45/week @ 2024-08-12 27/week @ 2024-08-19 46/week @ 2024-08-26 16/week @ 2024-09-02 22/week @ 2024-09-09 71/week @ 2024-09-16 129/week @ 2024-09-23 47/week @ 2024-09-30 69/week @ 2024-10-07 103/week @ 2024-10-14 19/week @ 2024-10-21 26/week @ 2024-10-28 21/week @ 2024-11-04 5/week @ 2024-11-18

54 downloads per month
Used in 5 crates (3 directly)

MIT/Apache

30KB
550 lines

Crates.io Rust

This library contains a collection of tools to help interacting with json encoded data.

Features

  • Simple Json Lexer
    • Without any intention of being feature complete, it is able to split ascii json data streams into their lexical tokens, keeping track of the character spans that make them up.
    • facilitates writing higher-level parsers and filters
  • Key-Value Filter
    • A utility to filter lexical tokens which belong to keys that have values of a given type. This makes it easy to re-assemble json data streams and strip them off their null values, for example.
  • TokenReader
    • An adapter to convert a stream of Tokens into a stream of bytes, supprting the Read trait.
    • Use it to convert filtered and/or manipulated token-streams back into byte-streams.
    • Configure the output style, to achieve effects like pretty-printing or strip the output of all whitespace.

Usage

Add this to your Cargo.toml

[dependencies]
json-tools = "*"

Add this to your lib ...

use json_tools::BufferType;
use json_tools::Lexer;

for token in Lexer::new(r#"{ "face": "😂" }"#.bytes(), BufferType::Span) {
	println!("{:?}", token);
}

Motivation

This library may possibly never grow bigger than the two features originally mentioned, as it was created as a workaround to missing features in serde.

Manual

Run tests with cargo test and benchmarks with cargo bench (works on stable).

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

No runtime deps