JSON streaming parser
=================
[](https://github.com/oxigraph/json-event-parser/actions)
[](https://crates.io/crates/json-event-parser)
[](https://docs.rs/json-event-parser)
JSON event parser is a simple streaming JSON parser and serializer implementation in Rust.
It does not aims to be the fastest or the more versatile JSON parser possible but to be an as simple as possible implementation.
If you want fast and battle-tested code you might prefer to use [json](https://crates.io/crates/json), [serde_json](https://crates.io/crates/serde_json) or [simd-json](https://crates.io/crates/simd-json).
Reader example:
```rust
use json_event_parser::{JsonReader, JsonEvent};
use std::io::Cursor;
let json = b"{\"foo\": 1}";
let mut reader = JsonReader::from_reader(Cursor::new(json));
let mut buffer = Vec::new();
assert_eq!(JsonEvent::StartObject, reader.read_event(&mut buffer)?);
assert_eq!(JsonEvent::ObjectKey("foo"), reader.read_event(&mut buffer)?);
assert_eq!(JsonEvent::Number("1"), reader.read_event(&mut buffer)?);
assert_eq!(JsonEvent::EndObject, reader.read_event(&mut buffer)?);
assert_eq!(JsonEvent::Eof, reader.read_event(&mut buffer)?);
# std::io::Result::Ok(())
```
Writer example:
```rust
use json_event_parser::{JsonWriter, JsonEvent};
let mut buffer = Vec::new();
let mut writer = JsonWriter::from_writer(&mut buffer);
writer.write_event(JsonEvent::StartObject)?;
writer.write_event(JsonEvent::ObjectKey("foo"))?;
writer.write_event(JsonEvent::Number("1"))?;
writer.write_event(JsonEvent::EndObject)?;
assert_eq!(buffer.as_slice(), b"{\"foo\":1}");
# std::io::Result::Ok(())
```
## License
This project is licensed under either of
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or
http://opensource.org/licenses/MIT)
at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Futures by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.