29 releases (breaking)

0.23.0 Oct 27, 2023
0.22.1 Jul 27, 2023
0.21.1 Apr 28, 2023
0.21.0 Aug 5, 2022
0.12.2 Jun 7, 2020

#89 in Parser implementations

Download history 17307/week @ 2023-12-07 11735/week @ 2023-12-14 8589/week @ 2023-12-21 13681/week @ 2023-12-28 10668/week @ 2024-01-04 11627/week @ 2024-01-11 20709/week @ 2024-01-18 12920/week @ 2024-01-25 18292/week @ 2024-02-01 12598/week @ 2024-02-08 8944/week @ 2024-02-15 10036/week @ 2024-02-22 12600/week @ 2024-02-29 12714/week @ 2024-03-07 12259/week @ 2024-03-14 8076/week @ 2024-03-21

48,189 downloads per month
Used in 46 crates (25 directly)

MIT license

71KB
2K SLoC

jsonc-parser

JSONC parser implemented in Rust.

Example

To a simple JsonValue:

use jsonc_parser::parse_to_value;

let json_value = parse_to_value(r#"{ "test": 5 } // test"#, &Default::default())?;
// check the json_value here

Or an AST:

use jsonc_parser::parse_to_ast;
use jsonc_parser::CollectOptions;

let parse_result = parse_to_ast(r#"{ "test": 5 } // test"#, &CollectOptions {
    comments: true, // include comments in result
    tokens: true, // include tokens in result
}, &Default::default())?;
// ...inspect parse_result for value, tokens, and comments here...

Serde

If you enable the "serde" feature as follows:

# in Cargo.toml
jsonc-parser = { version = "...", features = ["serde"] }

Then you can use the parse_to_serde_value function to get a serde_json::Value:

use jsonc_parser::parse_to_serde_value;

let json_value = parse_to_serde_value(r#"{ "test": 5 } // test"#, &Default::default())?;

Alternatively, use parse_to_ast then call .into() (ex. let value: serde_json::Value = ast.into();).

Parse Strictly as JSON

Provide ParseOptions and set all the options to false:

use jsonc_parser::parse_to_value;
use jsonc_parser::ParseOptions;

let json_value = parse_to_value(text, &ParseOptions {
  allow_comments: false,
  allow_loose_object_property_names: false,
  allow_trailing_commas: false,
})?;

Dependencies

~0–405KB