#serde-json #json #serde #framing

no-std json-lines

A no_std + serde compatible message library implementing JSON Lines

2 releases

0.1.1 Nov 21, 2023
0.1.0 Nov 20, 2023

#1047 in Encoding

Download history 583/week @ 2024-07-21 113/week @ 2024-07-28 305/week @ 2024-08-04 149/week @ 2024-08-11 73/week @ 2024-08-18 62/week @ 2024-08-25 58/week @ 2024-09-01 86/week @ 2024-09-08 68/week @ 2024-09-15 114/week @ 2024-09-22 128/week @ 2024-09-29 174/week @ 2024-10-06 165/week @ 2024-10-13 267/week @ 2024-10-20 327/week @ 2024-10-27 233/week @ 2024-11-03

1,005 downloads per month

MIT/Apache

16KB
221 lines

json-lines

Crates.io Documentation Crate License Dependency status build

json-lines is a #![no_std] + serde compatible message library implementing the JSON Lines format.

High-level overview

The crate provides a Rust-language implementation of JSON Lines (JSONL), also known as Newline-Delimited JSON (NDJSON).

The wikipedia page JSON Streaming and jsonlines.org are good resources describing the format.

This crate endeavors to have a similar API to the postcard crate. This way, Rust code can easily switch between JSONL and postcard formats depending on requirements. JSONL is "self-describing" but less efficient, whereas postcard is very compact but requires an out-of-band knowledge of message structure.

The crate contains a #![no_std] implementation for use in, e.g. embedded contexts. The std feature is enabled by defaults and provides things such as the [Error] enum implements the std::error::Error Trait.

The codec feature enables crate::codec::JsonLinesCodec, which provides an implementation of tokio_util::codec::Decoder and tokio_util::codec::Encoder.

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.

Dependencies

~1–7MB
~58K SLoC