2 releases

0.1.1 Jul 5, 2021
0.1.0 Dec 6, 2020

#2114 in Encoding

47 downloads per month

Apache-2.0 OR MIT OR Zlib

56KB
1.5K SLoC

smoljson

Build Status Docs Latest Version

This is a minimalist JSON library that trades away several desirable qualities (ergonomics, performance, ...) in favor of small code size and fast compiles.

It doesn't support serde, or any other custom derive. I'm not particularly happy with the API, and will likely change it to be better in the future. As a result, docs are somewhat sparse.

Basic usage

use smoljson::Value;
let v = Value::from_str(r#"{"foo": [1, 2, {"bar": 3}]}"#).unwrap();
let expected = smoljson::json!({"foo": [1, 2, {"bar": 3}]});
assert_eq!(v, expected);

JSON with Comments (CJSON) support

By default, strictly correct JSON is required, which excludes comments. However, the crate and parsers can be configured to support parsing JSON that contains JavaScript-style comments (AKA CJSON).

See the documentation for more info.

No runtime deps

Features